Browse Source

Discard response before throw

This will not leave hanging sockets for 2 minutes (if server does not provide `Connection: close` header). Downside of it - you will not get content of 3xx response, but almost always it does not contain anything.
http2
Vsevolod Strukchinsky 10 years ago
parent
commit
81d0697ae4
  1. 4
      index.js
  2. 2
      test/test-redirects.js

4
index.js

@ -61,13 +61,13 @@ function got(url, opts, cb) {
// redirect
if (statusCode >= 300 && statusCode < 400 && 'location' in res.headers) {
res.resume(); // Discard response
if (++redirectCount > 10) {
cb(new Error('Redirected 10 times. Aborting.'), undefined, res);
return;
}
res.resume(); // Discard response
get(urlLib.resolve(url, res.headers.location), opts, cb);
return;
}

2
test/test-redirects.js

@ -54,7 +54,7 @@ tape('follows relative redirect', function (t) {
});
tape('throws on endless redirect', function (t) {
got(s.url + '/endless', {agent: false}, function (err) {
got(s.url + '/endless', function (err) {
t.ok(err, 'should get error');
t.equal(err.message, 'Redirected 10 times. Aborting.');
t.end();

Loading…
Cancel
Save