2010-09-17 06:46:55 +08:00
|
|
|
describe("Jasmine Mock Ajax (for jQuery)", function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
var request, anotherRequest, response;
|
|
|
|
var success, error, complete;
|
2010-09-17 06:46:55 +08:00
|
|
|
var sharedContext = {};
|
2011-08-08 04:01:38 +08:00
|
|
|
var prototype = Prototype;
|
2010-09-17 06:46:55 +08:00
|
|
|
|
|
|
|
beforeEach(function() {
|
2011-08-08 04:01:38 +08:00
|
|
|
Prototype = undefined;
|
|
|
|
jasmine.Ajax.useMock();
|
|
|
|
|
2010-09-17 06:46:55 +08:00
|
|
|
success = jasmine.createSpy("onSuccess");
|
|
|
|
error = jasmine.createSpy("onFailure");
|
|
|
|
complete = jasmine.createSpy("onComplete");
|
|
|
|
});
|
|
|
|
|
2011-08-08 04:01:38 +08:00
|
|
|
afterEach(function() {
|
|
|
|
Prototype = prototype;
|
|
|
|
});
|
|
|
|
|
2010-09-17 06:46:55 +08:00
|
|
|
describe("when making a request", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 06:46:55 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should store URL and transport", function() {
|
|
|
|
expect(request.url).toEqual("example.com/someApi");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should queue the request", function() {
|
|
|
|
expect(ajaxRequests.length).toEqual(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should allow access to the queued request", function() {
|
|
|
|
expect(ajaxRequests[0]).toEqual(request);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("and then another request", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 06:46:55 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
anotherRequest = mostRecentAjaxRequest();
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should queue the next request", function() {
|
|
|
|
expect(ajaxRequests.length).toEqual(2);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should allow access to the other queued request", function() {
|
|
|
|
expect(ajaxRequests[1]).toEqual(anotherRequest);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("mostRecentAjaxRequest", function () {
|
|
|
|
|
|
|
|
describe("when there is one request queued", function () {
|
|
|
|
it("should return the request", function() {
|
|
|
|
expect(mostRecentAjaxRequest()).toEqual(request);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when there is more than one request", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 06:46:55 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
anotherRequest = mostRecentAjaxRequest();
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should return the most recent request", function() {
|
|
|
|
expect(mostRecentAjaxRequest()).toEqual(anotherRequest);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when there are no requests", function () {
|
|
|
|
beforeEach(function() {
|
|
|
|
clearAjaxRequests();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should return null", function() {
|
|
|
|
expect(mostRecentAjaxRequest()).toEqual(null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("clearAjaxRequests()", function () {
|
|
|
|
beforeEach(function() {
|
|
|
|
clearAjaxRequests();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should remove all requests", function() {
|
|
|
|
expect(ajaxRequests.length).toEqual(0);
|
|
|
|
expect(mostRecentAjaxRequest()).toEqual(null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
describe("when simulating a response with request.response", function () {
|
2010-09-17 06:46:55 +08:00
|
|
|
describe("and the response is Success", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 07:51:52 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
dataType: 'text',
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
2011-06-03 14:14:58 +08:00
|
|
|
error: error
|
2010-09-17 07:51:52 +08:00
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 07:51:52 +08:00
|
|
|
response = {status: 200, contentType: "text/html", responseText: "OK!"};
|
2010-09-17 06:46:55 +08:00
|
|
|
request.response(response);
|
2010-09-17 07:51:52 +08:00
|
|
|
|
2010-09-17 06:46:55 +08:00
|
|
|
sharedContext.responseCallback = success;
|
|
|
|
sharedContext.status = response.status;
|
|
|
|
sharedContext.contentType = response.contentType;
|
|
|
|
sharedContext.responseText = response.responseText;
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the success handler", function() {
|
|
|
|
expect(success).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should not call the failure handler", function() {
|
|
|
|
expect(error).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
sharedAjaxResponseBehaviorForJQuery_Success(sharedContext);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
describe("and the response is Success, but with JSON", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 07:51:52 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
dataType: 'json',
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 07:51:52 +08:00
|
|
|
var responseObject = {status: 200, contentType: "application/json", responseText: '{"foo":"bar"}'};
|
2010-09-17 06:46:55 +08:00
|
|
|
|
|
|
|
request.response(responseObject);
|
|
|
|
|
|
|
|
sharedContext.responseCallback = success;
|
|
|
|
sharedContext.status = responseObject.status;
|
|
|
|
sharedContext.contentType = responseObject.contentType;
|
|
|
|
sharedContext.responseText = responseObject.responseText;
|
2010-09-17 07:51:52 +08:00
|
|
|
|
|
|
|
response = success.mostRecentCall.args[2];
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the success handler", function() {
|
|
|
|
expect(success).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should not call the failure handler", function() {
|
|
|
|
expect(error).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should return a JavaScript object", function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
expect(success.mostRecentCall.args[0]).toEqual({foo: "bar"});
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
sharedAjaxResponseBehaviorForJQuery_Success(sharedContext);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
describe("the content type defaults to application/json", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 07:51:52 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
dataType: 'json',
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 07:51:52 +08:00
|
|
|
response = {status: 200, responseText: '{"foo": "valid JSON, dammit."}'};
|
2010-09-17 06:46:55 +08:00
|
|
|
request.response(response);
|
|
|
|
|
|
|
|
sharedContext.responseCallback = success;
|
|
|
|
sharedContext.status = response.status;
|
|
|
|
sharedContext.contentType = "application/json";
|
|
|
|
sharedContext.responseText = response.responseText;
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the success handler", function() {
|
|
|
|
expect(success).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should not call the failure handler", function() {
|
|
|
|
expect(error).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
sharedAjaxResponseBehaviorForJQuery_Success(sharedContext);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
describe("and the status/response code is 0", function () {
|
2010-09-17 06:46:55 +08:00
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 06:46:55 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
2010-09-17 07:51:52 +08:00
|
|
|
dataType: "text",
|
2010-09-17 06:46:55 +08:00
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 07:51:52 +08:00
|
|
|
response = {status: 0, responseText: '{"foo": "whoops!"}'};
|
2010-09-17 06:46:55 +08:00
|
|
|
request.response(response);
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
sharedContext.responseCallback = success;
|
2011-02-22 14:27:11 +08:00
|
|
|
sharedContext.status = 304; /* jQuery detects status code zero as 304 when headers are present */
|
2010-09-17 06:46:55 +08:00
|
|
|
sharedContext.contentType = 'application/json';
|
|
|
|
sharedContext.responseText = response.responseText;
|
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
it("should call the success handler", function() {
|
|
|
|
expect(success).toHaveBeenCalled();
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should not call the failure handler", function() {
|
|
|
|
expect(error).not.toHaveBeenCalled();
|
|
|
|
});
|
2010-09-17 07:51:52 +08:00
|
|
|
|
2010-09-17 06:46:55 +08:00
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
sharedAjaxResponseBehaviorForJQuery_Success(sharedContext);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("and the response is error", function () {
|
|
|
|
beforeEach(function() {
|
2011-02-22 14:27:11 +08:00
|
|
|
jQuery.ajax({
|
2010-09-17 07:51:52 +08:00
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
dataType: "text",
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
2011-02-22 14:27:11 +08:00
|
|
|
request = mostRecentAjaxRequest();
|
2010-09-17 07:51:52 +08:00
|
|
|
response = {status: 500, contentType: "text/html", responseText: "(._){"};
|
|
|
|
request.response(response);
|
|
|
|
|
|
|
|
sharedContext.responseCallback = error;
|
|
|
|
sharedContext.status = response.status;
|
|
|
|
sharedContext.contentType = response.contentType;
|
|
|
|
sharedContext.responseText = response.responseText;
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
2010-09-17 07:51:52 +08:00
|
|
|
|
|
|
|
it("should not call the success handler", function() {
|
|
|
|
expect(success).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the failure handler", function() {
|
|
|
|
expect(error).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
sharedAjaxResponseBehaviorForJQuery_Failure(sharedContext);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
2011-02-22 14:33:11 +08:00
|
|
|
|
|
|
|
describe('when simulating a response with request.responseTimeout', function() {
|
|
|
|
beforeEach(function() {
|
|
|
|
jasmine.Clock.useMock();
|
|
|
|
|
|
|
|
jQuery.ajax({
|
|
|
|
url: "example.com/someApi",
|
|
|
|
type: "GET",
|
|
|
|
dataType: "text",
|
|
|
|
success: success,
|
|
|
|
complete: complete,
|
|
|
|
error: error
|
|
|
|
});
|
|
|
|
request = mostRecentAjaxRequest();
|
|
|
|
response = {contentType: "text/html", responseText: "(._){"};
|
|
|
|
request.responseTimeout(response);
|
|
|
|
|
|
|
|
sharedContext.responseCallback = error;
|
|
|
|
sharedContext.status = response.status;
|
|
|
|
sharedContext.contentType = response.contentType;
|
|
|
|
sharedContext.responseText = response.responseText;
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should not call the success handler", function() {
|
|
|
|
expect(success).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the failure handler", function() {
|
|
|
|
expect(error).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should call the complete handler", function() {
|
|
|
|
expect(complete).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
2010-09-17 07:51:52 +08:00
|
|
|
|
|
|
|
function sharedAjaxResponseBehaviorForJQuery_Success(context) {
|
|
|
|
describe("the success response", function () {
|
|
|
|
var xhr;
|
|
|
|
beforeEach(function() {
|
|
|
|
xhr = context.responseCallback.mostRecentCall.args[2];
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected status code", function() {
|
|
|
|
expect(xhr.status).toEqual(context.status);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected content type", function() {
|
|
|
|
expect(xhr.getResponseHeader('Content-type')).toEqual(context.contentType);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected response text", function() {
|
|
|
|
expect(xhr.responseText).toEqual(context.responseText);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function sharedAjaxResponseBehaviorForJQuery_Failure(context) {
|
|
|
|
describe("the failure response", function () {
|
|
|
|
var xhr;
|
2010-09-17 06:46:55 +08:00
|
|
|
beforeEach(function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
xhr = context.responseCallback.mostRecentCall.args[0];
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected status code", function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
expect(xhr.status).toEqual(context.status);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected content type", function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
expect(xhr.getResponseHeader('Content-type')).toEqual(context.contentType);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should have the expected response text", function() {
|
2010-09-17 07:51:52 +08:00
|
|
|
expect(xhr.responseText).toEqual(context.responseText);
|
2010-09-17 06:46:55 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|