mirror of
https://github.com/nasa/openmct.git
synced 2025-01-08 22:12:42 +00:00
217 lines
8.2 KiB
JavaScript
217 lines
8.2 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
* Administration. All rights reserved.
|
|
*
|
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations
|
|
* under the License.
|
|
*
|
|
* Open MCT Web includes source code licensed under additional open source
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
* this source code distribution or the Licensing information page available
|
|
* at runtime from the About dialog for additional information.
|
|
*****************************************************************************/
|
|
/*global define,describe,it,expect,beforeEach,waitsFor,afterEach,jasmine*/
|
|
|
|
define(
|
|
["../src/ConductorRepresenter", "./TestTimeConductor"],
|
|
function (ConductorRepresenter, TestTimeConductor) {
|
|
"use strict";
|
|
|
|
var SCOPE_METHODS = [
|
|
'$on',
|
|
'$watch',
|
|
'$broadcast',
|
|
'$emit',
|
|
'$new',
|
|
'$destroy'
|
|
],
|
|
ELEMENT_METHODS = [
|
|
'hasClass',
|
|
'addClass',
|
|
'removeClass',
|
|
'css',
|
|
'after',
|
|
'remove'
|
|
];
|
|
|
|
describe("ConductorRepresenter", function () {
|
|
var mockConductorService,
|
|
mockCompile,
|
|
testViews,
|
|
mockScope,
|
|
mockElement,
|
|
mockConductor,
|
|
mockCompiledTemplate,
|
|
mockNewScope,
|
|
mockNewElement,
|
|
representer;
|
|
|
|
function fireWatch(scope, watch, value) {
|
|
scope.$watch.calls.forEach(function (call) {
|
|
if (call.args[0] === watch) {
|
|
call.args[1](value);
|
|
}
|
|
});
|
|
}
|
|
|
|
beforeEach(function () {
|
|
mockConductorService = jasmine.createSpyObj(
|
|
'conductorService',
|
|
['getConductor']
|
|
);
|
|
mockCompile = jasmine.createSpy('$compile');
|
|
testViews = [ { someKey: "some value" } ];
|
|
mockScope = jasmine.createSpyObj('scope', SCOPE_METHODS);
|
|
mockElement = jasmine.createSpyObj('element', ELEMENT_METHODS);
|
|
mockConductor = new TestTimeConductor();
|
|
mockCompiledTemplate = jasmine.createSpy('template');
|
|
mockNewScope = jasmine.createSpyObj('newScope', SCOPE_METHODS);
|
|
mockNewElement = jasmine.createSpyObj('newElement', ELEMENT_METHODS);
|
|
mockNewElement[0] = mockNewElement;
|
|
|
|
mockConductorService.getConductor.andReturn(mockConductor);
|
|
mockCompile.andReturn(mockCompiledTemplate);
|
|
mockCompiledTemplate.andReturn(mockNewElement);
|
|
mockScope.$new.andReturn(mockNewScope);
|
|
|
|
representer = new ConductorRepresenter(
|
|
mockConductorService,
|
|
mockCompile,
|
|
testViews,
|
|
mockScope,
|
|
mockElement
|
|
);
|
|
});
|
|
|
|
afterEach(function () {
|
|
representer.destroy();
|
|
});
|
|
|
|
it("adds a conductor to views", function () {
|
|
representer.represent(testViews[0], {});
|
|
expect(mockElement.after).toHaveBeenCalledWith(mockNewElement);
|
|
});
|
|
|
|
it("adds nothing to non-view representations", function () {
|
|
representer.represent({ someKey: "something else" }, {});
|
|
expect(mockElement.after).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("removes the conductor when destroyed", function () {
|
|
representer.represent(testViews[0], {});
|
|
expect(mockNewElement.remove).not.toHaveBeenCalled();
|
|
representer.destroy();
|
|
expect(mockNewElement.remove).toHaveBeenCalled();
|
|
});
|
|
|
|
it("destroys any new scope created", function () {
|
|
representer.represent(testViews[0], {});
|
|
representer.destroy();
|
|
expect(mockNewScope.$destroy.calls.length)
|
|
.toEqual(mockScope.$new.calls.length);
|
|
});
|
|
|
|
it("exposes conductor state in scope", function () {
|
|
mockConductor.queryStart.andReturn(42);
|
|
mockConductor.queryEnd.andReturn(12321);
|
|
mockConductor.displayStart.andReturn(1977);
|
|
mockConductor.displayEnd.andReturn(1984);
|
|
representer.represent(testViews[0], {});
|
|
|
|
expect(mockNewScope.ngModel.conductor).toEqual({
|
|
inner: { start: 1977, end: 1984 },
|
|
outer: { start: 42, end: 12321 }
|
|
});
|
|
});
|
|
|
|
it("updates conductor state from scope", function () {
|
|
var testState = {
|
|
inner: { start: 42, end: 1984 },
|
|
outer: { start: -1977, end: 12321 }
|
|
};
|
|
|
|
representer.represent(testViews[0], {});
|
|
|
|
mockNewScope.ngModel.conductor = testState;
|
|
|
|
fireWatch(
|
|
mockNewScope,
|
|
'ngModel.conductor.inner.start',
|
|
testState.inner.start
|
|
);
|
|
expect(mockConductor.displayStart).toHaveBeenCalledWith(42);
|
|
|
|
fireWatch(
|
|
mockNewScope,
|
|
'ngModel.conductor.inner.end',
|
|
testState.inner.end
|
|
);
|
|
expect(mockConductor.displayEnd).toHaveBeenCalledWith(1984);
|
|
|
|
fireWatch(
|
|
mockNewScope,
|
|
'ngModel.conductor.outer.start',
|
|
testState.outer.start
|
|
);
|
|
expect(mockConductor.queryStart).toHaveBeenCalledWith(-1977);
|
|
|
|
fireWatch(
|
|
mockNewScope,
|
|
'ngModel.conductor.outer.end',
|
|
testState.outer.end
|
|
);
|
|
expect(mockConductor.queryEnd).toHaveBeenCalledWith(12321);
|
|
});
|
|
|
|
it("exposes domain selection in scope", function () {
|
|
representer.represent(testViews[0], null);
|
|
|
|
expect(mockNewScope.ngModel.domain)
|
|
.toEqual(mockConductor.domain());
|
|
});
|
|
|
|
it("exposes domain options in scope", function () {
|
|
representer.represent(testViews[0], null);
|
|
|
|
mockConductor.domainOptions().forEach(function (option, i) {
|
|
expect(mockNewScope.ngModel.options[i].value)
|
|
.toEqual(option.key);
|
|
expect(mockNewScope.ngModel.options[i].name)
|
|
.toEqual(option.name);
|
|
});
|
|
});
|
|
|
|
it("updates domain selection from scope", function () {
|
|
var choice;
|
|
representer.represent(testViews[0], null);
|
|
|
|
// Choose a domain that isn't currently selected
|
|
mockNewScope.ngModel.options.forEach(function (option) {
|
|
if (option.value !== mockNewScope.ngModel.domain) {
|
|
choice = option.value;
|
|
}
|
|
});
|
|
|
|
expect(mockConductor.domain)
|
|
.not.toHaveBeenCalledWith(choice);
|
|
|
|
mockNewScope.ngModel.domain = choice;
|
|
fireWatch(mockNewScope, "ngModel.domain", choice);
|
|
|
|
expect(mockConductor.domain)
|
|
.toHaveBeenCalledWith(choice);
|
|
});
|
|
|
|
});
|
|
}
|
|
);
|