2010-12-05 07:20:34 +08:00
|
|
|
var common = require('../common');
|
|
|
|
var assert = require('assert');
|
2010-06-12 17:40:24 +08:00
|
|
|
var Buffer = require('buffer').Buffer;
|
2010-12-06 03:15:30 +08:00
|
|
|
var dgram = require('dgram');
|
2010-06-12 17:40:24 +08:00
|
|
|
|
|
|
|
var tests_run = 0;
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
function pingPongTest(port, host) {
|
2010-06-17 02:00:43 +08:00
|
|
|
var callbacks = 0;
|
2010-06-12 17:40:24 +08:00
|
|
|
var N = 500;
|
|
|
|
var count = 0;
|
|
|
|
var sent_final_ping = false;
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
var server = dgram.createSocket('udp4', function(msg, rinfo) {
|
|
|
|
console.log('server got: ' + msg +
|
|
|
|
' from ' + rinfo.address + ':' + rinfo.port);
|
2010-06-12 17:40:24 +08:00
|
|
|
|
|
|
|
if (/PING/.exec(msg)) {
|
|
|
|
var buf = new Buffer(4);
|
|
|
|
buf.write('PONG');
|
2010-12-06 03:15:30 +08:00
|
|
|
server.send(buf, 0, buf.length,
|
|
|
|
rinfo.port, rinfo.address,
|
|
|
|
function(err, sent) {
|
|
|
|
callbacks++;
|
|
|
|
});
|
2010-06-12 17:40:24 +08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
server.on('error', function(e) {
|
2010-06-12 17:40:24 +08:00
|
|
|
throw e;
|
|
|
|
});
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
server.on('listening', function() {
|
|
|
|
console.log('server listening on ' + port + ' ' + host);
|
2010-06-12 17:40:24 +08:00
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
var buf = new Buffer('PING'),
|
|
|
|
client = dgram.createSocket('udp4');
|
2010-06-12 17:40:24 +08:00
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
client.addListener('message', function(msg, rinfo) {
|
|
|
|
console.log('client got: ' + msg +
|
|
|
|
' from ' + rinfo.address + ':' + rinfo.port);
|
|
|
|
assert.equal('PONG', msg.toString('ascii'));
|
2010-06-12 17:40:24 +08:00
|
|
|
|
|
|
|
count += 1;
|
|
|
|
|
|
|
|
if (count < N) {
|
2010-12-06 03:15:30 +08:00
|
|
|
client.send(buf, 0, buf.length, port, 'localhost');
|
2010-06-12 17:40:24 +08:00
|
|
|
} else {
|
|
|
|
sent_final_ping = true;
|
2010-12-06 03:15:30 +08:00
|
|
|
client.send(buf, 0, buf.length, port, 'localhost');
|
2010-06-12 17:40:24 +08:00
|
|
|
process.nextTick(function() {
|
|
|
|
client.close();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
client.on('close', function() {
|
2010-07-06 04:38:13 +08:00
|
|
|
console.log('client has closed, closing server');
|
2010-06-12 17:40:24 +08:00
|
|
|
assert.equal(N, count);
|
|
|
|
tests_run += 1;
|
|
|
|
server.close();
|
2010-12-06 03:15:30 +08:00
|
|
|
assert.equal(N - 1, callbacks);
|
2010-06-12 17:40:24 +08:00
|
|
|
});
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
client.on('error', function(e) {
|
2010-06-12 17:40:24 +08:00
|
|
|
throw e;
|
|
|
|
});
|
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
console.log('Client sending to ' + port + ', localhost ' + buf);
|
|
|
|
client.send(buf, 0, buf.length, port, 'localhost', function(err, bytes) {
|
2010-07-06 04:38:13 +08:00
|
|
|
if (err) {
|
|
|
|
throw err;
|
|
|
|
}
|
2010-12-06 03:15:30 +08:00
|
|
|
console.log('Client sent ' + bytes + ' bytes');
|
2010-07-06 04:38:13 +08:00
|
|
|
});
|
2010-06-12 17:40:24 +08:00
|
|
|
count += 1;
|
|
|
|
});
|
2010-07-06 04:38:13 +08:00
|
|
|
server.bind(port, host);
|
2010-06-12 17:40:24 +08:00
|
|
|
}
|
|
|
|
|
2010-07-06 04:38:13 +08:00
|
|
|
// All are run at once, so run on different ports
|
2010-12-06 03:15:30 +08:00
|
|
|
pingPongTest(20989, 'localhost');
|
|
|
|
pingPongTest(20990, 'localhost');
|
2010-06-12 17:40:24 +08:00
|
|
|
pingPongTest(20988);
|
2010-12-06 03:15:30 +08:00
|
|
|
//pingPongTest('/tmp/pingpong.sock');
|
2010-06-12 17:40:24 +08:00
|
|
|
|
2010-12-06 03:15:30 +08:00
|
|
|
process.addListener('exit', function() {
|
2010-07-06 04:38:13 +08:00
|
|
|
assert.equal(3, tests_run);
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log('done');
|
2010-06-12 17:40:24 +08:00
|
|
|
});
|