2
0
mirror of https://github.com/tenrok/axios.git synced 2026-06-11 18:02:32 +03:00

Adding xsrf protection

This commit is contained in:
Matt Zabriskie
2014-08-29 01:17:40 -06:00
parent 3ae6670f77
commit 7aef479c7e
14 changed files with 534 additions and 99 deletions
+49 -3
View File
@@ -39,7 +39,9 @@ describe('axios', function () {
});
it('should default common headers', function () {
axios();
axios({
url: '/foo'
});
var request = jasmine.Ajax.requests.mostRecent();
var headers = axios.defaults.headers.common;
@@ -52,7 +54,12 @@ describe('axios', function () {
it('should add extra headers for post', function () {
axios({
method: 'post'
method: 'post',
url: '/foo',
data: {
firstName: 'foo',
lastName: 'bar'
}
});
var request = jasmine.Ajax.requests.mostRecent();
@@ -63,6 +70,16 @@ describe('axios', function () {
}
}
});
it('should remove content-type if data is empty', function () {
axios({
method: 'post',
url: '/foo'
});
var request = jasmine.Ajax.requests.mostRecent();
expect(request.requestHeaders['content-type']).toEqual(undefined);
});
});
describe('options', function () {
@@ -71,7 +88,9 @@ describe('axios', function () {
});
it('should default method to get', function () {
axios();
axios({
url: '/foo'
});
var request = jasmine.Ajax.requests.mostRecent();
expect(request.method).toBe('get');
@@ -79,6 +98,7 @@ describe('axios', function () {
it('should accept headers', function () {
axios({
url: '/foo',
headers: {
'X-Requested-With': 'XMLHttpRequest'
}
@@ -103,6 +123,7 @@ describe('axios', function () {
it('should allow overriding default headers', function () {
axios({
url: '/foo',
headers: {
'Accept': 'foo/bar'
}
@@ -112,4 +133,29 @@ describe('axios', function () {
expect(request.requestHeaders['Accept']).toEqual('foo/bar');
});
});
describe('xsrf', function () {
afterEach(function () {
document.cookie = axios.defaults.xsrfCookieName + '=;expires=' + new Date(Date.now() - 86400000).toGMTString();
});
it('should not set xsrf header if cookie is null', function () {
axios({
url: '/foo'
});
var request = jasmine.Ajax.requests.mostRecent();
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual(undefined);
});
it('should set xsrf header if cookie is set', function () {
document.cookie = axios.defaults.xsrfCookieName + '=12345';
axios({
url: '/foo'
});
var request = jasmine.Ajax.requests.mostRecent();
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual('12345');
});
});
});
+12
View File
@@ -7,6 +7,18 @@ module.exports = {
test.done();
},
testIsString: function (test) {
test.equals(utils.isString(''), true);
test.equals(utils.isString({toString: function () { return ''; }}), false);
test.done();
},
testIsNumber: function (test) {
test.equals(utils.isNumber(123), true);
test.equals(utils.isNumber('123'), false);
test.done();
},
testIsObject: function (test) {
test.equals(utils.isObject({}), true);
test.equals(utils.isObject(null), false);