mirror of
https://github.com/nodejs/node.git
synced 2025-04-30 07:19:19 +00:00

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>
44 lines
824 B
JavaScript
44 lines
824 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
|
|
const dgram = require('dgram');
|
|
const client = dgram.createSocket('udp4');
|
|
const chunk = 'abc';
|
|
let received = 0;
|
|
let sent = 0;
|
|
const limit = 10;
|
|
let async = false;
|
|
let port;
|
|
|
|
function onsend() {
|
|
if (sent++ < limit) {
|
|
client.send(chunk, 0, chunk.length, port, common.localhostIPv4, onsend);
|
|
} else {
|
|
assert.strictEqual(async, true, 'Send should be asynchronous.');
|
|
}
|
|
}
|
|
|
|
client.on('listening', function() {
|
|
port = this.address().port;
|
|
|
|
setImmediate(function() {
|
|
async = true;
|
|
});
|
|
|
|
onsend();
|
|
});
|
|
|
|
client.on('message', function(buf, info) {
|
|
received++;
|
|
if (received === limit) {
|
|
client.close();
|
|
}
|
|
});
|
|
|
|
client.on('close', common.mustCall(function() {
|
|
assert.equal(received, limit);
|
|
}));
|
|
|
|
client.bind(0);
|