2015-05-13 16:42:35 -07:00
|
|
|
/*****************************************************************************
|
2018-05-14 18:46:17 -04:00
|
|
|
* Open MCT, Copyright (c) 2014-2018, United States Government
|
2015-05-13 16:42:35 -07:00
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
2016-07-12 16:21:58 -07:00
|
|
|
* Open MCT is licensed under the Apache License, Version 2.0 (the
|
2015-05-13 16:42:35 -07:00
|
|
|
* "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.
|
|
|
|
*
|
2016-07-12 16:21:58 -07:00
|
|
|
* Open MCT includes source code licensed under additional open source
|
2015-05-13 16:42:35 -07:00
|
|
|
* 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.
|
|
|
|
*****************************************************************************/
|
2014-11-25 18:30:30 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
|
|
|
*/
|
|
|
|
define(
|
2014-12-30 13:40:42 -08:00
|
|
|
["../../src/controllers/ViewSwitcherController"],
|
2014-11-25 19:46:56 -08:00
|
|
|
function (ViewSwitcherController) {
|
2014-11-25 18:30:30 -08:00
|
|
|
|
|
|
|
describe("The view switcher controller", function () {
|
2014-11-25 19:46:56 -08:00
|
|
|
var mockScope,
|
2015-01-16 10:28:35 -08:00
|
|
|
mockTimeout,
|
2014-11-25 19:46:56 -08:00
|
|
|
controller;
|
2014-11-25 18:30:30 -08:00
|
|
|
|
2014-11-25 19:46:56 -08:00
|
|
|
beforeEach(function () {
|
2016-05-19 11:29:13 -07:00
|
|
|
mockScope = jasmine.createSpyObj("$scope", ["$watch"]);
|
2015-01-16 10:28:35 -08:00
|
|
|
mockTimeout = jasmine.createSpy("$timeout");
|
2018-06-29 17:32:59 -07:00
|
|
|
mockTimeout.and.callFake(function (cb) {
|
2016-05-19 11:29:13 -07:00
|
|
|
cb();
|
|
|
|
});
|
2014-12-04 12:17:43 -08:00
|
|
|
mockScope.ngModel = {};
|
2015-01-16 10:28:35 -08:00
|
|
|
controller = new ViewSwitcherController(mockScope, mockTimeout);
|
2014-11-25 19:46:56 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("watches for changes in applicable views", function () {
|
|
|
|
// The view capability is used by associated
|
|
|
|
// representations, so "view" in scope should always
|
|
|
|
// be the list of applicable views. The view switcher
|
|
|
|
// controller should be watching this.
|
|
|
|
expect(mockScope.$watch).toHaveBeenCalledWith(
|
|
|
|
"view",
|
|
|
|
jasmine.any(Function)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("maintains the current selection when views change", function () {
|
|
|
|
var views = [
|
|
|
|
{ key: "a", name: "View A" },
|
|
|
|
{ key: "b", name: "View B" },
|
|
|
|
{ key: "c", name: "View C" },
|
|
|
|
{ key: "d", name: "View D" }
|
|
|
|
];
|
2018-06-29 17:32:59 -07:00
|
|
|
mockScope.$watch.calls.mostRecent().args[1](views);
|
2014-12-04 12:17:43 -08:00
|
|
|
mockScope.ngModel.selected = views[1];
|
2014-11-25 19:46:56 -08:00
|
|
|
|
|
|
|
// Change the set of applicable views
|
2018-06-29 17:32:59 -07:00
|
|
|
mockScope.$watch.calls.mostRecent().args[1]([
|
2014-11-25 19:46:56 -08:00
|
|
|
{ key: "a", name: "View A" },
|
|
|
|
{ key: "b", name: "View B" },
|
|
|
|
{ key: "x", name: "View X" }
|
|
|
|
]);
|
|
|
|
|
|
|
|
// "b" is still in there, should remain selected
|
2014-12-04 12:17:43 -08:00
|
|
|
expect(mockScope.ngModel.selected).toEqual(views[1]);
|
2014-11-25 19:46:56 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("chooses a default if a selected view becomes inapplicable", function () {
|
|
|
|
var views = [
|
|
|
|
{ key: "a", name: "View A" },
|
|
|
|
{ key: "b", name: "View B" },
|
|
|
|
{ key: "c", name: "View C" },
|
|
|
|
{ key: "d", name: "View D" }
|
|
|
|
];
|
2018-06-29 17:32:59 -07:00
|
|
|
mockScope.$watch.calls.mostRecent().args[1](views);
|
2014-12-04 12:17:43 -08:00
|
|
|
mockScope.ngModel.selected = views[1];
|
2014-11-25 19:46:56 -08:00
|
|
|
|
|
|
|
// Change the set of applicable views
|
2018-06-29 17:32:59 -07:00
|
|
|
mockScope.$watch.calls.mostRecent().args[1]([
|
2014-11-25 19:46:56 -08:00
|
|
|
{ key: "a", name: "View A" },
|
|
|
|
{ key: "c", name: "View C" },
|
|
|
|
{ key: "x", name: "View X" }
|
|
|
|
]);
|
|
|
|
|
|
|
|
// "b" is still in there, should remain selected
|
2014-12-04 12:17:43 -08:00
|
|
|
expect(mockScope.ngModel.selected).not.toEqual(views[1]);
|
2014-11-25 19:46:56 -08:00
|
|
|
});
|
2014-11-25 18:30:30 -08:00
|
|
|
|
2015-01-16 10:28:35 -08:00
|
|
|
// Use of a timeout avoids infinite digest problems when deeply
|
|
|
|
// nesting switcher-driven views (e.g. in a layout.) See WTD-689
|
|
|
|
it("updates initial selection on a timeout", function () {
|
|
|
|
// Verify precondition
|
|
|
|
expect(mockTimeout).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
// Invoke the watch for set of views
|
2018-06-29 17:32:59 -07:00
|
|
|
mockScope.$watch.calls.mostRecent().args[1]([]);
|
2015-01-16 10:28:35 -08:00
|
|
|
|
|
|
|
// Should have run on a timeout
|
|
|
|
expect(mockTimeout).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2014-11-25 18:30:30 -08:00
|
|
|
});
|
|
|
|
}
|
2016-05-19 11:29:13 -07:00
|
|
|
);
|