mirror of
https://github.com/tenrok/axios.git
synced 2026-06-17 19:21:29 +03:00
Merge pull request #830 from mzabriskie/feature/include-request-in-errors
Include underlying request in errors
This commit is contained in:
@@ -469,11 +469,16 @@ instance.interceptors.request.use(function () {/*...*/});
|
|||||||
axios.get('/user/12345')
|
axios.get('/user/12345')
|
||||||
.catch(function (error) {
|
.catch(function (error) {
|
||||||
if (error.response) {
|
if (error.response) {
|
||||||
// The request was made, but the server responded with a status code
|
// The request was made and the server responded with a status code
|
||||||
// that falls out of the range of 2xx
|
// that falls out of the range of 2xx
|
||||||
console.log(error.response.data);
|
console.log(error.response.data);
|
||||||
console.log(error.response.status);
|
console.log(error.response.status);
|
||||||
console.log(error.response.headers);
|
console.log(error.response.headers);
|
||||||
|
} else if (error.request) {
|
||||||
|
// The request was made but no response was received
|
||||||
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
||||||
|
// http.ClientRequest in node.js
|
||||||
|
console.log(error.request);
|
||||||
} else {
|
} else {
|
||||||
// Something happened in setting up the request that triggered an Error
|
// Something happened in setting up the request that triggered an Error
|
||||||
console.log('Error', error.message);
|
console.log('Error', error.message);
|
||||||
|
|||||||
@@ -172,13 +172,14 @@ module.exports = function httpAdapter(config) {
|
|||||||
|
|
||||||
// make sure the content length is not over the maxContentLength if specified
|
// make sure the content length is not over the maxContentLength if specified
|
||||||
if (config.maxContentLength > -1 && Buffer.concat(responseBuffer).length > config.maxContentLength) {
|
if (config.maxContentLength > -1 && Buffer.concat(responseBuffer).length > config.maxContentLength) {
|
||||||
reject(createError('maxContentLength size of ' + config.maxContentLength + ' exceeded', config));
|
reject(createError('maxContentLength size of ' + config.maxContentLength + ' exceeded',
|
||||||
|
config, null, lastRequest));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
stream.on('error', function handleStreamError(err) {
|
stream.on('error', function handleStreamError(err) {
|
||||||
if (aborted) return;
|
if (aborted) return;
|
||||||
reject(enhanceError(err, config));
|
reject(enhanceError(err, config, null, lastRequest));
|
||||||
});
|
});
|
||||||
|
|
||||||
stream.on('end', function handleStreamEnd() {
|
stream.on('end', function handleStreamEnd() {
|
||||||
@@ -196,14 +197,14 @@ module.exports = function httpAdapter(config) {
|
|||||||
// Handle errors
|
// Handle errors
|
||||||
req.on('error', function handleRequestError(err) {
|
req.on('error', function handleRequestError(err) {
|
||||||
if (aborted) return;
|
if (aborted) return;
|
||||||
reject(enhanceError(err, config));
|
reject(enhanceError(err, config, null, req));
|
||||||
});
|
});
|
||||||
|
|
||||||
// Handle request timeout
|
// Handle request timeout
|
||||||
if (config.timeout && !timer) {
|
if (config.timeout && !timer) {
|
||||||
timer = setTimeout(function handleRequestTimeout() {
|
timer = setTimeout(function handleRequestTimeout() {
|
||||||
req.abort();
|
req.abort();
|
||||||
reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED'));
|
reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED', req));
|
||||||
aborted = true;
|
aborted = true;
|
||||||
}, config.timeout);
|
}, config.timeout);
|
||||||
}
|
}
|
||||||
|
|||||||
+3
-2
@@ -84,7 +84,7 @@ module.exports = function xhrAdapter(config) {
|
|||||||
request.onerror = function handleError() {
|
request.onerror = function handleError() {
|
||||||
// Real errors are hidden from us by the browser
|
// Real errors are hidden from us by the browser
|
||||||
// onerror should only fire if it's a network error
|
// onerror should only fire if it's a network error
|
||||||
reject(createError('Network Error', config));
|
reject(createError('Network Error', config, null, request));
|
||||||
|
|
||||||
// Clean up request
|
// Clean up request
|
||||||
request = null;
|
request = null;
|
||||||
@@ -92,7 +92,8 @@ module.exports = function xhrAdapter(config) {
|
|||||||
|
|
||||||
// Handle timeout
|
// Handle timeout
|
||||||
request.ontimeout = function handleTimeout() {
|
request.ontimeout = function handleTimeout() {
|
||||||
reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED'));
|
reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED',
|
||||||
|
request));
|
||||||
|
|
||||||
// Clean up request
|
// Clean up request
|
||||||
request = null;
|
request = null;
|
||||||
|
|||||||
@@ -3,15 +3,16 @@
|
|||||||
var enhanceError = require('./enhanceError');
|
var enhanceError = require('./enhanceError');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an Error with the specified message, config, error code, and response.
|
* Create an Error with the specified message, config, error code, request and response.
|
||||||
*
|
*
|
||||||
* @param {string} message The error message.
|
* @param {string} message The error message.
|
||||||
* @param {Object} config The config.
|
* @param {Object} config The config.
|
||||||
* @param {string} [code] The error code (for example, 'ECONNABORTED').
|
* @param {string} [code] The error code (for example, 'ECONNABORTED').
|
||||||
|
@ @param {Object} [request] The request.
|
||||||
@ @param {Object} [response] The response.
|
@ @param {Object} [response] The response.
|
||||||
* @returns {Error} The created error.
|
* @returns {Error} The created error.
|
||||||
*/
|
*/
|
||||||
module.exports = function createError(message, config, code, response) {
|
module.exports = function createError(message, config, code, request, response) {
|
||||||
var error = new Error(message);
|
var error = new Error(message);
|
||||||
return enhanceError(error, config, code, response);
|
return enhanceError(error, config, code, request, response);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -6,14 +6,16 @@
|
|||||||
* @param {Error} error The error to update.
|
* @param {Error} error The error to update.
|
||||||
* @param {Object} config The config.
|
* @param {Object} config The config.
|
||||||
* @param {string} [code] The error code (for example, 'ECONNABORTED').
|
* @param {string} [code] The error code (for example, 'ECONNABORTED').
|
||||||
|
@ @param {Object} [request] The request.
|
||||||
@ @param {Object} [response] The response.
|
@ @param {Object} [response] The response.
|
||||||
* @returns {Error} The error.
|
* @returns {Error} The error.
|
||||||
*/
|
*/
|
||||||
module.exports = function enhanceError(error, config, code, response) {
|
module.exports = function enhanceError(error, config, code, request, response) {
|
||||||
error.config = config;
|
error.config = config;
|
||||||
if (code) {
|
if (code) {
|
||||||
error.code = code;
|
error.code = code;
|
||||||
}
|
}
|
||||||
|
error.request = request;
|
||||||
error.response = response;
|
error.response = response;
|
||||||
return error;
|
return error;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ module.exports = function settle(resolve, reject, response) {
|
|||||||
'Request failed with status code ' + response.status,
|
'Request failed with status code ' + response.status,
|
||||||
response.config,
|
response.config,
|
||||||
null,
|
null,
|
||||||
|
response.request,
|
||||||
response
|
response
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,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);
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user