mirror of
https://github.com/tenrok/axios.git
synced 2026-06-23 20:40:40 +03:00
Adding failing tests that verify errors contain the request
This commit is contained in:
@@ -1,11 +1,15 @@
|
|||||||
var createError = require('../../../lib/core/createError');
|
var createError = require('../../../lib/core/createError');
|
||||||
|
|
||||||
describe('core::createError', function() {
|
describe('core::createError', function() {
|
||||||
it('should create an Error with message, config, and code', function() {
|
it('should create an Error with message, config, code, request and response', function() {
|
||||||
var error = createError('Boom!', { foo: 'bar' }, 'ESOMETHING');
|
var request = { path: '/foo' };
|
||||||
|
var response = { status: 200, data: { foo: 'bar' } };
|
||||||
|
var error = createError('Boom!', { foo: 'bar' }, 'ESOMETHING', request, response);
|
||||||
expect(error instanceof Error).toBe(true);
|
expect(error instanceof Error).toBe(true);
|
||||||
expect(error.message).toBe('Boom!');
|
expect(error.message).toBe('Boom!');
|
||||||
expect(error.config).toEqual({ foo: 'bar' });
|
expect(error.config).toEqual({ foo: 'bar' });
|
||||||
expect(error.code).toBe('ESOMETHING');
|
expect(error.code).toBe('ESOMETHING');
|
||||||
|
expect(error.request).toBe(request);
|
||||||
|
expect(error.response).toBe(response);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,11 +1,16 @@
|
|||||||
var enhanceError = require('../../../lib/core/enhanceError');
|
var enhanceError = require('../../../lib/core/enhanceError');
|
||||||
|
|
||||||
describe('core::enhanceError', function() {
|
describe('core::enhanceError', function() {
|
||||||
it('should add config and code to error', function() {
|
it('should add config, config, request and response to error', function() {
|
||||||
var error = new Error('Boom!');
|
var error = new Error('Boom!');
|
||||||
enhanceError(error, { foo: 'bar' }, 'ESOMETHING');
|
var request = { path: '/foo' };
|
||||||
|
var response = { status: 200, data: { foo: 'bar' } };
|
||||||
|
|
||||||
|
enhanceError(error, { foo: 'bar' }, 'ESOMETHING', request, response);
|
||||||
expect(error.config).toEqual({ foo: 'bar' });
|
expect(error.config).toEqual({ foo: 'bar' });
|
||||||
expect(error.code).toBe('ESOMETHING');
|
expect(error.code).toBe('ESOMETHING');
|
||||||
|
expect(error.request).toBe(request);
|
||||||
|
expect(error.response).toBe(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return error', function() {
|
it('should return error', function() {
|
||||||
|
|||||||
@@ -48,13 +48,17 @@ describe('core::settle', function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('should reject promise if validateStatus returns false', function() {
|
it('should reject promise if validateStatus returns false', function() {
|
||||||
|
var req = {
|
||||||
|
path: '/foo'
|
||||||
|
};
|
||||||
var response = {
|
var response = {
|
||||||
status: 500,
|
status: 500,
|
||||||
config: {
|
config: {
|
||||||
validateStatus: function() {
|
validateStatus: function() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
request: req
|
||||||
};
|
};
|
||||||
settle(resolve, reject, response);
|
settle(resolve, reject, response);
|
||||||
expect(resolve).not.toHaveBeenCalled();
|
expect(resolve).not.toHaveBeenCalled();
|
||||||
@@ -63,6 +67,7 @@ describe('core::settle', function() {
|
|||||||
expect(reason instanceof Error).toBe(true);
|
expect(reason instanceof Error).toBe(true);
|
||||||
expect(reason.message).toBe('Request failed with status code 500');
|
expect(reason.message).toBe('Request failed with status code 500');
|
||||||
expect(reason.config).toBe(response.config);
|
expect(reason.config).toBe(response.config);
|
||||||
|
expect(reason.request).toBe(req);
|
||||||
expect(reason.response).toBe(response);
|
expect(reason.response).toBe(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -49,7 +49,8 @@ describe('requests', function () {
|
|||||||
var reason = rejectSpy.calls.first().args[0];
|
var reason = rejectSpy.calls.first().args[0];
|
||||||
expect(reason instanceof Error).toBe(true);
|
expect(reason instanceof Error).toBe(true);
|
||||||
expect(reason.config.method).toBe('get');
|
expect(reason.config.method).toBe('get');
|
||||||
expect(reason.config.url).toBe('http://thisisnotaserver');
|
expect(reason.config.url).toBe('http://thisisnotaserver/foo');
|
||||||
|
expect(reason.request).toEqual(jasmine.any(XMLHttpRequest));
|
||||||
|
|
||||||
// re-enable jasmine.Ajax
|
// re-enable jasmine.Ajax
|
||||||
jasmine.Ajax.install();
|
jasmine.Ajax.install();
|
||||||
@@ -57,7 +58,7 @@ describe('requests', function () {
|
|||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
axios('http://thisisnotaserver')
|
axios('http://thisisnotaserver/foo')
|
||||||
.then(resolveSpy, rejectSpy)
|
.then(resolveSpy, rejectSpy)
|
||||||
.then(finish, finish);
|
.then(finish, finish);
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user