node/test/parallel/test-https-resume-after-renew.js
James M Snell 85ab4a5f12 buffer: add .from(), .alloc() and .allocUnsafe()
Several changes:

* Soft-Deprecate Buffer() constructors
* Add `Buffer.from()`, `Buffer.alloc()`, and `Buffer.allocUnsafe()`
* Add `--zero-fill-buffers` command line option
* Add byteOffset and length to `new Buffer(arrayBuffer)` constructor
* buffer.fill('') previously had no effect, now zero-fills
* Update the docs

PR-URL: https://github.com/nodejs/node/pull/4682
Reviewed-By: Сковорода Никита Андреевич <chalkerx@gmail.com>
Reviewed-By: Stephen Belanger <admin@stephenbelanger.com>
2016-03-16 08:34:02 -07:00

54 lines
1.2 KiB
JavaScript

'use strict';
var common = require('../common');
var fs = require('fs');
var https = require('https');
var crypto = require('crypto');
var options = {
key: fs.readFileSync(common.fixturesDir + '/keys/agent1-key.pem'),
cert: fs.readFileSync(common.fixturesDir + '/keys/agent1-cert.pem'),
ca: fs.readFileSync(common.fixturesDir + '/keys/ca1-cert.pem')
};
var server = https.createServer(options, function(req, res) {
res.end('hello');
});
var aes = Buffer.alloc(16, 'S');
var hmac = Buffer.alloc(16, 'H');
server._sharedCreds.context.enableTicketKeyCallback();
server._sharedCreds.context.onticketkeycallback = function(name, iv, enc) {
if (enc) {
var newName = Buffer.alloc(16, 'A');
var newIV = crypto.randomBytes(16);
} else {
// Renew
return [ 2, hmac, aes ];
}
return [ 1, hmac, aes, newName, newIV ];
};
server.listen(common.PORT, function() {
var 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();
});
});
});