mirror of
https://github.com/tenrok/axios.git
synced 2026-06-02 16:04:10 +03:00
58 lines
1.6 KiB
JavaScript
58 lines
1.6 KiB
JavaScript
var axios = require('../../index');
|
|
var getAjaxRequest = require('./__getAjaxRequest');
|
|
|
|
describe('xsrf', function () {
|
|
beforeEach(function () {
|
|
jasmine.Ajax.install();
|
|
});
|
|
|
|
afterEach(function () {
|
|
document.cookie = axios.defaults.xsrfCookieName + '=;expires=' + new Date(Date.now() - 86400000).toGMTString();
|
|
jasmine.Ajax.uninstall();
|
|
});
|
|
|
|
it('should not set xsrf header if cookie is null', function (done) {
|
|
axios('/foo');
|
|
|
|
getAjaxRequest().then(function (request) {
|
|
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual(undefined);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should set xsrf header if cookie is set', function (done) {
|
|
document.cookie = axios.defaults.xsrfCookieName + '=12345';
|
|
|
|
axios('/foo');
|
|
|
|
getAjaxRequest().then(function (request) {
|
|
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual('12345');
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should not set xsrf header for cross origin', function (done) {
|
|
document.cookie = axios.defaults.xsrfCookieName + '=12345';
|
|
|
|
axios('http://example.com/');
|
|
|
|
getAjaxRequest().then(function (request) {
|
|
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual(undefined);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should set xsrf header for cross origin when using withCredentials', function (done) {
|
|
document.cookie = axios.defaults.xsrfCookieName + '=12345';
|
|
|
|
axios('http://example.com/', {
|
|
withCredentials: true
|
|
});
|
|
|
|
getAjaxRequest().then(function (request) {
|
|
expect(request.requestHeaders[axios.defaults.xsrfHeaderName]).toEqual('12345');
|
|
done();
|
|
});
|
|
});
|
|
});
|