mirror of
https://github.com/nasa/openmct.git
synced 2025-01-11 07:23:16 +00:00
433dee0314
* Updated Karma and Jasmine versions * Added DOMObserver class. Supports promise-based testing of DOM changes Update asynchronous test specs to use promises or done() instead of waitsFor/runs * Modified ActionCapability to duplicate context object properties as own properties for better object equality comparisons * Global find + replace to fix syntax issues * Fixed various issues caused by non-deterministic runtime order of tests in Jasmine 3. Fixed issues caused by changes to determination of object equality * Addressed review comments * Resolved merge conflicts with master * Fixed style errors * Use spy.calls.count() instead of manually tracking
248 lines
9.9 KiB
JavaScript
248 lines
9.9 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2018, United States Government
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
* Administration. All rights reserved.
|
|
*
|
|
* Open MCT 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 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 describe,it,expect,beforeEach,jasmine,spyOn*/
|
|
|
|
define(
|
|
["../../src/actions/SaveAsAction"],
|
|
function (SaveAsAction) {
|
|
|
|
describe("The Save As action", function () {
|
|
var mockDomainObject,
|
|
mockClonedObject,
|
|
mockEditorCapability,
|
|
mockActionCapability,
|
|
mockObjectService,
|
|
mockDialogService,
|
|
mockCopyService,
|
|
mockNotificationService,
|
|
mockParent,
|
|
actionContext,
|
|
capabilities = {},
|
|
action;
|
|
|
|
function noop() {}
|
|
|
|
function mockPromise(value) {
|
|
return (value || {}).then ? value :
|
|
{
|
|
then: function (callback) {
|
|
return mockPromise(callback(value));
|
|
},
|
|
catch: function (callback) {
|
|
return mockPromise(callback(value));
|
|
}
|
|
} ;
|
|
}
|
|
|
|
beforeEach(function () {
|
|
mockDomainObject = jasmine.createSpyObj(
|
|
"domainObject",
|
|
[
|
|
"getCapability",
|
|
"hasCapability",
|
|
"getModel",
|
|
"getId"
|
|
]
|
|
);
|
|
mockDomainObject.hasCapability.and.returnValue(true);
|
|
mockDomainObject.getCapability.and.callFake(function (capability) {
|
|
return capabilities[capability];
|
|
});
|
|
mockDomainObject.getModel.and.returnValue({location: 'a', persisted: undefined});
|
|
mockDomainObject.getId.and.returnValue(0);
|
|
|
|
mockClonedObject = jasmine.createSpyObj(
|
|
"clonedObject",
|
|
[
|
|
"getId"
|
|
]
|
|
);
|
|
mockClonedObject.getId.and.returnValue(1);
|
|
|
|
mockParent = jasmine.createSpyObj(
|
|
"parentObject",
|
|
[
|
|
"getCapability",
|
|
"hasCapability",
|
|
"getModel"
|
|
]
|
|
);
|
|
|
|
mockEditorCapability = jasmine.createSpyObj(
|
|
"editor",
|
|
["save", "finish", "isEditContextRoot"]
|
|
);
|
|
mockEditorCapability.save.and.returnValue(mockPromise(true));
|
|
mockEditorCapability.finish.and.returnValue(mockPromise(true));
|
|
mockEditorCapability.isEditContextRoot.and.returnValue(true);
|
|
capabilities.editor = mockEditorCapability;
|
|
|
|
mockActionCapability = jasmine.createSpyObj(
|
|
"action",
|
|
["perform"]
|
|
);
|
|
capabilities.action = mockActionCapability;
|
|
|
|
mockObjectService = jasmine.createSpyObj(
|
|
"objectService",
|
|
["getObjects"]
|
|
);
|
|
mockObjectService.getObjects.and.returnValue(mockPromise({'a': mockParent}));
|
|
|
|
mockDialogService = jasmine.createSpyObj(
|
|
"dialogService",
|
|
[
|
|
"getUserInput",
|
|
"showBlockingMessage"
|
|
]
|
|
);
|
|
mockDialogService.getUserInput.and.returnValue(mockPromise(undefined));
|
|
|
|
mockCopyService = jasmine.createSpyObj(
|
|
"copyService",
|
|
[
|
|
"perform"
|
|
]
|
|
);
|
|
mockCopyService.perform.and.returnValue(mockPromise(mockClonedObject));
|
|
|
|
mockNotificationService = jasmine.createSpyObj(
|
|
"notificationService",
|
|
[
|
|
"info",
|
|
"error"
|
|
]
|
|
);
|
|
|
|
actionContext = {
|
|
domainObject: mockDomainObject
|
|
};
|
|
|
|
action = new SaveAsAction(
|
|
undefined,
|
|
undefined,
|
|
mockDialogService,
|
|
mockCopyService,
|
|
mockNotificationService,
|
|
actionContext);
|
|
|
|
spyOn(action, "getObjectService");
|
|
action.getObjectService.and.returnValue(mockObjectService);
|
|
|
|
spyOn(action, "createWizard");
|
|
action.createWizard.and.returnValue({
|
|
getFormStructure: noop,
|
|
getInitialFormValue: noop,
|
|
populateObjectFromInput: function () {
|
|
return mockDomainObject;
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
it("only applies to domain object with an editor capability", function () {
|
|
expect(SaveAsAction.appliesTo(actionContext)).toBe(true);
|
|
expect(mockDomainObject.hasCapability).toHaveBeenCalledWith("editor");
|
|
|
|
mockDomainObject.hasCapability.and.returnValue(false);
|
|
mockDomainObject.getCapability.and.returnValue(undefined);
|
|
expect(SaveAsAction.appliesTo(actionContext)).toBe(false);
|
|
});
|
|
|
|
it("only applies to domain object that has not already been" +
|
|
" persisted", function () {
|
|
expect(SaveAsAction.appliesTo(actionContext)).toBe(true);
|
|
expect(mockDomainObject.hasCapability).toHaveBeenCalledWith("editor");
|
|
|
|
mockDomainObject.getModel.and.returnValue({persisted: 0});
|
|
expect(SaveAsAction.appliesTo(actionContext)).toBe(false);
|
|
});
|
|
|
|
it("uses the editor capability to save the object", function () {
|
|
mockEditorCapability.save.and.returnValue(Promise.resolve());
|
|
|
|
return action.perform().then(function () {
|
|
expect(mockEditorCapability.save).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
it("uses the editor capability to finish editing the object", function () {
|
|
return action.perform().then(function () {
|
|
expect(mockEditorCapability.finish.calls.count()).toBeGreaterThan(0);
|
|
});
|
|
});
|
|
|
|
it("returns to browse after save", function () {
|
|
spyOn(action, "save");
|
|
action.save.and.returnValue(mockPromise(mockDomainObject));
|
|
action.perform();
|
|
expect(mockActionCapability.perform).toHaveBeenCalledWith(
|
|
"navigate"
|
|
);
|
|
});
|
|
|
|
it("prompts the user for object details", function () {
|
|
action.perform();
|
|
expect(mockDialogService.getUserInput).toHaveBeenCalled();
|
|
});
|
|
|
|
describe("in order to keep the user in the loop", function () {
|
|
var mockDialogHandle;
|
|
|
|
beforeEach(function () {
|
|
mockDialogHandle = jasmine.createSpyObj("dialogHandle", ["dismiss"]);
|
|
mockDialogService.showBlockingMessage.and.returnValue(mockDialogHandle);
|
|
});
|
|
|
|
it("shows a blocking dialog indicating that saving is in progress", function () {
|
|
mockEditorCapability.save.and.returnValue(new Promise(function () {}));
|
|
action.perform();
|
|
expect(mockDialogService.showBlockingMessage).toHaveBeenCalled();
|
|
expect(mockDialogHandle.dismiss).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("hides the blocking dialog after saving finishes", function () {
|
|
return action.perform().then(function () {
|
|
expect(mockDialogService.showBlockingMessage).toHaveBeenCalled();
|
|
expect(mockDialogHandle.dismiss).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
it("notifies if saving succeeded", function () {
|
|
return action.perform().then(function () {
|
|
expect(mockNotificationService.info).toHaveBeenCalled();
|
|
expect(mockNotificationService.error).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
it("notifies if saving failed", function () {
|
|
mockCopyService.perform.and.returnValue(Promise.reject("some failure reason"));
|
|
action.perform().then(function () {
|
|
expect(mockNotificationService.error).toHaveBeenCalled();
|
|
expect(mockNotificationService.info).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
}
|
|
);
|