I zamień Jasmine's toThrow matcher na następujące, co pozwala dopasować właściwość nazwy wyjątku lub jego właściwość komunikatu. Dla mnie to sprawia, że testy łatwiej napisać i mniej kruche, jak mogę zrobić następujące:
throw {
name: "NoActionProvided",
message: "Please specify an 'action' property when configuring the action map."
}
a następnie przetestować z poniższym:
expect (function() {
.. do something
}).toThrow ("NoActionProvided");
To pozwala mi dostosować komunikat wyjątku później bez zerwania testy, gdy ważne jest, aby rzucił oczekiwany typ wyjątku.
Jest to zamiennik toThrow że pozwala na to:
jasmine.Matchers.prototype.toThrow = function(expected) {
var result = false;
var exception;
if (typeof this.actual != 'function') {
throw new Error('Actual is not a function');
}
try {
this.actual();
} catch (e) {
exception = e;
}
if (exception) {
result = (expected === jasmine.undefined || this.env.equals_(exception.message || exception, expected.message || expected) || this.env.equals_(exception.name, expected));
}
var not = this.isNot ? "not " : "";
this.message = function() {
if (exception && (expected === jasmine.undefined || !this.env.equals_(exception.message || exception, expected.message || expected))) {
return ["Expected function " + not + "to throw", expected ? expected.name || expected.message || expected : " an exception", ", but it threw", exception.name || exception.message || exception].join(' ');
} else {
return "Expected function to throw an exception.";
}
};
return result;
};
przekazywać argumenty do funkcji testowane, bez użycia anonimową funkcję, spróbuj 'Function.bind': http://stackoverflow.com/ a/13233194/294855 –