58 lines
1.3 KiB
JavaScript
58 lines
1.3 KiB
JavaScript
|
'use strict';
|
||
|
const common = require('../common');
|
||
|
|
||
|
if (!common.hasCrypto)
|
||
|
common.skip('missing crypto');
|
||
|
|
||
|
const fixtures = require('../common/fixtures');
|
||
|
|
||
|
const assert = require('assert');
|
||
|
const https = require('https');
|
||
|
|
||
|
const TOTAL_REQS = 2;
|
||
|
|
||
|
const options = {
|
||
|
key: fixtures.readKey('agent1-key.pem'),
|
||
|
cert: fixtures.readKey('agent1-cert.pem')
|
||
|
};
|
||
|
|
||
|
const clientSessions = [];
|
||
|
let serverRequests = 0;
|
||
|
|
||
|
const agent = new https.Agent({
|
||
|
maxCachedSessions: 0
|
||
|
});
|
||
|
|
||
|
const server = https.createServer(options, function(req, res) {
|
||
|
serverRequests++;
|
||
|
res.end('ok');
|
||
|
}).listen(0, function() {
|
||
|
let waiting = TOTAL_REQS;
|
||
|
function request() {
|
||
|
const options = {
|
||
|
agent: agent,
|
||
|
port: server.address().port,
|
||
|
rejectUnauthorized: false
|
||
|
};
|
||
|
|
||
|
https.request(options, function(res) {
|
||
|
clientSessions.push(res.socket.getSession());
|
||
|
|
||
|
res.resume();
|
||
|
res.on('end', function() {
|
||
|
if (--waiting !== 0)
|
||
|
return request();
|
||
|
server.close();
|
||
|
});
|
||
|
}).end();
|
||
|
}
|
||
|
request();
|
||
|
});
|
||
|
|
||
|
process.on('exit', function() {
|
||
|
assert.strictEqual(serverRequests, TOTAL_REQS);
|
||
|
assert.strictEqual(clientSessions.length, TOTAL_REQS);
|
||
|
assert.notStrictEqual(clientSessions[0].toString('hex'),
|
||
|
clientSessions[1].toString('hex'));
|
||
|
});
|