0
0
mirror of https://github.com/nodejs/node.git synced 2024-11-30 07:27:22 +01:00
nodejs/test/parallel/test-http-outgoing-finish.js
Brian White 2bc7841d0f
test: use random ports where possible
This helps to prevent issues where a failed test can keep a bound
socket open long enough to cause other tests to fail with EADDRINUSE
because the same port number is used.

PR-URL: https://github.com/nodejs/node/pull/7045
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Rod Vagg <rod@vagg.org>
2016-06-10 22:30:55 -04:00

56 lines
1.4 KiB
JavaScript

'use strict';
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(0, function() {
var req = http.request({
port: this.address().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);
});
});
}