2
0
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:
Rubén Norte
2017-04-08 21:43:04 +02:00
parent 5c8095e483
commit e0d59eb29b
4 changed files with 23 additions and 8 deletions
+6 -2
View File
@@ -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);
}); });
}); });
+7 -2
View File
@@ -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() {
+6 -1
View File
@@ -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);
}); });
+4 -3
View File
@@ -49,15 +49,16 @@ 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();
done(); done();
}; };
axios('http://thisisnotaserver') axios('http://thisisnotaserver/foo')
.then(resolveSpy, rejectSpy) .then(resolveSpy, rejectSpy)
.then(finish, finish); .then(finish, finish);
}); });