From c46aa3c4b27a2c3b4af060567d4ee63b9d26e5a8 Mon Sep 17 00:00:00 2001 From: Nick Frazier Date: Sat, 8 Oct 2016 08:37:01 -0400 Subject: [PATCH] added tests for simulating empty body responses --- README.md | 14 ++++++++++++++ test/calling_test.js | 31 ++++++++++++++++++++++++++++++- 2 files changed, 44 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index f1ba1f2..da6e577 100644 --- a/README.md +++ b/README.md @@ -145,6 +145,20 @@ var server = new Pretender(function() { }); ``` +You may return `null` or `undefined` instead of a string body, to simulate real-world responses: + +```javascript +var server = new Pretender(function(){ + this.get('/photos/:id/mark_favorite', function(request) { + return [ + 200, + {'content-type': 'application/json'}, + null + ]; + }); +}); +``` + ### Pass-Through You can specify paths that should be ignored by pretender and made as real XHR requests. Enable these by specifying pass-through routes with `pretender.passthrough`: diff --git a/test/calling_test.js b/test/calling_test.js index 3f4532b..e1d1395 100644 --- a/test/calling_test.js +++ b/test/calling_test.js @@ -481,5 +481,34 @@ describe('pretender invoking', function(config) { $.ajax({url: '/some/path'}); }); -}); + it('can return a null body response', function(assert) { + var done = assert.async(); + + this.pretender.get('/some/path', function(req) { + return [200, {'Content-Type': 'application/json'}, null]; + }); + + this.pretender.handledRequest = function(verb, path, request) { + equal(request.responseText, ''); + done(); + }; + + $.ajax({url: '/some/path'}); + }); + + it('can return an undefined body response', function(assert) { + var done = assert.async(); + + this.pretender.get('/some/path', function(req) { + return [200, {'Content-Type': 'application/json'}, undefined]; + }); + + this.pretender.handledRequest = function(verb, path, request) { + equal(request.responseText, ''); + done(); + }; + + $.ajax({url: '/some/path'}); + }); +});