jasmine-ajax/spec/webmock-style-spec.js

153 lines
4.9 KiB
JavaScript
Raw Normal View History

2013-02-05 11:32:59 +08:00
describe("Webmock style mocking", function() {
var successSpy, errorSpy, response, fakeGlobal, mockAjax;
2013-02-05 11:32:59 +08:00
var sendRequest = function(fakeGlobal, url, method) {
2014-07-29 09:38:06 +08:00
url = url || "http://example.com/someApi";
method = method || 'GET';
var xhr = new fakeGlobal.XMLHttpRequest();
2014-07-29 09:38:06 +08:00
xhr.onreadystatechange = function(args) {
if (this.readyState === (this.DONE || 4)) { // IE 8 doesn't support DONE
2013-02-05 11:32:59 +08:00
response = this;
successSpy();
2013-02-05 11:32:59 +08:00
}
};
xhr.open(method, url);
2013-02-05 11:32:59 +08:00
xhr.send();
2013-02-19 12:37:17 +08:00
};
beforeEach(function() {
successSpy = jasmine.createSpy('success');
fakeGlobal = {XMLHttpRequest: jasmine.createSpy('realXMLHttpRequest')};
2014-07-29 09:38:06 +08:00
mockAjax = new window.MockAjax(fakeGlobal);
mockAjax.install();
2013-02-19 12:37:17 +08:00
mockAjax.stubRequest("http://example.com/someApi").andReturn({responseText: "hi!"});
2013-02-19 12:37:17 +08:00
});
it("allows a url to be setup as a stub", function() {
sendRequest(fakeGlobal);
expect(successSpy).toHaveBeenCalled();
2013-02-19 12:37:17 +08:00
});
it("should allow you to clear all the ajax stubs", function() {
mockAjax.stubs.reset();
sendRequest(fakeGlobal);
expect(successSpy).not.toHaveBeenCalled();
2013-02-05 11:32:59 +08:00
});
it("should set the contentType", function() {
sendRequest(fakeGlobal);
expect(response.getResponseHeader('Content-Type')).toEqual('application/json');
2013-02-05 11:32:59 +08:00
});
it("should set the responseText", function() {
sendRequest(fakeGlobal);
2013-02-05 11:32:59 +08:00
expect(response.responseText).toEqual('hi!');
});
2013-02-19 12:37:17 +08:00
it("should default the status to 200", function() {
sendRequest(fakeGlobal);
2013-02-19 12:37:17 +08:00
expect(response.status).toEqual(200);
});
describe("with another stub for the same url", function() {
beforeEach(function() {
mockAjax.stubRequest("http://example.com/someApi").andReturn({responseText: "no", status: 403});
sendRequest(fakeGlobal);
2013-02-19 12:37:17 +08:00
});
it("should set the status", function() {
expect(response.status).toEqual(403);
});
it("should allow the latest stub to win", function() {
expect(response.responseText).toEqual('no');
});
2013-02-05 11:32:59 +08:00
});
describe('stubs with method specified', function() {
beforeEach(function() {
mockAjax.stubRequest('http://example.com/myApi', null, 'POST').andReturn({responseText: 'post', status: '201'});
mockAjax.stubRequest('http://example.com/myApi', null, 'PUT').andReturn({responseText: 'put', status: '200'});
});
it("does not match a different method", function() {
sendRequest(fakeGlobal, 'http://example.com/myApi', 'GET');
expect(successSpy).not.toHaveBeenCalled();
});
it("matches with the right method", function() {
sendRequest(fakeGlobal, 'http://example.com/myApi', 'POST');
expect(response.responseText).toEqual('post');
});
});
describe("with a query string", function() {
beforeEach(function() {
mockAjax.stubRequest("http://example.com/someApi?foo=bar&baz=quux").andReturn({responseText: "greetings", status: 422});
});
it("should match the query string in any order", function() {
sendRequest(fakeGlobal, "http://example.com/someApi?baz=quux&foo=bar");
expect(response.status).toEqual(422);
expect(response.responseText).toEqual('greetings');
});
});
2014-06-10 23:24:21 +08:00
it("allows stubs to use RegExp", function () {
mockAjax.stubRequest(/thisGuy/).andReturn({responseText: 'regex', status: 200});
sendRequest(fakeGlobal, 'http://www.example.com/thisGuy/thatGuy');
expect(successSpy).toHaveBeenCalled();
expect(response.responseText).toBe('regex');
});
describe("stubbing with form data", function() {
beforeEach(function() {
2014-01-18 03:38:27 +08:00
mockAjax.stubRequest("http://example.com/someApi", 'foo=bar&baz=quux').andReturn({responseText: "form", status: 201});
});
var postRequest = function(data) {
var xhr = new fakeGlobal.XMLHttpRequest();
2014-07-29 09:38:06 +08:00
xhr.onreadystatechange = function(args) {
if (this.readyState === (this.DONE || 4)) { // IE 8 doesn't support DONE
response = this;
successSpy();
}
};
xhr.open("POST", "http://example.com/someApi");
xhr.send(data);
};
it("uses the form data stub when the data matches", function() {
2014-01-18 03:38:27 +08:00
postRequest('foo=bar&baz=quux');
expect(response.status).toEqual(201);
expect(response.responseText).toEqual('form');
});
it("matches data params in any order", function() {
postRequest('baz=quux&foo=bar');
expect(response.status).toEqual(201);
expect(response.responseText).toEqual('form');
});
it("falls back to the stub without data specified if the data doesn't match", function() {
2014-01-18 03:38:27 +08:00
postRequest('foo=bar');
expect(response.status).toEqual(200);
expect(response.responseText).toEqual('hi!');
});
it("uses the stub without data specified if no data is passed", function() {
postRequest();
expect(response.status).toEqual(200);
expect(response.responseText).toEqual('hi!');
});
});
2013-02-05 11:32:59 +08:00
});