rejectValue wraps non-Errors like throwError does

This commit is contained in:
Elliot Nelson
2019-05-08 09:36:12 -04:00
parent 4731b4ee4d
commit df818f3fbc
2 changed files with 17 additions and 1 deletions

View File

@@ -150,6 +150,20 @@ describe("SpyStrategy", function() {
}).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() {
var originalFn = jasmine.createSpy("original"),
spyStrategy = new jasmineUnderTest.SpyStrategy({fn: originalFn});

View File

@@ -60,8 +60,10 @@ getJasmineRequireObj().SpyStrategy = function(j$) {
*/
this.rejectValue = function(value) {
var Promise = requirePromise('rejectValue');
var error = (value instanceof Error) ? value : new Error(value);
self.plan = function() {
return Promise.reject(value);
return Promise.reject(error);
};
return self.getSpy();
};