mirror of
https://github.com/nasa/openmct.git
synced 2025-01-03 03:46:42 +00:00
Merge pull request #319 from nasa/open-status-tracking
[Status] Add status tracking
This commit is contained in:
commit
573e5608fc
@ -29,6 +29,7 @@
|
|||||||
"platform/policy",
|
"platform/policy",
|
||||||
"platform/entanglement",
|
"platform/entanglement",
|
||||||
"platform/search",
|
"platform/search",
|
||||||
|
"platform/status",
|
||||||
|
|
||||||
"example/imagery",
|
"example/imagery",
|
||||||
"example/eventGenerator",
|
"example/eventGenerator",
|
||||||
|
@ -2080,6 +2080,31 @@ objects which has a `relationships` property in their model, whose value is an
|
|||||||
object containing key-value pairs, where keys are strings identifying
|
object containing key-value pairs, where keys are strings identifying
|
||||||
relationship types, and values are arrays of domain object identifiers.
|
relationship types, and values are arrays of domain object identifiers.
|
||||||
|
|
||||||
|
## Status Capability
|
||||||
|
|
||||||
|
The `status` capability provides a way to flag domain objects as possessing
|
||||||
|
certain states, represented as simple strings. These states, in turn, are
|
||||||
|
reflected on `mct-representation` elements as classes (prefixed with
|
||||||
|
`s-status-`.) The `status` capability has the following interface:
|
||||||
|
|
||||||
|
* `get()`: Returns an array of all status strings that currently apply
|
||||||
|
to this object.
|
||||||
|
* `set(status, state)`: Adds or removes a status flag to this domain object.
|
||||||
|
The `status` argument is the string to set; `state` is a boolean
|
||||||
|
indicating whether this status should be included (true) or removed (false).
|
||||||
|
* `listen(callback)`: Listen for changes in status. The provided `callback`
|
||||||
|
will be invoked with an array of all current status strings whenever status
|
||||||
|
changes.
|
||||||
|
|
||||||
|
Plug-ins may add and/or recognize arbitrary status flags. Flags defined
|
||||||
|
and/or supported by the platform are:
|
||||||
|
|
||||||
|
Status | CSS Class | Meaning
|
||||||
|
-----------|--------------------|-----------------------------------
|
||||||
|
`editing` | `s-status-editing` | Domain object is being edited.
|
||||||
|
`pending` | `s-status-pending` | Domain object is partially loaded.
|
||||||
|
|
||||||
|
|
||||||
## Telemetry Capability
|
## Telemetry Capability
|
||||||
|
|
||||||
The telemetry capability provides a means for accessing telemetry data
|
The telemetry capability provides a means for accessing telemetry data
|
||||||
|
2
platform/status/README.md
Normal file
2
platform/status/README.md
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
Facilitates tracking states associated with specific domain
|
||||||
|
objects.
|
23
platform/status/bundle.json
Normal file
23
platform/status/bundle.json
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
{
|
||||||
|
"extensions": {
|
||||||
|
"representers": [
|
||||||
|
{
|
||||||
|
"implementation": "StatusRepresenter.js"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"capabilities": [
|
||||||
|
{
|
||||||
|
"key": "status",
|
||||||
|
"implementation": "StatusCapability.js",
|
||||||
|
"depends": [ "statusService" ]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"services": [
|
||||||
|
{
|
||||||
|
"key": "statusService",
|
||||||
|
"implementation": "StatusService.js",
|
||||||
|
"depends": [ "topic" ]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
100
platform/status/src/StatusCapability.js
Normal file
100
platform/status/src/StatusCapability.js
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The `status` capability can be used to attach information
|
||||||
|
* about the state of a domain object, expressed as simple
|
||||||
|
* string flags.
|
||||||
|
*
|
||||||
|
* Representations of domain objects will also receive CSS
|
||||||
|
* classes which reflect their current status.
|
||||||
|
* (@see platform/status.StatusRepresenter)
|
||||||
|
*
|
||||||
|
* @param {platform/status.StatusService} statusService
|
||||||
|
* the service which will track domain object status
|
||||||
|
* within the application.
|
||||||
|
* @param {DomainObject} the domain object whose status will
|
||||||
|
* be tracked.
|
||||||
|
* @constructor
|
||||||
|
* @memberof platform/status
|
||||||
|
*/
|
||||||
|
function StatusCapability(statusService, domainObject) {
|
||||||
|
this.statusService = statusService;
|
||||||
|
this.domainObject = domainObject;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List all status flags currently set for this domain object.
|
||||||
|
* @returns {string[]} all current status flags.
|
||||||
|
*/
|
||||||
|
StatusCapability.prototype.list = function () {
|
||||||
|
return this.statusService.listStatuses(this.domainObject.getId());
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a status flag is currently set for this domain object.
|
||||||
|
* @param {string} status the status to get
|
||||||
|
* @returns {boolean} true if the flag is present, otherwise false
|
||||||
|
*/
|
||||||
|
StatusCapability.prototype.get = function (status) {
|
||||||
|
return this.list().indexOf(status) !== -1;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a status flag on this domain object.
|
||||||
|
* @param {string} status the status to set
|
||||||
|
* @param {boolean} state true if the domain object should
|
||||||
|
* possess this status, false if it should not
|
||||||
|
*/
|
||||||
|
StatusCapability.prototype.set = function (status, state) {
|
||||||
|
return this.statusService.setStatus(
|
||||||
|
this.domainObject.getId(),
|
||||||
|
status,
|
||||||
|
state
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Listen for changes in this domain object's status.
|
||||||
|
* @param {Function} callback function to invoke on changes;
|
||||||
|
* called with the new status of the domain object, as an
|
||||||
|
* array of strings
|
||||||
|
* @returns {Function} a function which can be used to stop
|
||||||
|
* listening to status changes for this domain object.
|
||||||
|
*/
|
||||||
|
StatusCapability.prototype.listen = function (callback) {
|
||||||
|
return this.statusService.listen(
|
||||||
|
this.domainObject.getId(),
|
||||||
|
callback
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
return StatusCapability;
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
26
platform/status/src/StatusConstants.js
Normal file
26
platform/status/src/StatusConstants.js
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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*/
|
||||||
|
define({
|
||||||
|
CSS_CLASS_PREFIX: 's-status-',
|
||||||
|
TOPIC_PREFIX: 'status:'
|
||||||
|
});
|
96
platform/status/src/StatusRepresenter.js
Normal file
96
platform/status/src/StatusRepresenter.js
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
['./StatusConstants'],
|
||||||
|
function (StatusConstants) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var STATUS_CLASS_PREFIX = StatusConstants.CSS_CLASS_PREFIX;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds/removes CSS classes to `mct-representation`s to reflect the
|
||||||
|
* current status of represented domain objects, as reported by
|
||||||
|
* their `status` capability.
|
||||||
|
*
|
||||||
|
* Statuses are prefixed with `s-status-` to build CSS class names.
|
||||||
|
* As such, when a domain object has the status "pending", its
|
||||||
|
* representations will have the CSS class `s-status-pending`.
|
||||||
|
*
|
||||||
|
* @param {angular.Scope} scope the representation's scope object
|
||||||
|
* @param element the representation's jqLite-wrapped DOM element
|
||||||
|
* @implements {Representer}
|
||||||
|
* @constructor
|
||||||
|
* @memberof platform/status
|
||||||
|
*/
|
||||||
|
function StatusRepresenter(scope, element) {
|
||||||
|
this.element = element;
|
||||||
|
this.lastClasses = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove any status-related classes from this representation.
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
StatusRepresenter.prototype.clearClasses = function () {
|
||||||
|
var element = this.element;
|
||||||
|
this.lastClasses.forEach(function (c) {
|
||||||
|
element.removeClass(c);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
StatusRepresenter.prototype.represent = function (representation, domainObject) {
|
||||||
|
var self = this,
|
||||||
|
statusCapability = domainObject.getCapability('status');
|
||||||
|
|
||||||
|
function updateStatus(flags) {
|
||||||
|
var newClasses = flags.map(function (flag) {
|
||||||
|
return STATUS_CLASS_PREFIX + flag;
|
||||||
|
});
|
||||||
|
|
||||||
|
self.clearClasses();
|
||||||
|
|
||||||
|
newClasses.forEach(function (c) {
|
||||||
|
self.element.addClass(c);
|
||||||
|
});
|
||||||
|
|
||||||
|
self.lastClasses = newClasses;
|
||||||
|
}
|
||||||
|
|
||||||
|
updateStatus(statusCapability.list());
|
||||||
|
this.unlisten = statusCapability.listen(updateStatus);
|
||||||
|
};
|
||||||
|
|
||||||
|
StatusRepresenter.prototype.destroy = function () {
|
||||||
|
this.clearClasses();
|
||||||
|
if (this.unlisten) {
|
||||||
|
this.unlisten();
|
||||||
|
this.unlisten = undefined;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
return StatusRepresenter;
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
92
platform/status/src/StatusService.js
Normal file
92
platform/status/src/StatusService.js
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
['./StatusConstants'],
|
||||||
|
function (StatusConstants) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var STATUS_PREFIX = StatusConstants.TOPIC_PREFIX;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The `statusService` maintains information about the current
|
||||||
|
* status of specific domain objects within the system. Status
|
||||||
|
* is represented as string flags which are present when a
|
||||||
|
* domain object possesses that status, and false when it does
|
||||||
|
* not.
|
||||||
|
*
|
||||||
|
* @param {platform/core.Topic} topic the `topic` service, used
|
||||||
|
* to create/use named listeners.
|
||||||
|
* @constructor
|
||||||
|
* @memberof platform/status
|
||||||
|
*/
|
||||||
|
function StatusService(topic) {
|
||||||
|
this.statusTable = {};
|
||||||
|
this.topic = topic;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all status flags currently set for a domain object.
|
||||||
|
* @param {string} id the identifier of the domain object
|
||||||
|
* @returns {string[]} an array containing all status flags currently
|
||||||
|
* applicable to the object with this identifier
|
||||||
|
*/
|
||||||
|
StatusService.prototype.listStatuses = function (id) {
|
||||||
|
return this.statusTable[id] || [];
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a status flag for a domain object.
|
||||||
|
* @param {string} id the identifier of the domain object
|
||||||
|
* @param {string} status the status to set
|
||||||
|
* @param {boolean} state true if the domain object should
|
||||||
|
* possess this status, false if it should not
|
||||||
|
*/
|
||||||
|
StatusService.prototype.setStatus = function (id, status, state) {
|
||||||
|
this.statusTable[id] = this.statusTable[id] || [];
|
||||||
|
this.statusTable[id] = this.statusTable[id].filter(function (s) {
|
||||||
|
return s !== status;
|
||||||
|
});
|
||||||
|
if (state) {
|
||||||
|
this.statusTable[id].push(status);
|
||||||
|
}
|
||||||
|
this.topic(STATUS_PREFIX + id).notify(this.statusTable[id]);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Listen for changes in a domain object's status.
|
||||||
|
* @param {string} id the identifier of the domain object
|
||||||
|
* @param {Function} callback function to invoke on changes;
|
||||||
|
* called with the new status of the domain object, as an
|
||||||
|
* array of strings
|
||||||
|
* @returns {Function} a function which can be used to stop
|
||||||
|
* listening to status changes for this domain object.
|
||||||
|
*/
|
||||||
|
StatusService.prototype.listen = function (id, callback) {
|
||||||
|
return this.topic(STATUS_PREFIX + id).listen(callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
return StatusService;
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
89
platform/status/test/StatusCapabilitySpec.js
Normal file
89
platform/status/test/StatusCapabilitySpec.js
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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(
|
||||||
|
["../src/StatusCapability"],
|
||||||
|
function (StatusCapability) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The status capability", function () {
|
||||||
|
var mockStatusService,
|
||||||
|
mockDomainObject,
|
||||||
|
mockUnlisten,
|
||||||
|
testId,
|
||||||
|
testStatusFlags,
|
||||||
|
capability;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testId = "some-id";
|
||||||
|
testStatusFlags = [ 'a', 'b', 'c' ];
|
||||||
|
|
||||||
|
mockStatusService = jasmine.createSpyObj(
|
||||||
|
'statusService',
|
||||||
|
[ 'listen', 'setStatus', 'listStatuses' ]
|
||||||
|
);
|
||||||
|
mockDomainObject = jasmine.createSpyObj(
|
||||||
|
'domainObject',
|
||||||
|
[ 'getId', 'getCapability', 'getModel' ]
|
||||||
|
);
|
||||||
|
mockUnlisten = jasmine.createSpy('unlisten');
|
||||||
|
|
||||||
|
mockStatusService.listen.andReturn(mockUnlisten);
|
||||||
|
mockStatusService.listStatuses.andReturn(testStatusFlags);
|
||||||
|
mockDomainObject.getId.andReturn(testId);
|
||||||
|
|
||||||
|
capability = new StatusCapability(
|
||||||
|
mockStatusService,
|
||||||
|
mockDomainObject
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("sets status with the statusService", function () {
|
||||||
|
var testStatus = "some-test-status";
|
||||||
|
capability.set(testStatus, true);
|
||||||
|
expect(mockStatusService.setStatus)
|
||||||
|
.toHaveBeenCalledWith(testId, testStatus, true);
|
||||||
|
capability.set(testStatus, false);
|
||||||
|
expect(mockStatusService.setStatus)
|
||||||
|
.toHaveBeenCalledWith(testId, testStatus, false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("gets status from the statusService", function () {
|
||||||
|
expect(capability.list()).toBe(testStatusFlags);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("listens to changes from the statusService", function () {
|
||||||
|
var mockCallback = jasmine.createSpy();
|
||||||
|
expect(capability.listen(mockCallback))
|
||||||
|
.toBe(mockUnlisten);
|
||||||
|
expect(mockStatusService.listen)
|
||||||
|
.toHaveBeenCalledWith(testId, mockCallback);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows statuses to be checked individually", function () {
|
||||||
|
expect(capability.get('some-unset-status')).toBe(false);
|
||||||
|
expect(capability.get(testStatusFlags[0])).toBe(true);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
118
platform/status/test/StatusRepresenterSpec.js
Normal file
118
platform/status/test/StatusRepresenterSpec.js
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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(
|
||||||
|
["../src/StatusRepresenter", "../src/StatusConstants"],
|
||||||
|
function (StatusRepresenter, StatusConstants) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The status representer", function () {
|
||||||
|
var mockScope,
|
||||||
|
mockElement,
|
||||||
|
testRepresentation,
|
||||||
|
mockDomainObject,
|
||||||
|
mockStatusCapability,
|
||||||
|
mockUnlisten,
|
||||||
|
elementClasses,
|
||||||
|
testStatusFlags,
|
||||||
|
representer;
|
||||||
|
|
||||||
|
function verifyClasses() {
|
||||||
|
expect(Object.keys(elementClasses).sort())
|
||||||
|
.toEqual(testStatusFlags.map(function (s) {
|
||||||
|
return StatusConstants.CSS_CLASS_PREFIX + s;
|
||||||
|
}).sort());
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateStatus(newFlags) {
|
||||||
|
testStatusFlags = newFlags;
|
||||||
|
mockStatusCapability.get.andReturn(newFlags);
|
||||||
|
mockStatusCapability.listen.mostRecentCall
|
||||||
|
.args[0](newFlags);
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testStatusFlags = [ 'x', 'y', 'z' ];
|
||||||
|
|
||||||
|
mockScope = {};
|
||||||
|
mockElement = jasmine.createSpyObj('element', [
|
||||||
|
'addClass',
|
||||||
|
'removeClass'
|
||||||
|
]);
|
||||||
|
testRepresentation = { key: "someKey" };
|
||||||
|
mockDomainObject = jasmine.createSpyObj(
|
||||||
|
'domainObject',
|
||||||
|
[ 'getModel', 'getId', 'getCapability' ]
|
||||||
|
);
|
||||||
|
mockStatusCapability = jasmine.createSpyObj(
|
||||||
|
'status',
|
||||||
|
[ 'list', 'get', 'set', 'listen' ]
|
||||||
|
);
|
||||||
|
mockUnlisten = jasmine.createSpy();
|
||||||
|
|
||||||
|
elementClasses = {};
|
||||||
|
|
||||||
|
mockElement.addClass.andCallFake(function (c) {
|
||||||
|
elementClasses[c] = true;
|
||||||
|
});
|
||||||
|
mockElement.removeClass.andCallFake(function (c) {
|
||||||
|
delete elementClasses[c];
|
||||||
|
});
|
||||||
|
|
||||||
|
mockStatusCapability.list.andReturn(testStatusFlags);
|
||||||
|
mockStatusCapability.listen.andReturn(mockUnlisten);
|
||||||
|
|
||||||
|
mockDomainObject.getCapability.andCallFake(function (c) {
|
||||||
|
return c === 'status' && mockStatusCapability;
|
||||||
|
});
|
||||||
|
|
||||||
|
representer = new StatusRepresenter(mockScope, mockElement);
|
||||||
|
representer.represent(testRepresentation, mockDomainObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("listens for status changes", function () {
|
||||||
|
expect(mockStatusCapability.listen)
|
||||||
|
.toHaveBeenCalledWith(jasmine.any(Function));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("initially sets classes to reflect status", verifyClasses);
|
||||||
|
|
||||||
|
it("changes classes on status change callbacks", function () {
|
||||||
|
updateStatus(['a', 'x', '123']);
|
||||||
|
verifyClasses();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("stops listening when destroyed", function () {
|
||||||
|
expect(mockUnlisten).not.toHaveBeenCalled();
|
||||||
|
representer.destroy();
|
||||||
|
expect(mockUnlisten).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("removes status classes when destroyed", function () {
|
||||||
|
expect(elementClasses).not.toEqual({});
|
||||||
|
representer.destroy();
|
||||||
|
expect(elementClasses).toEqual({});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
94
platform/status/test/StatusServiceSpec.js
Normal file
94
platform/status/test/StatusServiceSpec.js
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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(
|
||||||
|
["../src/StatusService"],
|
||||||
|
function (StatusService) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The status service", function () {
|
||||||
|
var mockTopic,
|
||||||
|
mockTopicInstance,
|
||||||
|
mockUnlisten,
|
||||||
|
mockCallback,
|
||||||
|
testId,
|
||||||
|
testStatus,
|
||||||
|
statusService;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testId = "some-domain-object-identifier";
|
||||||
|
testStatus = "test-status";
|
||||||
|
|
||||||
|
mockTopic = jasmine.createSpy('topic');
|
||||||
|
mockTopicInstance = jasmine.createSpyObj(
|
||||||
|
'topicInstance',
|
||||||
|
[ 'notify', 'listen' ]
|
||||||
|
);
|
||||||
|
mockUnlisten = jasmine.createSpy('unlisten');
|
||||||
|
mockCallback = jasmine.createSpy('callback');
|
||||||
|
|
||||||
|
mockTopic.andReturn(mockTopicInstance);
|
||||||
|
mockTopicInstance.listen.andReturn(mockUnlisten);
|
||||||
|
|
||||||
|
statusService = new StatusService(mockTopic);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("initially contains no flags for an object", function () {
|
||||||
|
expect(statusService.listStatuses(testId)).toEqual([]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("stores and clears status flags", function () {
|
||||||
|
statusService.setStatus(testId, testStatus, true);
|
||||||
|
expect(statusService.listStatuses(testId)).toEqual([testStatus]);
|
||||||
|
statusService.setStatus(testId, testStatus, false);
|
||||||
|
expect(statusService.listStatuses(testId)).toEqual([]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("uses topic to listen for changes", function () {
|
||||||
|
expect(statusService.listen(testId, mockCallback))
|
||||||
|
.toEqual(mockUnlisten);
|
||||||
|
expect(mockTopic)
|
||||||
|
.toHaveBeenCalledWith(jasmine.any(String));
|
||||||
|
// Just care that the topic was somehow unique to the object
|
||||||
|
expect(mockTopic.mostRecentCall.args[0].indexOf(testId))
|
||||||
|
.not.toEqual(-1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("notifies listeners of changes", function () {
|
||||||
|
statusService.setStatus(testId, testStatus, true);
|
||||||
|
expect(mockTopicInstance.notify)
|
||||||
|
.toHaveBeenCalledWith([ testStatus ]);
|
||||||
|
statusService.setStatus(testId, testStatus, false);
|
||||||
|
expect(mockTopicInstance.notify)
|
||||||
|
.toHaveBeenCalledWith([ ]);
|
||||||
|
|
||||||
|
expect(mockTopic)
|
||||||
|
.toHaveBeenCalledWith(jasmine.any(String));
|
||||||
|
// Just care that the topic was somehow unique to the object
|
||||||
|
expect(mockTopic.mostRecentCall.args[0].indexOf(testId))
|
||||||
|
.not.toEqual(-1);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
5
platform/status/test/suite.json
Normal file
5
platform/status/test/suite.json
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[
|
||||||
|
"StatusCapability",
|
||||||
|
"StatusRepresenter",
|
||||||
|
"StatusService"
|
||||||
|
]
|
Loading…
Reference in New Issue
Block a user