From 5d5d0cc6e26192f45ec8c7816cce93355293aa2d Mon Sep 17 00:00:00 2001 From: Vsevolod Strukchinsky Date: Wed, 31 Dec 2014 12:43:50 +0500 Subject: [PATCH] Use agents with maxSockets set to Infinity Closes #22 --- .travis.yml | 1 + index.js | 17 ++++++++++++----- package.json | 1 + readme.md | 10 ++++++++++ test/test-https.js | 10 ++++++++++ 5 files changed, 34 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml index 244b7e8..3c6757d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,3 +1,4 @@ language: node_js node_js: - '0.10' + - '0.11' diff --git a/index.js b/index.js index 5e336c5..8fdcf55 100644 --- a/index.js +++ b/index.js @@ -1,13 +1,15 @@ 'use strict'; + +var assign = require('object-assign'); +var agent = require('infinity-agent'); +var duplexify = require('duplexify'); var http = require('http'); var https = require('https'); -var urlLib = require('url'); -var zlib = require('zlib'); -var duplexify = require('duplexify'); -var assign = require('object-assign'); +var isReadableStream = require('isstream').isReadable; var read = require('read-all-stream'); var timeout = require('timed-out'); -var isReadableStream = require('isstream').isReadable; +var urlLib = require('url'); +var zlib = require('zlib'); function got(url, opts, cb) { if (typeof opts === 'function') { @@ -55,6 +57,11 @@ function got(url, opts, cb) { var fn = parsedUrl.protocol === 'https:' ? https : http; var arg = assign({}, parsedUrl, opts); + // TODO: remove this when Node 0.10 will be deprecated + if (arg.agent === undefined) { + arg.agent = agent(arg); + } + var req = fn.request(arg, function (response) { var statusCode = response.statusCode; var res = response; diff --git a/package.json b/package.json index 3403550..2d0bd73 100644 --- a/package.json +++ b/package.json @@ -32,6 +32,7 @@ ], "dependencies": { "duplexify": "^3.2.0", + "infinity-agent": "^0.1.0", "isstream": "^0.1.1", "object-assign": "^2.0.0", "read-all-stream": "^0.1.0", diff --git a/readme.md b/readme.md index 4d251a8..a31b8f2 100644 --- a/readme.md +++ b/readme.md @@ -75,6 +75,16 @@ Type: `number` Milliseconds after which the request will be aborted and an error event with `ETIMEDOUT` code will be emitted. +##### options.agent + +[http.Agent](http://nodejs.org/api/http.html#http_class_http_agent) instance. + +Node HTTP/HTTPS [Agent in 0.10.35](https://github.com/joyent/node/blob/v0.10.35-release/lib/http.js#L1261) by default limits number of open sockets to 5 — which is a little low. By default got will use `new Agent({maxSockets: Infinity})` like new [Agent in 0.11.14](https://github.com/joyent/node/blob/v0.11.14-release/lib/_http_agent.js#L110). + +You can read more about in [why pooling is evil](https://github.com/substack/hyperquest#pooling-is-evil). + +To use default [globalAgent](http://nodejs.org/api/http.html#http_http_globalagent) just pass `null` to this option. + ##### callback(err, data, response) ###### err diff --git a/test/test-https.js b/test/test-https.js index 0ba1988..1a20193 100644 --- a/test/test-https.js +++ b/test/test-https.js @@ -51,6 +51,16 @@ tape('setup', function (t) { }); tape('make request to https server', function (t) { + got('https://google.com', { + strictSSL: true + }, function (err, data) { + t.error(err); + t.ok(data); + t.end(); + }); +}); + +tape('make request to https server with ca', function (t) { got(s.url, { strictSSL: true, ca: caRootCert,