node/test/parallel/test-https-resume-after-renew.js
Daniel Bevenius 82ceb5e4b1 test: minor refactoring of onticketkeycallback
The motivation for this commit is to make the the onticketkeycallback
function more readable.

PR-URL: https://github.com/nodejs/node/pull/24718
Reviewed-By: Jon Moss <me@jonathanmoss.me>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2018-12-01 08:55:59 -08:00

55 lines
1.2 KiB
JavaScript

'use strict';
const common = require('../common');
if (!common.hasCrypto)
common.skip('missing crypto');
const fixtures = require('../common/fixtures');
const https = require('https');
const crypto = require('crypto');
const options = {
key: fixtures.readKey('agent1-key.pem'),
cert: fixtures.readKey('agent1-cert.pem'),
ca: fixtures.readKey('ca1-cert.pem')
};
const server = https.createServer(options, function(req, res) {
res.end('hello');
});
const aes = Buffer.alloc(16, 'S');
const hmac = Buffer.alloc(16, 'H');
server._sharedCreds.context.enableTicketKeyCallback();
server._sharedCreds.context.onticketkeycallback = function(name, iv, enc) {
if (enc) {
const newName = Buffer.alloc(16, 'A');
const newIV = crypto.randomBytes(16);
return [ 1, hmac, aes, newName, newIV ];
}
// Renew
return [ 2, hmac, aes ];
};
server.listen(0, function() {
const addr = this.address();
function doReq(callback) {
https.request({
method: 'GET',
port: addr.port,
servername: 'agent1',
ca: options.ca
}, function(res) {
res.resume();
res.once('end', callback);
}).end();
}
doReq(function() {
doReq(function() {
server.close();
});
});
});