test: refactor test-dgram-udp4
This test was sometimes timing out in `OS X`. Remove the timeout and clean up the code. Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> PR-URL: https://github.com/nodejs/node/pull/5339
This commit is contained in:
parent
2426b3dd86
commit
dff01d10c5
@ -4,57 +4,29 @@ const assert = require('assert');
|
|||||||
const dgram = require('dgram');
|
const dgram = require('dgram');
|
||||||
const server_port = common.PORT;
|
const server_port = common.PORT;
|
||||||
const message_to_send = 'A message to send';
|
const message_to_send = 'A message to send';
|
||||||
let client;
|
|
||||||
let timer;
|
|
||||||
|
|
||||||
const server = dgram.createSocket('udp4');
|
const server = dgram.createSocket('udp4');
|
||||||
server.on('message', function(msg, rinfo) {
|
server.on('message', common.mustCall((msg, rinfo) => {
|
||||||
console.log('server got: ' + msg +
|
|
||||||
' from ' + rinfo.address + ':' + rinfo.port);
|
|
||||||
assert.strictEqual(rinfo.address, common.localhostIPv4);
|
assert.strictEqual(rinfo.address, common.localhostIPv4);
|
||||||
assert.strictEqual(msg.toString(), message_to_send.toString());
|
assert.strictEqual(msg.toString(), message_to_send.toString());
|
||||||
server.send(msg, 0, msg.length, rinfo.port, rinfo.address);
|
server.send(msg, 0, msg.length, rinfo.port, rinfo.address);
|
||||||
});
|
}));
|
||||||
server.on('listening', function() {
|
server.on('listening', common.mustCall(() => {
|
||||||
var address = server.address();
|
const client = dgram.createSocket('udp4');
|
||||||
console.log('server is listening on ' + address.address + ':' + address.port);
|
client.on('message', common.mustCall((msg, rinfo) => {
|
||||||
client = dgram.createSocket('udp4');
|
|
||||||
client.on('message', function(msg, rinfo) {
|
|
||||||
console.log('client got: ' + msg +
|
|
||||||
' from ' + rinfo.address + ':' + address.port);
|
|
||||||
assert.strictEqual(rinfo.address, common.localhostIPv4);
|
assert.strictEqual(rinfo.address, common.localhostIPv4);
|
||||||
assert.strictEqual(rinfo.port, server_port);
|
assert.strictEqual(rinfo.port, server_port);
|
||||||
assert.strictEqual(msg.toString(), message_to_send.toString());
|
assert.strictEqual(msg.toString(), message_to_send.toString());
|
||||||
client.close();
|
client.close();
|
||||||
server.close();
|
server.close();
|
||||||
});
|
}));
|
||||||
client.send(
|
client.send(message_to_send,
|
||||||
message_to_send,
|
|
||||||
0,
|
0,
|
||||||
message_to_send.length,
|
message_to_send.length,
|
||||||
server_port,
|
server_port,
|
||||||
'localhost',
|
'localhost');
|
||||||
function(err) {
|
client.on('close', common.mustCall(() => {}));
|
||||||
if (err) {
|
}));
|
||||||
console.log('Caught error in client send.');
|
server.on('close', common.mustCall(() => {}));
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
client.on('close',
|
|
||||||
function() {
|
|
||||||
if (server.fd === null) {
|
|
||||||
clearTimeout(timer);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
server.on('close', function() {
|
|
||||||
if (client.fd === null) {
|
|
||||||
clearTimeout(timer);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
server.bind(server_port);
|
server.bind(server_port);
|
||||||
|
|
||||||
timer = setTimeout(function() {
|
|
||||||
throw new Error('Timeout');
|
|
||||||
}, common.platformTimeout(200));
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user