nodejs/test/parallel/test-tls-fast-writing.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

65 lines
1.4 KiB
JavaScript

'use strict';
var common = require('../common');
var assert = require('assert');
if (!common.hasCrypto) {
console.log('1..0 # Skipped: missing crypto');
return;
}
var tls = require('tls');
var fs = require('fs');
var PORT = common.PORT;
var dir = common.fixturesDir;
var options = { key: fs.readFileSync(dir + '/test_key.pem'),
cert: fs.readFileSync(dir + '/test_cert.pem'),
ca: [ fs.readFileSync(dir + '/test_ca.pem') ] };
var server = tls.createServer(options, onconnection);
var gotChunk = false;
var gotDrain = false;
setTimeout(function() {
console.log('not ok - timed out');
process.exit(1);
}, common.platformTimeout(1000));
function onconnection(conn) {
conn.on('data', function(c) {
if (!gotChunk) {
gotChunk = true;
console.log('ok - got chunk');
}
// just some basic sanity checks.
assert(c.length);
assert(Buffer.isBuffer(c));
if (gotDrain)
process.exit(0);
});
}
server.listen(PORT, function() {
var chunk = Buffer.alloc(1024, 'x');
var opt = { port: PORT, rejectUnauthorized: false };
var conn = tls.connect(opt, function() {
conn.on('drain', ondrain);
write();
});
function ondrain() {
if (!gotDrain) {
gotDrain = true;
console.log('ok - got drain');
}
if (gotChunk)
process.exit(0);
write();
}
function write() {
// this needs to return false eventually
while (false !== conn.write(chunk));
}
});