Skip to content

Commit

Permalink
toBeRejectedWithError can expect the error to be Error, not just a su…
Browse files Browse the repository at this point in the history
…btype
  • Loading branch information
sgravrock committed Sep 6, 2019
1 parent 5a219da commit 2d3ac38
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 6 deletions.
7 changes: 2 additions & 5 deletions spec/core/integration/MatchersSpec.js
Expand Up @@ -294,15 +294,12 @@ describe('Matchers (Integration)', function() {
});

describe('toBeRejectedWithError', function() {
function MyCustomError() {}
MyCustomError.prototype = new Error();

verifyPassesAsync(function(env) {
return env.expectAsync(Promise.reject(new MyCustomError())).toBeRejectedWithError(MyCustomError);
return env.expectAsync(Promise.reject(new Error())).toBeRejectedWithError(Error);
});

verifyFailsAsync(function(env) {
return env.expectAsync(Promise.resolve()).toBeRejectedWithError(MyCustomError);
return env.expectAsync(Promise.resolve()).toBeRejectedWithError(Error);
});
});

Expand Down
15 changes: 15 additions & 0 deletions spec/core/matchers/async/toBeRejectedWithErrorSpec.js
Expand Up @@ -27,6 +27,21 @@ describe('#toBeRejectedWithError', function () {
});
});

it('passes when Error matches and is exactly Error', function() {
jasmine.getEnv().requirePromises();

var matcher = jasmineUnderTest.asyncMatchers.toBeRejectedWithError(jasmineUnderTest.matchersUtil),
actual = Promise.reject(new Error());

return matcher.compare(actual, Error).then(function (result) {
expect(result).toEqual(jasmine.objectContaining({
pass: true,
message: 'Expected a promise not to be rejected with Error, but it was.'
}));
});

});

it('passes when Error message matches a string', function () {
jasmine.getEnv().requirePromises();

Expand Down
6 changes: 5 additions & 1 deletion src/core/matchers/async/toBeRejectedWithError.js
Expand Up @@ -76,7 +76,7 @@ getJasmineRequireObj().toBeRejectedWithError = function(j$) {
function getExpectedFromArgs(arg1, arg2) {
var error, message;

if (typeof arg1 === 'function' && j$.isError_(arg1.prototype)) {
if (isErrorConstructor(arg1)) {
error = arg1;
message = arg2;
} else {
Expand All @@ -90,4 +90,8 @@ getJasmineRequireObj().toBeRejectedWithError = function(j$) {
printValue: j$.fnNameFor(error) + (typeof message === 'undefined' ? '' : ': ' + j$.pp(message))
};
}

function isErrorConstructor(value) {
return typeof value === 'function' && (value === Error || j$.isError_(value.prototype));
}
};

0 comments on commit 2d3ac38

Please sign in to comment.