mirror of
https://github.com/nasa/openmct.git
synced 2025-01-23 21:08:00 +00:00
Added tests
This commit is contained in:
parent
8d2c489fa9
commit
5b656faa9d
@ -1,11 +1,37 @@
|
|||||||
define(['EventEmitter'],
|
/*****************************************************************************
|
||||||
function (EventEmitter) {
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
define(['EventEmitter'], function (EventEmitter) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The public API for setting and querying time conductor state. The
|
* The public API for setting and querying time conductor state. The
|
||||||
* TimeConductor is an event emitter and extends the EventEmitter
|
* time conductor is the means by which the temporal bounds of a view
|
||||||
* class. A number of events are fired when properties of the time
|
* are controlled. Time-sensitive views will typically respond to
|
||||||
* conductor change, and these are documented below.
|
* changes to bounds or other properties of the time conductor and
|
||||||
|
* update the data displayed based on the time conductor state.
|
||||||
|
*
|
||||||
|
* The TimeConductor extends the EventEmitter class. A number of events are
|
||||||
|
* fired when properties of the time conductor change, which are
|
||||||
|
* documented below.
|
||||||
* @constructor
|
* @constructor
|
||||||
*/
|
*/
|
||||||
function TimeConductor() {
|
function TimeConductor() {
|
||||||
@ -34,8 +60,8 @@ define(['EventEmitter'],
|
|||||||
* @returns {string | true} A validation error, or true if valid
|
* @returns {string | true} A validation error, or true if valid
|
||||||
*/
|
*/
|
||||||
TimeConductor.prototype.validateBounds = function (bounds) {
|
TimeConductor.prototype.validateBounds = function (bounds) {
|
||||||
if (!bounds.start ||
|
if ((bounds.start === undefined) ||
|
||||||
!bounds.end ||
|
(bounds.end === undefined) ||
|
||||||
isNaN(bounds.start) ||
|
isNaN(bounds.start) ||
|
||||||
isNaN(bounds.end)
|
isNaN(bounds.end)
|
||||||
) {
|
) {
|
||||||
@ -48,19 +74,21 @@ define(['EventEmitter'],
|
|||||||
|
|
||||||
function throwOnError(validationResult) {
|
function throwOnError(validationResult) {
|
||||||
if (validationResult !== true) {
|
if (validationResult !== true) {
|
||||||
throw validationResult;
|
throw new Error(validationResult);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Switch the time conductor between follow and fixed modes. In
|
* Get or set the follow mode of the time conductor. In follow mode the
|
||||||
* follow mode the time conductor ticks.
|
* time conductor ticks, regularly updating the bounds from a timing
|
||||||
|
* source appropriate to the selected time system and mode of the time
|
||||||
|
* conductor.
|
||||||
* @fires TimeConductor#follow
|
* @fires TimeConductor#follow
|
||||||
* @param followMode
|
* @param {boolean} followMode
|
||||||
* @returns {*}
|
* @returns {boolean}
|
||||||
*/
|
*/
|
||||||
TimeConductor.prototype.follow = function (followMode) {
|
TimeConductor.prototype.follow = function (followMode) {
|
||||||
if (arguments.length === 1) {
|
if (arguments.length > 0) {
|
||||||
this.followMode = followMode;
|
this.followMode = followMode;
|
||||||
/**
|
/**
|
||||||
* @event TimeConductor#follow The TimeConductor has toggled
|
* @event TimeConductor#follow The TimeConductor has toggled
|
||||||
@ -68,7 +96,7 @@ define(['EventEmitter'],
|
|||||||
* @property {boolean} followMode true if follow mode is
|
* @property {boolean} followMode true if follow mode is
|
||||||
* enabled, otherwise false.
|
* enabled, otherwise false.
|
||||||
*/
|
*/
|
||||||
this.emit('follow', followMode);
|
this.emit('follow', this.followMode);
|
||||||
}
|
}
|
||||||
return this.followMode;
|
return this.followMode;
|
||||||
};
|
};
|
||||||
@ -79,16 +107,16 @@ define(['EventEmitter'],
|
|||||||
* @property {number} end The end time displayed by the time conductor in ms since epoch.
|
* @property {number} end The end time displayed by the time conductor in ms since epoch.
|
||||||
*/
|
*/
|
||||||
/**
|
/**
|
||||||
* Set the start and end time of the time conductor. Basic validation of bounds is performed.
|
* Get or set the start and end time of the time conductor. Basic validation
|
||||||
|
* of bounds is performed.
|
||||||
*
|
*
|
||||||
* @param {TimeConductorBounds} newBounds
|
* @param {TimeConductorBounds} newBounds
|
||||||
* @param {TimeConductorBounds} should this change trigger a refresh?
|
* @throws {Error} Validation error
|
||||||
* @throws {string} Validation error
|
|
||||||
* @fires TimeConductor#bounds
|
* @fires TimeConductor#bounds
|
||||||
* @returns {TimeConductorBounds}
|
* @returns {TimeConductorBounds}
|
||||||
*/
|
*/
|
||||||
TimeConductor.prototype.bounds = function (newBounds) {
|
TimeConductor.prototype.bounds = function (newBounds) {
|
||||||
if (arguments.length === 1) {
|
if (arguments.length > 0) {
|
||||||
throwOnError(this.validateBounds(newBounds));
|
throwOnError(this.validateBounds(newBounds));
|
||||||
this.boundsVal = newBounds;
|
this.boundsVal = newBounds;
|
||||||
/**
|
/**
|
||||||
@ -102,13 +130,16 @@ define(['EventEmitter'],
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the time system of the TimeConductor. Time systems determine units, epoch, and other aspects of time representation.
|
* Get or set the time system of the TimeConductor. Time systems determine
|
||||||
* @param newTimeSystem
|
* units, epoch, and other aspects of time representation. When changing
|
||||||
|
* the time system in use, new valid bounds must also be provided.
|
||||||
|
* @param {TimeSystem} newTimeSystem
|
||||||
|
* @param {TimeConductorBounds} bounds
|
||||||
* @fires TimeConductor#timeSystem
|
* @fires TimeConductor#timeSystem
|
||||||
* @returns {TimeSystem} The currently applied time system
|
* @returns {TimeSystem} The currently applied time system
|
||||||
*/
|
*/
|
||||||
TimeConductor.prototype.timeSystem = function (newTimeSystem, bounds) {
|
TimeConductor.prototype.timeSystem = function (newTimeSystem, bounds) {
|
||||||
if (arguments.length === 2) {
|
if (arguments.length >= 2) {
|
||||||
this.system = newTimeSystem;
|
this.system = newTimeSystem;
|
||||||
/**
|
/**
|
||||||
* @event TimeConductor#timeSystem The time system used by the time
|
* @event TimeConductor#timeSystem The time system used by the time
|
||||||
@ -129,20 +160,21 @@ define(['EventEmitter'],
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The Time of Interest is the temporal focus of the current view. It can be manipulated by the user from the time
|
* Get or set the Time of Interest. The Time of Interest is the temporal
|
||||||
* conductor or from other views.
|
* focus of the current view. It can be manipulated by the user from the
|
||||||
|
* time conductor or from other views.
|
||||||
* @fires TimeConductor#timeOfInterest
|
* @fires TimeConductor#timeOfInterest
|
||||||
* @param newTOI
|
* @param newTOI
|
||||||
* @returns {*}
|
* @returns {number} the current time of interest
|
||||||
*/
|
*/
|
||||||
TimeConductor.prototype.timeOfInterest = function (newTOI) {
|
TimeConductor.prototype.timeOfInterest = function (newTOI) {
|
||||||
if (arguments.length === 1) {
|
if (arguments.length > 0) {
|
||||||
this.toi = newTOI;
|
this.toi = newTOI;
|
||||||
/**
|
/**
|
||||||
* @event TimeConductor#timeOfInterest The Time of Interest has moved.
|
* @event TimeConductor#timeOfInterest The Time of Interest has moved.
|
||||||
* @property {number} Current time of interest
|
* @property {number} Current time of interest
|
||||||
*/
|
*/
|
||||||
this.emit('timeOfInterest');
|
this.emit('timeOfInterest', this.toi);
|
||||||
}
|
}
|
||||||
return this.toi;
|
return this.toi;
|
||||||
};
|
};
|
||||||
|
110
src/api/TimeConductorSpec.js
Normal file
110
src/api/TimeConductorSpec.js
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
define(['./TimeConductor'], function (TimeConductor) {
|
||||||
|
describe("The Time Conductor", function () {
|
||||||
|
var tc,
|
||||||
|
timeSystem,
|
||||||
|
bounds,
|
||||||
|
eventListener,
|
||||||
|
toi,
|
||||||
|
follow;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
tc = new TimeConductor();
|
||||||
|
timeSystem = {};
|
||||||
|
bounds = {start: 0, end: 0};
|
||||||
|
eventListener = jasmine.createSpy("eventListener");
|
||||||
|
toi = 111;
|
||||||
|
follow = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Supports setting and querying of time of interest and and follow mode", function () {
|
||||||
|
expect(tc.timeOfInterest()).not.toBe(toi);
|
||||||
|
tc.timeOfInterest(toi);
|
||||||
|
expect(tc.timeOfInterest()).toBe(toi);
|
||||||
|
|
||||||
|
expect(tc.follow()).not.toBe(follow);
|
||||||
|
tc.follow(follow);
|
||||||
|
expect(tc.follow()).toBe(follow);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Allows setting of valid bounds", function () {
|
||||||
|
bounds = {start: 0, end: 1};
|
||||||
|
expect(tc.bounds()).not.toBe(bounds);
|
||||||
|
expect(tc.bounds.bind(tc, bounds)).not.toThrow();
|
||||||
|
expect(tc.bounds()).toBe(bounds);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Disallows setting of invalid bounds", function () {
|
||||||
|
bounds = {start: 1, end: 0};
|
||||||
|
expect(tc.bounds()).not.toBe(bounds);
|
||||||
|
expect(tc.bounds.bind(tc, bounds)).toThrow();
|
||||||
|
expect(tc.bounds()).not.toBe(bounds);
|
||||||
|
|
||||||
|
bounds = {start: 1};
|
||||||
|
expect(tc.bounds()).not.toBe(bounds);
|
||||||
|
expect(tc.bounds.bind(tc, bounds)).toThrow();
|
||||||
|
expect(tc.bounds()).not.toBe(bounds);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Allows setting of time system with bounds", function () {
|
||||||
|
expect(tc.timeSystem()).not.toBe(timeSystem);
|
||||||
|
expect(tc.timeSystem.bind(tc, timeSystem, bounds)).not.toThrow();
|
||||||
|
expect(tc.timeSystem()).toBe(timeSystem);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Disallows setting of time system without bounds", function () {
|
||||||
|
expect(tc.timeSystem()).not.toBe(timeSystem);
|
||||||
|
expect(tc.timeSystem.bind(tc, timeSystem)).toThrow();
|
||||||
|
expect(tc.timeSystem()).not.toBe(timeSystem);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Emits an event when time system changes", function () {
|
||||||
|
expect(eventListener).not.toHaveBeenCalled();
|
||||||
|
tc.on("timeSystem", eventListener);
|
||||||
|
tc.timeSystem(timeSystem, bounds);
|
||||||
|
expect(eventListener).toHaveBeenCalledWith(timeSystem);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Emits an event when time of interest changes", function () {
|
||||||
|
expect(eventListener).not.toHaveBeenCalled();
|
||||||
|
tc.on("timeOfInterest", eventListener);
|
||||||
|
tc.timeOfInterest(toi);
|
||||||
|
expect(eventListener).toHaveBeenCalledWith(toi);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Emits an event when bounds change", function () {
|
||||||
|
expect(eventListener).not.toHaveBeenCalled();
|
||||||
|
tc.on("bounds", eventListener);
|
||||||
|
tc.bounds(bounds);
|
||||||
|
expect(eventListener).toHaveBeenCalledWith(bounds);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("Emits an event when follow mode changes", function () {
|
||||||
|
expect(eventListener).not.toHaveBeenCalled();
|
||||||
|
tc.on("follow", eventListener);
|
||||||
|
tc.follow(follow);
|
||||||
|
expect(eventListener).toHaveBeenCalledWith(follow);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user