mirror of
https://github.com/http-party/node-http-proxy.git
synced 2025-12-08 20:59:18 +00:00
Handle errors for forward request, add test case (#1099)
This commit is contained in:
parent
2f7f03778c
commit
69cf892519
@ -103,6 +103,10 @@ module.exports = {
|
|||||||
var forwardReq = (options.forward.protocol === 'https:' ? https : http).request(
|
var forwardReq = (options.forward.protocol === 'https:' ? https : http).request(
|
||||||
common.setupOutgoing(options.ssl || {}, options, req, 'forward')
|
common.setupOutgoing(options.ssl || {}, options, req, 'forward')
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// error handler (e.g. ECONNREFUSED)
|
||||||
|
forwardReq.on('error', proxyError);
|
||||||
|
|
||||||
(options.buffer || req).pipe(forwardReq);
|
(options.buffer || req).pipe(forwardReq);
|
||||||
if(!options.target) { return res.end(); }
|
if(!options.target) { return res.end(); }
|
||||||
}
|
}
|
||||||
@ -138,7 +142,7 @@ module.exports = {
|
|||||||
|
|
||||||
function proxyError (err){
|
function proxyError (err){
|
||||||
if (req.socket.destroyed && err.code === 'ECONNRESET') {
|
if (req.socket.destroyed && err.code === 'ECONNRESET') {
|
||||||
server.emit('econnreset', err, req, res, options.target);
|
server.emit('econnreset', err, req, res, options.target || options.forward);
|
||||||
return proxyReq.abort();
|
return proxyReq.abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -177,6 +177,35 @@ describe('#createProxyServer.web() using own http server', function () {
|
|||||||
}, function() {}).end();
|
}, function() {}).end();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should forward the request and handle error via event listener', function(done) {
|
||||||
|
var proxy = httpProxy.createProxyServer({
|
||||||
|
forward: 'http://127.0.0.1:8080'
|
||||||
|
});
|
||||||
|
|
||||||
|
var proxyServer = http.createServer(requestHandler);
|
||||||
|
|
||||||
|
function requestHandler(req, res) {
|
||||||
|
proxy.once('error', function (err, errReq, errRes) {
|
||||||
|
proxyServer.close();
|
||||||
|
expect(err).to.be.an(Error);
|
||||||
|
expect(errReq).to.be.equal(req);
|
||||||
|
expect(errRes).to.be.equal(res);
|
||||||
|
expect(err.code).to.be('ECONNREFUSED');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
proxy.web(req, res);
|
||||||
|
}
|
||||||
|
|
||||||
|
proxyServer.listen('8083');
|
||||||
|
|
||||||
|
http.request({
|
||||||
|
hostname: '127.0.0.1',
|
||||||
|
port: '8083',
|
||||||
|
method: 'GET',
|
||||||
|
}, function() {}).end();
|
||||||
|
});
|
||||||
|
|
||||||
it('should proxy the request and handle timeout error (proxyTimeout)', function(done) {
|
it('should proxy the request and handle timeout error (proxyTimeout)', function(done) {
|
||||||
var proxy = httpProxy.createProxyServer({
|
var proxy = httpProxy.createProxyServer({
|
||||||
target: 'http://127.0.0.1:45000',
|
target: 'http://127.0.0.1:45000',
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user