我该如何编写一个针对以下代码的QUnit测试:
function doSomethingWithAjax() {
$.ajax({
url: '/GetHelloWorld',
success: function(data) { $("#responseFromServer").text(data); },
});
}
Mockjax + qunit要求在ajax complete()方法中调用 start() 方法。test("should mock ajax", function() {
$.ajax = function(options) {
equals(options.url, "/GetHelloWorld");
options.success("Hello");
};
doSomethingWithAjax();
equal($("#responseFromServer").text(), "Hello");
});
jasmine-ajax 库允许您定义模拟响应,而无需触及调用本身,适用于所有 ajax 调用。
这个问题已经有几年了,对于新版本的jQuery和Jasmine来说有些变化。
如果你不想使用jasmine-ajax,可以尝试Michael Falaga的方法。
function ajax_response(response) {
var deferred = $.Deferred().resolve(response);
return deferred.promise();
}
describe("Test test", function() {
beforeEach(function() {
spyOn($, 'ajax').and.returnValue(
ajax_response([1, 2, 3])
);
});
it("is it [1, 2, 3]", function() {
var response;
$.ajax('GET', 'some/url/i/fancy').done(function(data) {
response = data;
});
expect(response).toEqual([1, 2, 3]);
});
});