mirror of
https://github.com/nasa/openmct.git
synced 2025-06-18 15:18:12 +00:00
[persistence] #58 added tests for notification on persistence error
This commit is contained in:
@ -89,16 +89,28 @@ define(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function formatError(error){
|
||||||
|
if (error && error.message) {
|
||||||
|
return error.message;
|
||||||
|
} else if (error && typeof error === "string"){
|
||||||
|
return error;
|
||||||
|
} else {
|
||||||
|
return "unknown error";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display a notification message if an error has occurred during
|
* Display a notification message if an error has occurred during
|
||||||
* persistence.
|
* persistence.
|
||||||
*/
|
*/
|
||||||
function notifyOnError(error, domainObject, notificationService, $q){
|
function notifyOnError(error, domainObject, notificationService, $q){
|
||||||
var errorMessage = "Unable to persist " + domainObject.model.name + ": ";
|
var errorMessage = "Unable to persist " + domainObject.getModel().name;
|
||||||
errorMessage += typeof error === "string" ? error : error.message;
|
if (error) {
|
||||||
|
errorMessage += ": " + formatError(error);
|
||||||
|
}
|
||||||
|
|
||||||
notificationService.error({
|
notificationService.error({
|
||||||
title: "Error persisting " + domainObject.model.name,
|
title: "Error persisting " + domainObject.getModel().name,
|
||||||
hint: errorMessage || "Unknown error"
|
hint: errorMessage || "Unknown error"
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
* at runtime from the About dialog for additional information.
|
* at runtime from the About dialog for additional information.
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
/*jslint es5: true */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PersistenceCapabilitySpec. Created by vwoeltje on 11/6/14.
|
* PersistenceCapabilitySpec. Created by vwoeltje on 11/6/14.
|
||||||
@ -34,24 +35,36 @@ define(
|
|||||||
mockIdentifierService,
|
mockIdentifierService,
|
||||||
mockDomainObject,
|
mockDomainObject,
|
||||||
mockIdentifier,
|
mockIdentifier,
|
||||||
|
mockAlertService,
|
||||||
|
mockQ,
|
||||||
id = "object id",
|
id = "object id",
|
||||||
model = { someKey: "some value"},
|
model,
|
||||||
SPACE = "some space",
|
SPACE = "some space",
|
||||||
persistence;
|
persistence,
|
||||||
|
happyPromise;
|
||||||
|
|
||||||
function asPromise(value) {
|
function asPromise(value, doCatch) {
|
||||||
return (value || {}).then ? value : {
|
return (value || {}).then ? value : {
|
||||||
then: function (callback) {
|
then: function (callback) {
|
||||||
return asPromise(callback(value));
|
return asPromise(callback(value));
|
||||||
|
},
|
||||||
|
catch: function(callback) {
|
||||||
|
//Define a default 'happy' catch, that skips over the
|
||||||
|
// catch callback
|
||||||
|
return doCatch ? asPromise(callback(value)): asPromise(value);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
happyPromise = asPromise(true);
|
||||||
|
model = { someKey: "some value", name: "domain object"};
|
||||||
|
|
||||||
mockPersistenceService = jasmine.createSpyObj(
|
mockPersistenceService = jasmine.createSpyObj(
|
||||||
"persistenceService",
|
"persistenceService",
|
||||||
[ "updateObject", "readObject", "createObject", "deleteObject" ]
|
[ "updateObject", "readObject", "createObject", "deleteObject" ]
|
||||||
);
|
);
|
||||||
|
|
||||||
mockIdentifierService = jasmine.createSpyObj(
|
mockIdentifierService = jasmine.createSpyObj(
|
||||||
'identifierService',
|
'identifierService',
|
||||||
[ 'parse', 'generate' ]
|
[ 'parse', 'generate' ]
|
||||||
@ -60,6 +73,15 @@ define(
|
|||||||
'identifier',
|
'identifier',
|
||||||
[ 'getSpace', 'getKey', 'getDefinedSpace' ]
|
[ 'getSpace', 'getKey', 'getDefinedSpace' ]
|
||||||
);
|
);
|
||||||
|
mockQ = jasmine.createSpyObj(
|
||||||
|
"$q",
|
||||||
|
["reject"]
|
||||||
|
);
|
||||||
|
mockAlertService = jasmine.createSpyObj(
|
||||||
|
"notificationService",
|
||||||
|
["error"]
|
||||||
|
);
|
||||||
|
|
||||||
mockDomainObject = {
|
mockDomainObject = {
|
||||||
getId: function () { return id; },
|
getId: function () { return id; },
|
||||||
getModel: function () { return model; },
|
getModel: function () { return model; },
|
||||||
@ -76,10 +98,17 @@ define(
|
|||||||
persistence = new PersistenceCapability(
|
persistence = new PersistenceCapability(
|
||||||
mockPersistenceService,
|
mockPersistenceService,
|
||||||
mockIdentifierService,
|
mockIdentifierService,
|
||||||
|
mockAlertService,
|
||||||
|
mockQ,
|
||||||
mockDomainObject
|
mockDomainObject
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe("successful persistence", function() {
|
||||||
|
beforeEach(function () {
|
||||||
|
mockPersistenceService.updateObject.andReturn(happyPromise);
|
||||||
|
mockPersistenceService.createObject.andReturn(happyPromise);
|
||||||
|
});
|
||||||
it("creates unpersisted objects with the persistence service", function () {
|
it("creates unpersisted objects with the persistence service", function () {
|
||||||
// Verify precondition; no call made during constructor
|
// Verify precondition; no call made during constructor
|
||||||
expect(mockPersistenceService.createObject).not.toHaveBeenCalled();
|
expect(mockPersistenceService.createObject).not.toHaveBeenCalled();
|
||||||
@ -116,16 +145,15 @@ define(
|
|||||||
persistence.persist();
|
persistence.persist();
|
||||||
expect(model.persisted).toEqual(12321);
|
expect(model.persisted).toEqual(12321);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("refreshes the domain object model from persistence", function () {
|
it("refreshes the domain object model from persistence", function () {
|
||||||
var refreshModel = { someOtherKey: "some other value" };
|
var refreshModel = {someOtherKey: "some other value"};
|
||||||
mockPersistenceService.readObject.andReturn(asPromise(refreshModel));
|
mockPersistenceService.readObject.andReturn(asPromise(refreshModel));
|
||||||
persistence.refresh();
|
persistence.refresh();
|
||||||
expect(model).toEqual(refreshModel);
|
expect(model).toEqual(refreshModel);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("does not overwrite unpersisted changes on refresh", function () {
|
it("does not overwrite unpersisted changes on refresh", function () {
|
||||||
var refreshModel = { someOtherKey: "some other value" },
|
var refreshModel = {someOtherKey: "some other value"},
|
||||||
mockCallback = jasmine.createSpy();
|
mockCallback = jasmine.createSpy();
|
||||||
model.modified = 2;
|
model.modified = 2;
|
||||||
model.persisted = 1;
|
model.persisted = 1;
|
||||||
@ -136,6 +164,33 @@ define(
|
|||||||
expect(mockCallback).toHaveBeenCalledWith(false);
|
expect(mockCallback).toHaveBeenCalledWith(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("does not trigger error notification on successful" +
|
||||||
|
" persistence", function () {
|
||||||
|
persistence.persist();
|
||||||
|
expect(mockQ.reject).not.toHaveBeenCalled();
|
||||||
|
expect(mockAlertService.error).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
describe("unsuccessful persistence", function() {
|
||||||
|
var sadPromise = {
|
||||||
|
then: function(callback){
|
||||||
|
return asPromise(callback(0), true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
beforeEach(function () {
|
||||||
|
mockPersistenceService.createObject.andReturn(sadPromise);
|
||||||
|
});
|
||||||
|
it("rejects on falsey persistence result", function () {
|
||||||
|
persistence.persist();
|
||||||
|
expect(mockQ.reject).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("notifies user on persistence failure", function () {
|
||||||
|
persistence.persist();
|
||||||
|
expect(mockQ.reject).toHaveBeenCalled();
|
||||||
|
expect(mockAlertService.error).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
Reference in New Issue
Block a user