node/test/parallel/test-net-error-twice.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

43 lines
930 B
JavaScript

'use strict';
const common = require('../common');
const assert = require('assert');
const net = require('net');
const buf = Buffer.alloc(10 * 1024 * 1024, 0x62);
const errs = [];
var clientSocket;
var serverSocket;
function ready() {
if (clientSocket && serverSocket) {
clientSocket.destroy();
serverSocket.write(buf);
}
}
var srv = net.createServer(function onConnection(conn) {
conn.on('error', function(err) {
errs.push(err);
if (errs.length > 1 && errs[0] === errs[1])
assert(false, 'We should not be emitting the same error twice');
});
conn.on('close', function() {
srv.unref();
});
serverSocket = conn;
ready();
}).listen(common.PORT, function() {
var client = net.connect({ port: common.PORT });
client.on('connect', function() {
clientSocket = client;
ready();
});
});
process.on('exit', function() {
console.log(errs);
assert.equal(errs.length, 1);
});