mirror of
https://github.com/nasa/openmct.git
synced 2025-01-10 15:02:53 +00:00
433dee0314
* Updated Karma and Jasmine versions * Added DOMObserver class. Supports promise-based testing of DOM changes Update asynchronous test specs to use promises or done() instead of waitsFor/runs * Modified ActionCapability to duplicate context object properties as own properties for better object equality comparisons * Global find + replace to fix syntax issues * Fixed various issues caused by non-deterministic runtime order of tests in Jasmine 3. Fixed issues caused by changes to determination of object equality * Addressed review comments * Resolved merge conflicts with master * Fixed style errors * Use spy.calls.count() instead of manually tracking
312 lines
13 KiB
JavaScript
312 lines
13 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2018, United States Government
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
* Administration. All rights reserved.
|
|
*
|
|
* Open MCT 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 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.
|
|
*****************************************************************************/
|
|
|
|
define(
|
|
["../../src/controllers/TimeRangeController", "moment"],
|
|
function (TimeRangeController, moment) {
|
|
|
|
var SEC = 1000,
|
|
MIN = 60 * SEC,
|
|
HOUR = 60 * MIN,
|
|
DAY = 24 * HOUR;
|
|
|
|
describe("The TimeRangeController", function () {
|
|
var mockScope,
|
|
mockFormatService,
|
|
testDefaultFormat,
|
|
mockTimeout,
|
|
mockNow,
|
|
mockFormat,
|
|
controller;
|
|
|
|
function fireWatch(expr, value) {
|
|
mockScope.$watch.calls.all().forEach(function (call) {
|
|
if (call.args[0] === expr) {
|
|
call.args[1](value);
|
|
}
|
|
});
|
|
}
|
|
|
|
function fireWatchCollection(expr, value) {
|
|
mockScope.$watchCollection.calls.all().forEach(function (call) {
|
|
if (call.args[0] === expr) {
|
|
call.args[1](value);
|
|
}
|
|
});
|
|
}
|
|
|
|
beforeEach(function () {
|
|
mockTimeout = function (fn) {
|
|
return fn();
|
|
};
|
|
|
|
mockScope = jasmine.createSpyObj(
|
|
"$scope",
|
|
["$apply", "$watch", "$watchCollection"]
|
|
);
|
|
mockFormatService = jasmine.createSpyObj(
|
|
"formatService",
|
|
["getFormat"]
|
|
);
|
|
testDefaultFormat = 'utc';
|
|
mockFormat = jasmine.createSpyObj(
|
|
"format",
|
|
["validate", "format", "parse"]
|
|
);
|
|
|
|
mockFormatService.getFormat.and.returnValue(mockFormat);
|
|
|
|
mockFormat.format.and.callFake(function (value) {
|
|
return moment.utc(value).format("YYYY-MM-DD HH:mm:ss");
|
|
});
|
|
|
|
mockNow = jasmine.createSpy('now');
|
|
|
|
controller = new TimeRangeController(
|
|
mockScope,
|
|
mockTimeout,
|
|
mockFormatService,
|
|
testDefaultFormat,
|
|
mockNow
|
|
);
|
|
});
|
|
|
|
it("watches the model that was passed in", function () {
|
|
expect(mockScope.$watchCollection)
|
|
.toHaveBeenCalledWith("ngModel", jasmine.any(Function));
|
|
});
|
|
|
|
it("exposes start time validator", function () {
|
|
var testValue = 42000000;
|
|
mockScope.formModel = { end: testValue };
|
|
expect(controller.validateStart(testValue + 1))
|
|
.toBe(false);
|
|
expect(controller.validateStart(testValue - 60 * 60 * 1000 - 1))
|
|
.toBe(true);
|
|
});
|
|
|
|
it("exposes end time validator", function () {
|
|
var testValue = 42000000;
|
|
mockScope.formModel = { start: testValue };
|
|
expect(controller.validateEnd(testValue - 1))
|
|
.toBe(false);
|
|
expect(controller.validateEnd(testValue + 60 * 60 * 1000 + 1))
|
|
.toBe(true);
|
|
});
|
|
|
|
describe("when changes are made via form entry", function () {
|
|
beforeEach(function () {
|
|
mockScope.ngModel = {
|
|
outer: { start: DAY * 2, end: DAY * 3 },
|
|
inner: { start: DAY * 2.25, end: DAY * 2.75 }
|
|
};
|
|
mockScope.formModel = {
|
|
start: DAY * 10000,
|
|
end: DAY * 11000
|
|
};
|
|
});
|
|
|
|
it('updates all changed bounds when requested', function () {
|
|
fireWatchCollection("formModel", mockScope.formModel);
|
|
fireWatch("formModel.start", mockScope.formModel.start);
|
|
fireWatch("formModel.end", mockScope.formModel.end);
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
|
|
controller.updateBoundsFromForm();
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.toEqual(mockScope.formModel.end);
|
|
});
|
|
|
|
it('updates changed start bound when requested', function () {
|
|
fireWatchCollection("formModel", mockScope.formModel);
|
|
fireWatch("formModel.start", mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
|
|
controller.updateBoundsFromForm();
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
});
|
|
|
|
it('updates changed end bound when requested', function () {
|
|
fireWatchCollection("formModel", mockScope.formModel);
|
|
fireWatch("formModel.end", mockScope.formModel.end);
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.not.toEqual(mockScope.formModel.end);
|
|
|
|
controller.updateBoundsFromForm();
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.not.toEqual(mockScope.formModel.start);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
.toEqual(mockScope.formModel.end);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.toEqual(mockScope.formModel.end);
|
|
});
|
|
});
|
|
|
|
describe("when dragged", function () {
|
|
beforeEach(function () {
|
|
mockScope.ngModel = {
|
|
outer: {
|
|
start: DAY * 1000,
|
|
end: DAY * 1001
|
|
},
|
|
inner: {
|
|
start: DAY * 1000 + HOUR * 3,
|
|
end: DAY * 1001 - HOUR * 3
|
|
}
|
|
};
|
|
mockScope.spanWidth = 1000;
|
|
fireWatch("spanWidth", mockScope.spanWidth);
|
|
fireWatchCollection("ngModel", mockScope.ngModel);
|
|
});
|
|
|
|
it("updates the start time for left drags", function () {
|
|
controller.startLeftDrag();
|
|
controller.leftDrag(250);
|
|
expect(mockScope.ngModel.inner.start)
|
|
.toEqual(DAY * 1000 + HOUR * 9);
|
|
});
|
|
|
|
it("updates the end time for right drags", function () {
|
|
controller.startRightDrag();
|
|
controller.rightDrag(-250);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.toEqual(DAY * 1000 + HOUR * 15);
|
|
});
|
|
|
|
it("updates both start and end for middle drags", function () {
|
|
controller.startMiddleDrag();
|
|
controller.middleDrag(-125);
|
|
expect(mockScope.ngModel.inner).toEqual({
|
|
start: DAY * 1000,
|
|
end: DAY * 1000 + HOUR * 18
|
|
});
|
|
controller.middleDrag(250);
|
|
expect(mockScope.ngModel.inner).toEqual({
|
|
start: DAY * 1000 + HOUR * 6,
|
|
end: DAY * 1001
|
|
});
|
|
});
|
|
|
|
it("enforces a minimum inner span", function () {
|
|
controller.startRightDrag();
|
|
controller.rightDrag(-9999999);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.toBeGreaterThan(mockScope.ngModel.inner.start);
|
|
});
|
|
});
|
|
|
|
describe("when outer bounds are changed", function () {
|
|
beforeEach(function () {
|
|
mockScope.ngModel = {
|
|
outer: {
|
|
start: DAY * 1000,
|
|
end: DAY * 1001
|
|
},
|
|
inner: {
|
|
start: DAY * 1000 + HOUR * 3,
|
|
end: DAY * 1001 - HOUR * 3
|
|
}
|
|
};
|
|
mockScope.spanWidth = 1000;
|
|
fireWatch("spanWidth", mockScope.spanWidth);
|
|
fireWatchCollection("ngModel", mockScope.ngModel);
|
|
});
|
|
|
|
it("enforces a minimum inner span when outer span changes", function () {
|
|
mockScope.ngModel.outer.end =
|
|
mockScope.ngModel.outer.start - DAY * 100;
|
|
fireWatch(
|
|
"ngModel.outer.end",
|
|
mockScope.ngModel.outer.end
|
|
);
|
|
expect(mockScope.ngModel.inner.end)
|
|
.toBeGreaterThan(mockScope.ngModel.inner.start);
|
|
});
|
|
|
|
});
|
|
|
|
it("watches for changes in format selection", function () {
|
|
expect(mockFormatService.getFormat)
|
|
.not.toHaveBeenCalledWith('test-format');
|
|
fireWatch("parameters.format", 'test-format');
|
|
expect(mockFormatService.getFormat)
|
|
.toHaveBeenCalledWith('test-format');
|
|
});
|
|
|
|
it("throws an error for unknown formats", function () {
|
|
mockFormatService.getFormat.and.returnValue(undefined);
|
|
expect(function () {
|
|
fireWatch("parameters.format", "some-format");
|
|
}).toThrow();
|
|
});
|
|
|
|
});
|
|
}
|
|
);
|