node/test/parallel/test-http-outgoing-finish.js
Gibson Fahnestock 7a0e462f9f test: use eslint to fix var->const/let
Manually fix issues that eslint --fix couldn't do automatically.

PR-URL: https://github.com/nodejs/node/pull/10685
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Roman Reiss <me@silverwind.io>
2017-01-11 11:43:52 +00:00

56 lines
1.5 KiB
JavaScript

'use strict';
require('../common');
const assert = require('assert');
const http = require('http');
http.createServer(function(req, res) {
req.resume();
req.on('end', function() {
write(res);
});
this.close();
}).listen(0, function() {
const req = http.request({
port: this.address().port,
method: 'PUT'
});
write(req);
req.on('response', function(res) {
res.resume();
});
});
const buf = Buffer.alloc(1024 * 16, 'x');
function write(out) {
const name = out.constructor.name;
let finishEvent = false;
let 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);
});
});
}