[persistence] #58 added tests for notification on persistence error

This commit is contained in:
Henry
2015-12-03 20:25:28 -08:00
parent fefd27162c
commit 00f96c314a
2 changed files with 124 additions and 57 deletions

View File

@ -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"
}); });

View File

@ -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();
});
});
}); });
} }
); );