2015-09-15 17:00:41 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* 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,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
|
|
|
|
|
|
|
define(
|
2015-10-21 22:38:58 +00:00
|
|
|
["../../src/controllers/TimeRangeController", "moment"],
|
|
|
|
function (TimeRangeController, moment) {
|
2015-09-15 17:00:41 +00:00
|
|
|
"use strict";
|
|
|
|
|
2015-10-09 14:58:10 +00:00
|
|
|
var SEC = 1000,
|
|
|
|
MIN = 60 * SEC,
|
|
|
|
HOUR = 60 * MIN,
|
|
|
|
DAY = 24 * HOUR;
|
|
|
|
|
2015-09-15 17:00:41 +00:00
|
|
|
describe("The TimeRangeController", function () {
|
|
|
|
var mockScope,
|
2015-10-22 19:17:08 +00:00
|
|
|
mockDateService,
|
2015-09-15 17:00:41 +00:00
|
|
|
mockNow,
|
|
|
|
controller;
|
|
|
|
|
|
|
|
function fireWatch(expr, value) {
|
|
|
|
mockScope.$watch.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === expr) {
|
|
|
|
call.args[1](value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function fireWatchCollection(expr, value) {
|
|
|
|
mockScope.$watchCollection.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === expr) {
|
|
|
|
call.args[1](value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockScope = jasmine.createSpyObj(
|
|
|
|
"$scope",
|
|
|
|
[ "$apply", "$watch", "$watchCollection" ]
|
|
|
|
);
|
2015-10-22 19:17:08 +00:00
|
|
|
mockDateService = jasmine.createSpyObj(
|
|
|
|
"dateService",
|
|
|
|
[ "validate", "format", "parse" ]
|
|
|
|
);
|
|
|
|
mockDateService.validate.andCallFake(function (text) {
|
|
|
|
return moment.utc(text).isValid();
|
|
|
|
});
|
|
|
|
mockDateService.parse.andCallFake(function (text) {
|
|
|
|
return moment.utc(text).valueOf();
|
|
|
|
});
|
|
|
|
mockDateService.format.andCallFake(function (value) {
|
|
|
|
return moment.utc(value).format("YYYY-MM-DD HH:mm:ss");
|
|
|
|
});
|
2015-09-15 17:00:41 +00:00
|
|
|
mockNow = jasmine.createSpy('now');
|
2015-10-22 19:17:08 +00:00
|
|
|
|
|
|
|
controller = new TimeRangeController(
|
|
|
|
mockScope,
|
|
|
|
mockDateService,
|
|
|
|
mockNow
|
|
|
|
);
|
2015-09-15 17:00:41 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("watches the model that was passed in", function () {
|
|
|
|
expect(mockScope.$watchCollection)
|
|
|
|
.toHaveBeenCalledWith("ngModel", jasmine.any(Function));
|
|
|
|
});
|
|
|
|
|
2015-10-09 14:58:10 +00:00
|
|
|
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 () {
|
|
|
|
mockScope.startLeftDrag();
|
|
|
|
mockScope.leftDrag(250);
|
|
|
|
expect(mockScope.ngModel.inner.start)
|
|
|
|
.toEqual(DAY * 1000 + HOUR * 9);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("updates the end time for right drags", function () {
|
|
|
|
mockScope.startRightDrag();
|
|
|
|
mockScope.rightDrag(-250);
|
|
|
|
expect(mockScope.ngModel.inner.end)
|
|
|
|
.toEqual(DAY * 1000 + HOUR * 15);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("updates both start and end for middle drags", function () {
|
|
|
|
mockScope.startMiddleDrag();
|
|
|
|
mockScope.middleDrag(-125);
|
|
|
|
expect(mockScope.ngModel.inner).toEqual({
|
|
|
|
start: DAY * 1000,
|
|
|
|
end: DAY * 1000 + HOUR * 18
|
|
|
|
});
|
|
|
|
mockScope.middleDrag(250);
|
|
|
|
expect(mockScope.ngModel.inner).toEqual({
|
|
|
|
start: DAY * 1000 + HOUR * 6,
|
|
|
|
end: DAY * 1001
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-10-09 16:27:59 +00:00
|
|
|
it("enforces a minimum inner span", function () {
|
|
|
|
mockScope.startRightDrag();
|
|
|
|
mockScope.rightDrag(-9999999);
|
|
|
|
expect(mockScope.ngModel.inner.end)
|
|
|
|
.toBeGreaterThan(mockScope.ngModel.inner.start);
|
|
|
|
});
|
2015-10-09 14:58:10 +00:00
|
|
|
});
|
|
|
|
|
2015-10-09 16:27:59 +00:00
|
|
|
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);
|
|
|
|
});
|
2015-10-09 14:58:10 +00:00
|
|
|
|
2015-10-09 16:27:59 +00:00
|
|
|
it("enforces a minimum outer span", function () {
|
|
|
|
mockScope.ngModel.outer.end =
|
|
|
|
mockScope.ngModel.outer.start - DAY * 100;
|
|
|
|
fireWatch(
|
|
|
|
"ngModel.outer.end",
|
|
|
|
mockScope.ngModel.outer.end
|
|
|
|
);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
|
|
.toBeGreaterThan(mockScope.ngModel.outer.start);
|
|
|
|
|
|
|
|
mockScope.ngModel.outer.start =
|
|
|
|
mockScope.ngModel.outer.end + DAY * 100;
|
|
|
|
fireWatch(
|
|
|
|
"ngModel.outer.start",
|
|
|
|
mockScope.ngModel.outer.start
|
|
|
|
);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
|
|
.toBeGreaterThan(mockScope.ngModel.outer.start);
|
|
|
|
});
|
2015-10-09 14:58:10 +00:00
|
|
|
|
2015-10-09 16:27:59 +00:00
|
|
|
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);
|
|
|
|
});
|
2015-10-21 22:38:58 +00:00
|
|
|
|
|
|
|
describe("by typing", function () {
|
|
|
|
it("updates models", function () {
|
|
|
|
var newStart = "1977-05-25 17:30:00",
|
|
|
|
newEnd = "2015-12-18 03:30:00";
|
|
|
|
|
|
|
|
mockScope.boundsModel.start = newStart;
|
|
|
|
fireWatch("boundsModel.start", newStart);
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
|
|
.toEqual(moment.utc(newStart).valueOf());
|
|
|
|
expect(mockScope.boundsModel.startValid)
|
|
|
|
.toBeTruthy();
|
|
|
|
|
|
|
|
mockScope.boundsModel.end = newEnd;
|
|
|
|
fireWatch("boundsModel.end", newEnd);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
|
|
.toEqual(moment.utc(newEnd).valueOf());
|
|
|
|
expect(mockScope.boundsModel.endValid)
|
|
|
|
.toBeTruthy();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("displays error state", function () {
|
|
|
|
var newStart = "Not a date",
|
|
|
|
newEnd = "Definitely not a date",
|
|
|
|
oldStart = mockScope.ngModel.outer.start,
|
|
|
|
oldEnd = mockScope.ngModel.outer.end;
|
|
|
|
|
|
|
|
mockScope.boundsModel.start = newStart;
|
|
|
|
fireWatch("boundsModel.start", newStart);
|
|
|
|
expect(mockScope.ngModel.outer.start)
|
|
|
|
.toEqual(oldStart);
|
|
|
|
expect(mockScope.boundsModel.startValid)
|
|
|
|
.toBeFalsy();
|
|
|
|
|
|
|
|
mockScope.boundsModel.end = newEnd;
|
|
|
|
fireWatch("boundsModel.end", newEnd);
|
|
|
|
expect(mockScope.ngModel.outer.end)
|
|
|
|
.toEqual(oldEnd);
|
|
|
|
expect(mockScope.boundsModel.endValid)
|
|
|
|
.toBeFalsy();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("does not modify user input", function () {
|
|
|
|
// Don't want the controller "fixing" bad or
|
|
|
|
// irregularly-formatted input out from under
|
|
|
|
// the user's fingertips.
|
|
|
|
var newStart = "Not a date",
|
|
|
|
newEnd = "2015-3-3 01:02:04",
|
|
|
|
oldStart = mockScope.ngModel.outer.start,
|
|
|
|
oldEnd = mockScope.ngModel.outer.end;
|
|
|
|
|
|
|
|
mockScope.boundsModel.start = newStart;
|
|
|
|
fireWatch("boundsModel.start", newStart);
|
|
|
|
expect(mockScope.boundsModel.start)
|
|
|
|
.toEqual(newStart);
|
|
|
|
|
|
|
|
mockScope.boundsModel.end = newEnd;
|
|
|
|
fireWatch("boundsModel.end", newEnd);
|
|
|
|
expect(mockScope.boundsModel.end)
|
|
|
|
.toEqual(newEnd);
|
|
|
|
});
|
|
|
|
});
|
2015-10-09 14:58:10 +00:00
|
|
|
});
|
2015-09-15 17:00:41 +00:00
|
|
|
|
2015-10-21 22:38:58 +00:00
|
|
|
|
|
|
|
|
2015-09-15 17:00:41 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|