Skip to content

Commit

Permalink
Adding failing test for #184
Browse files Browse the repository at this point in the history
  • Loading branch information
mzabriskie committed Jan 18, 2016
1 parent 5ac6e8d commit 20e724a
Showing 1 changed file with 40 additions and 14 deletions.
54 changes: 40 additions & 14 deletions test/specs/headers.spec.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,25 @@
var axios = require('../../index');

function testHeaderValue(headers, key, val) {
var found = false;

for (var k in headers) {
if (k.toLowerCase() === key.toLowerCase()) {
found = true;
expect(headers[k]).toEqual(val);
break;
}
}

if (!found) {
if (typeof val === 'undefined') {
expect(headers.hasOwnProperty(key)).toEqual(false);
} else {
throw new Error(key + ' was not found in headers');
}
}
}

describe('headers', function () {
beforeEach(function () {
jasmine.Ajax.install();
Expand All @@ -10,15 +30,14 @@ describe('headers', function () {
});

it('should default common headers', function (done) {
var request;
var headers = axios.defaults.headers.common;

axios({
url: '/foo'
});

setTimeout(function () {
request = jasmine.Ajax.requests.mostRecent();
var request = jasmine.Ajax.requests.mostRecent();

for (var key in headers) {
if (headers.hasOwnProperty(key)) {
Expand All @@ -30,7 +49,6 @@ describe('headers', function () {
});

it('should add extra headers for post', function (done) {
var request;
var headers = axios.defaults.headers.common;

axios({
Expand All @@ -40,7 +58,7 @@ describe('headers', function () {
});

setTimeout(function () {
request = jasmine.Ajax.requests.mostRecent();
var request = jasmine.Ajax.requests.mostRecent();

for (var key in headers) {
if (headers.hasOwnProperty(key)) {
Expand All @@ -52,8 +70,6 @@ describe('headers', function () {
});

it('should use application/json when posting an object', function (done) {
var request;

axios({
url: '/foo/bar',
method: 'post',
Expand All @@ -64,25 +80,35 @@ describe('headers', function () {
});

setTimeout(function () {
request = jasmine.Ajax.requests.mostRecent();

expect(request.requestHeaders['Content-Type']).toEqual('application/json;charset=utf-8');
var request = jasmine.Ajax.requests.mostRecent();
testHeaderValue(request.requestHeaders, 'Content-Type', 'application/json;charset=utf-8');
done();
}, 0);
});

it('should remove content-type if data is empty', function (done) {
var request;
axios({
url: '/foo',
method: 'post'
});

setTimeout(function () {
var request = jasmine.Ajax.requests.mostRecent();
testHeaderValue(request.requestHeaders, 'Content-Type', undefined);
done();
}, 0);
});

xit('should preserve content-type if data is false', function (done) {
axios({
url: '/foo',
method: 'post',
url: '/foo'
data: false
});

setTimeout(function () {
request = jasmine.Ajax.requests.mostRecent();

expect(request.requestHeaders['content-type']).toEqual(undefined);
var request = jasmine.Ajax.requests.mostRecent();
testHeaderValue(request.requestHeaders, 'Content-Type', 'application/x-www-form-urlencoded');
done();
}, 0);
});
Expand Down

0 comments on commit 20e724a

Please sign in to comment.