| 'use strict'; |
| |
| const common = require('../common'); |
| if (!common.hasCrypto) |
| common.skip('missing crypto'); |
| |
| const https = require('https'); |
| const assert = require('assert'); |
| const fixtures = require('../common/fixtures'); |
| |
| const options = { |
| key: fixtures.readKey('agent1-key.pem'), |
| cert: fixtures.readKey('agent1-cert.pem'), |
| ca: fixtures.readKey('ca1-cert.pem') |
| }; |
| |
| const server = https.Server(options, common.mustCall((req, res) => { |
| res.writeHead(200); |
| res.end('https\n'); |
| })); |
| |
| const agent = new https.Agent({ |
| keepAlive: false |
| }); |
| |
| server.listen(0, common.mustCall(() => { |
| https.get({ |
| host: server.address().host, |
| port: server.address().port, |
| headers: { host: 'agent1' }, |
| rejectUnauthorized: true, |
| ca: options.ca, |
| agent: agent |
| }, common.mustCall((res) => { |
| res.resume(); |
| server.close(); |
| |
| // Only one entry should exist in agent.sockets pool |
| // If there are more entries in agent.sockets, |
| // removeSocket will not delete them resulting in a resource leak |
| assert.strictEqual(Object.keys(agent.sockets).length, 1); |
| |
| res.req.on('close', common.mustCall(() => { |
| // To verify that no leaks occur, check that no entries |
| // exist in agent.sockets pool after both request and socket |
| // has been closed. |
| assert.strictEqual(Object.keys(agent.sockets).length, 0); |
| })); |
| })); |
| })); |