mirror of
https://github.com/tenrok/axios.git
synced 2026-06-20 20:00:40 +03:00
Adding X-Requested-With header
This commit is contained in:
@@ -25,6 +25,9 @@ module.exports = function xhrAdapter(resolve, reject, config) {
|
|||||||
config.headers || {}
|
config.headers || {}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Indicate that request is being made with XHR
|
||||||
|
requestHeaders['X-Requested-With'] = 'XMLHttpRequest';
|
||||||
|
|
||||||
if (utils.isFormData(data)) {
|
if (utils.isFormData(data)) {
|
||||||
delete requestHeaders['Content-Type']; // Let the browser set it
|
delete requestHeaders['Content-Type']; // Let the browser set it
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,104 @@
|
|||||||
|
var axios = require('../../index');
|
||||||
|
|
||||||
|
describe('headers', function () {
|
||||||
|
beforeEach(function () {
|
||||||
|
jasmine.Ajax.install();
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(function () {
|
||||||
|
jasmine.Ajax.uninstall();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should add X-Requested-With header', function (done) {
|
||||||
|
var request;
|
||||||
|
|
||||||
|
axios({
|
||||||
|
url: '/foo'
|
||||||
|
});
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
request = jasmine.Ajax.requests.mostRecent();
|
||||||
|
|
||||||
|
expect(request.requestHeaders['X-Requested-With']).toEqual('XMLHttpRequest');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
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();
|
||||||
|
|
||||||
|
for (var key in headers) {
|
||||||
|
if (headers.hasOwnProperty(key)) {
|
||||||
|
expect(request.requestHeaders[key]).toEqual(headers[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
done();
|
||||||
|
}, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should add extra headers for post', function (done) {
|
||||||
|
var request;
|
||||||
|
var headers = axios.defaults.headers.common;
|
||||||
|
|
||||||
|
axios({
|
||||||
|
method: 'post',
|
||||||
|
url: '/foo',
|
||||||
|
data: 'fizz=buzz'
|
||||||
|
});
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
request = jasmine.Ajax.requests.mostRecent();
|
||||||
|
|
||||||
|
for (var key in headers) {
|
||||||
|
if (headers.hasOwnProperty(key)) {
|
||||||
|
expect(request.requestHeaders[key]).toEqual(headers[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
done();
|
||||||
|
}, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should use application/json when posting an object', function (done) {
|
||||||
|
var request;
|
||||||
|
|
||||||
|
axios({
|
||||||
|
url: '/foo/bar',
|
||||||
|
method: 'post',
|
||||||
|
data: {
|
||||||
|
firstName: 'foo',
|
||||||
|
lastName: 'bar'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
request = jasmine.Ajax.requests.mostRecent();
|
||||||
|
|
||||||
|
expect(request.requestHeaders['Content-Type']).toEqual('application/json;charset=utf-8');
|
||||||
|
done();
|
||||||
|
}, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should remove content-type if data is empty', function (done) {
|
||||||
|
var request;
|
||||||
|
|
||||||
|
axios({
|
||||||
|
method: 'post',
|
||||||
|
url: '/foo'
|
||||||
|
});
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
request = jasmine.Ajax.requests.mostRecent();
|
||||||
|
|
||||||
|
expect(request.requestHeaders['content-type']).toEqual(undefined);
|
||||||
|
done();
|
||||||
|
}, 0);
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
var axios = require('../../index');
|
var axios = require('../../index');
|
||||||
|
|
||||||
describe('wrapper', function () {
|
describe('requests', function () {
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
jasmine.Ajax.install();
|
jasmine.Ajax.install();
|
||||||
});
|
});
|
||||||
@@ -24,65 +24,35 @@ describe('wrapper', function () {
|
|||||||
}, 0);
|
}, 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should default common headers', function (done) {
|
it('should supply correct response', function (done) {
|
||||||
var request;
|
var request, response;
|
||||||
var headers = axios.defaults.headers.common;
|
|
||||||
|
|
||||||
axios({
|
axios({
|
||||||
|
method: 'post',
|
||||||
url: '/foo'
|
url: '/foo'
|
||||||
|
}).then(function (res) {
|
||||||
|
response = res;
|
||||||
});
|
});
|
||||||
|
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
request = jasmine.Ajax.requests.mostRecent();
|
request = jasmine.Ajax.requests.mostRecent();
|
||||||
|
|
||||||
for (var key in headers) {
|
request.respondWith({
|
||||||
if (headers.hasOwnProperty(key)) {
|
status: 200,
|
||||||
expect(request.requestHeaders[key]).toEqual(headers[key]);
|
statusText: 'OK',
|
||||||
|
responseText: '{"foo": "bar"}',
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'application/json'
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
done();
|
|
||||||
}, 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should add extra headers for post', function (done) {
|
setTimeout(function () {
|
||||||
var request;
|
expect(response.data.foo).toEqual('bar');
|
||||||
var headers = axios.defaults.headers.common;
|
expect(response.status).toEqual(200);
|
||||||
|
expect(response.statusText).toEqual('OK');
|
||||||
axios({
|
expect(response.headers['content-type']).toEqual('application/json');
|
||||||
method: 'post',
|
done();
|
||||||
url: '/foo',
|
}, 0);
|
||||||
data: 'fizz=buzz'
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
request = jasmine.Ajax.requests.mostRecent();
|
|
||||||
|
|
||||||
for (var key in headers) {
|
|
||||||
if (headers.hasOwnProperty(key)) {
|
|
||||||
expect(request.requestHeaders[key]).toEqual(headers[key]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
done();
|
|
||||||
}, 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should use application/json when posting an object', function (done) {
|
|
||||||
var request;
|
|
||||||
|
|
||||||
axios({
|
|
||||||
url: '/foo/bar',
|
|
||||||
method: 'post',
|
|
||||||
data: {
|
|
||||||
firstName: 'foo',
|
|
||||||
lastName: 'bar'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
request = jasmine.Ajax.requests.mostRecent();
|
|
||||||
|
|
||||||
expect(request.requestHeaders['Content-Type']).toEqual('application/json;charset=utf-8');
|
|
||||||
done();
|
|
||||||
}, 0);
|
}, 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -132,54 +102,6 @@ describe('wrapper', function () {
|
|||||||
}, 0);
|
}, 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should remove content-type if data is empty', function (done) {
|
|
||||||
var request;
|
|
||||||
|
|
||||||
axios({
|
|
||||||
method: 'post',
|
|
||||||
url: '/foo'
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
request = jasmine.Ajax.requests.mostRecent();
|
|
||||||
|
|
||||||
expect(request.requestHeaders['content-type']).toEqual(undefined);
|
|
||||||
done();
|
|
||||||
}, 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should supply correct response', function (done) {
|
|
||||||
var request, response;
|
|
||||||
|
|
||||||
axios({
|
|
||||||
method: 'post',
|
|
||||||
url: '/foo'
|
|
||||||
}).then(function (res) {
|
|
||||||
response = res;
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
request = jasmine.Ajax.requests.mostRecent();
|
|
||||||
|
|
||||||
request.respondWith({
|
|
||||||
status: 200,
|
|
||||||
statusText: 'OK',
|
|
||||||
responseText: '{"foo": "bar"}',
|
|
||||||
headers: {
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
expect(response.data.foo).toEqual('bar');
|
|
||||||
expect(response.status).toEqual(200);
|
|
||||||
expect(response.statusText).toEqual('OK');
|
|
||||||
expect(response.headers['content-type']).toEqual('application/json');
|
|
||||||
done();
|
|
||||||
}, 0);
|
|
||||||
}, 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should support array buffer response', function (done) {
|
it('should support array buffer response', function (done) {
|
||||||
var request, response;
|
var request, response;
|
||||||
|
|
||||||
Reference in New Issue
Block a user