rejectValue wraps non-Errors like throwError does
This commit is contained in:
@@ -150,6 +150,20 @@ describe("SpyStrategy", function() {
|
|||||||
}).catch(done.fail);
|
}).catch(done.fail);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("allows a non-Error to be rejected, wrapping it in an exception when executed", function(done) {
|
||||||
|
jasmine.getEnv().requirePromises();
|
||||||
|
|
||||||
|
var originalFn = jasmine.createSpy("original"),
|
||||||
|
getPromise = function() { return Promise; },
|
||||||
|
spyStrategy = new jasmineUnderTest.SpyStrategy({fn: originalFn, getPromise: getPromise});
|
||||||
|
|
||||||
|
spyStrategy.rejectValue('oops');
|
||||||
|
spyStrategy.exec().then(done.fail).catch(function (error) {
|
||||||
|
expect(error).toEqual(new Error('oops'));
|
||||||
|
done();
|
||||||
|
}).catch(done.fail);
|
||||||
|
});
|
||||||
|
|
||||||
it("fails if promises are not available", function() {
|
it("fails if promises are not available", function() {
|
||||||
var originalFn = jasmine.createSpy("original"),
|
var originalFn = jasmine.createSpy("original"),
|
||||||
spyStrategy = new jasmineUnderTest.SpyStrategy({fn: originalFn});
|
spyStrategy = new jasmineUnderTest.SpyStrategy({fn: originalFn});
|
||||||
|
|||||||
@@ -60,8 +60,10 @@ getJasmineRequireObj().SpyStrategy = function(j$) {
|
|||||||
*/
|
*/
|
||||||
this.rejectValue = function(value) {
|
this.rejectValue = function(value) {
|
||||||
var Promise = requirePromise('rejectValue');
|
var Promise = requirePromise('rejectValue');
|
||||||
|
var error = (value instanceof Error) ? value : new Error(value);
|
||||||
|
|
||||||
self.plan = function() {
|
self.plan = function() {
|
||||||
return Promise.reject(value);
|
return Promise.reject(error);
|
||||||
};
|
};
|
||||||
return self.getSpy();
|
return self.getSpy();
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user