node/test/parallel/test-http-outgoing-finish.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

56 lines
1.5 KiB
JavaScript

'use strict';
var common = require('../common');
var assert = require('assert');
var http = require('http');
http.createServer(function(req, res) {
req.resume();
req.on('end', function() {
write(res);
});
this.close();
}).listen(common.PORT, function() {
var req = http.request({
port: common.PORT,
method: 'PUT'
});
write(req);
req.on('response', function(res) {
res.resume();
});
});
var buf = Buffer.alloc(1024 * 16, 'x');
function write(out) {
var name = out.constructor.name;
var finishEvent = false;
var endCb = false;
// first, write until it gets some backpressure
while (out.write(buf)) {}
// now end, and make sure that we don't get the 'finish' event
// before the tick where the cb gets called. We give it until
// nextTick because this is added as a listener before the endcb
// is registered. The order is not what we're testing here, just
// that 'finish' isn't emitted until the stream is fully flushed.
out.on('finish', function() {
finishEvent = true;
console.error('%s finish event', name);
process.nextTick(function() {
assert(endCb, name + ' got finish event before endcb!');
console.log('ok - %s finishEvent', name);
});
});
out.end(buf, function() {
endCb = true;
console.error('%s endCb', name);
process.nextTick(function() {
assert(finishEvent, name + ' got endCb event before finishEvent!');
console.log('ok - %s endCb', name);
});
});
}