mirror of
https://github.com/nasa/openmct.git
synced 2025-06-23 09:25:29 +00:00
[Common UI] Skeleton specs for Browse
Add skeleton specs for browse mode. WTD-574.
This commit is contained in:
125
platform/commonUI/browse/test/BrowseControllerSpec.js
Normal file
125
platform/commonUI/browse/test/BrowseControllerSpec.js
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../src/BrowseController"],
|
||||||
|
function (BrowseController) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The browse controller", function () {
|
||||||
|
var mockScope,
|
||||||
|
mockObjectService,
|
||||||
|
mockNavigationService,
|
||||||
|
mockRootObject,
|
||||||
|
mockDomainObject,
|
||||||
|
controller;
|
||||||
|
|
||||||
|
function mockPromise(value) {
|
||||||
|
return {
|
||||||
|
then: function (callback) {
|
||||||
|
return mockPromise(callback(value));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
mockScope = jasmine.createSpyObj("$scope", [ "$on" ]);
|
||||||
|
mockObjectService = jasmine.createSpyObj(
|
||||||
|
"objectService",
|
||||||
|
[ "getObjects" ]
|
||||||
|
);
|
||||||
|
mockNavigationService = jasmine.createSpyObj(
|
||||||
|
"navigationService",
|
||||||
|
[
|
||||||
|
"getNavigation",
|
||||||
|
"setNavigation",
|
||||||
|
"addListener",
|
||||||
|
"removeListener"
|
||||||
|
]
|
||||||
|
);
|
||||||
|
mockRootObject = jasmine.createSpyObj(
|
||||||
|
"domainObject",
|
||||||
|
[ "getId", "getCapability", "getModel", "useCapability" ]
|
||||||
|
);
|
||||||
|
mockDomainObject = jasmine.createSpyObj(
|
||||||
|
"domainObject",
|
||||||
|
[ "getId", "getCapability", "getModel", "useCapability" ]
|
||||||
|
);
|
||||||
|
|
||||||
|
mockObjectService.getObjects.andReturn(mockPromise({
|
||||||
|
ROOT: mockRootObject
|
||||||
|
}));
|
||||||
|
|
||||||
|
|
||||||
|
controller = new BrowseController(
|
||||||
|
mockScope,
|
||||||
|
mockObjectService,
|
||||||
|
mockNavigationService
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides a means of changing navigation", function () {
|
||||||
|
// Browse template needs a setNavigation function
|
||||||
|
|
||||||
|
// Verify precondition
|
||||||
|
expect(mockNavigationService.setNavigation)
|
||||||
|
.not.toHaveBeenCalled();
|
||||||
|
|
||||||
|
// Set navigation via controller
|
||||||
|
controller.setNavigation(mockDomainObject);
|
||||||
|
|
||||||
|
expect(mockNavigationService.setNavigation)
|
||||||
|
.toHaveBeenCalledWith(mockDomainObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("uses composition to set the navigated object, if there is none", function () {
|
||||||
|
mockRootObject.useCapability.andReturn(mockPromise([
|
||||||
|
mockDomainObject
|
||||||
|
]));
|
||||||
|
controller = new BrowseController(
|
||||||
|
mockScope,
|
||||||
|
mockObjectService,
|
||||||
|
mockNavigationService
|
||||||
|
);
|
||||||
|
expect(mockNavigationService.setNavigation)
|
||||||
|
.toHaveBeenCalledWith(mockDomainObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("does not try to override navigation", function () {
|
||||||
|
// This behavior is needed if object navigation has been
|
||||||
|
// determined by query string parameters
|
||||||
|
mockRootObject.useCapability.andReturn(mockPromise([null]));
|
||||||
|
mockNavigationService.getNavigation.andReturn(mockDomainObject);
|
||||||
|
controller = new BrowseController(
|
||||||
|
mockScope,
|
||||||
|
mockObjectService,
|
||||||
|
mockNavigationService
|
||||||
|
);
|
||||||
|
expect(mockScope.navigatedObject).toBe(mockDomainObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("updates scope when navigated object changes", function () {
|
||||||
|
// Should have registered a listener - call it
|
||||||
|
mockNavigationService.addListener.mostRecentCall.args[0](
|
||||||
|
mockDomainObject
|
||||||
|
);
|
||||||
|
expect(mockScope.navigatedObject).toEqual(mockDomainObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("releases its navigation listener when its scope is destroyed", function () {
|
||||||
|
expect(mockScope.$on).toHaveBeenCalledWith(
|
||||||
|
"$destroy",
|
||||||
|
jasmine.any(Function)
|
||||||
|
);
|
||||||
|
mockScope.$on.mostRecentCall.args[1]();
|
||||||
|
// Should remove the listener it added earlier
|
||||||
|
expect(mockNavigationService.removeListener).toHaveBeenCalledWith(
|
||||||
|
mockNavigationService.addListener.mostRecentCall.args[0]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
16
platform/commonUI/browse/test/ViewSwitcherControllerSpec.js
Normal file
16
platform/commonUI/browse/test/ViewSwitcherControllerSpec.js
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../src/ViewSwitcherController"],
|
||||||
|
function (BrowseController) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The view switcher controller", function () {
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/creation/CreateActionProvider"],
|
||||||
|
function (CreateActionProvider) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The create action provider", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
15
platform/commonUI/browse/test/creation/CreateActionSpec.js
Normal file
15
platform/commonUI/browse/test/creation/CreateActionSpec.js
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/creation/CreateAction"],
|
||||||
|
function (CreateAction) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The create action", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/creation/CreateMenuController"],
|
||||||
|
function (CreateActionProvider) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The create menu controller", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
15
platform/commonUI/browse/test/creation/CreateWizardSpec.js
Normal file
15
platform/commonUI/browse/test/creation/CreateWizardSpec.js
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/creation/CreateWizard"],
|
||||||
|
function (CreateWizard) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The create action provider", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/creation/CreationService"],
|
||||||
|
function (CreationService) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The creation service", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/navigation/NavigateAction"],
|
||||||
|
function (NavigateAction) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The navigate action", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/navigation/NavigationService"],
|
||||||
|
function (NavigateAction) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The navigation service", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
12
platform/commonUI/browse/test/suite.json
Normal file
12
platform/commonUI/browse/test/suite.json
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
[
|
||||||
|
"BrowseController",
|
||||||
|
"ViewSwitcherController",
|
||||||
|
"creation/CreateAction",
|
||||||
|
"creation/CreateActionProvider",
|
||||||
|
"creation/CreateMenuController",
|
||||||
|
"creation/CreateWizard",
|
||||||
|
"creation/CreationService",
|
||||||
|
"navigation/NavigateAction",
|
||||||
|
"navigation/NavigationService",
|
||||||
|
"windowing/FullscreenAction"
|
||||||
|
]
|
@ -0,0 +1,15 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MCTRepresentationSpec. Created by vwoeltje on 11/6/14.
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
["../../src/windowing/FullscreenAction"],
|
||||||
|
function (FullscreenAction) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("The fullscreen action", function () {
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
Reference in New Issue
Block a user