2010-08-12 05:03:56 +08:00
|
|
|
common = require("../common");
|
|
|
|
assert = common.assert
|
|
|
|
|
|
|
|
var dgram = require("dgram"),
|
|
|
|
sys = require('sys'),
|
|
|
|
assert = require('assert'),
|
|
|
|
Buffer = require("buffer").Buffer;
|
|
|
|
var LOCAL_BROADCAST_HOST = '224.0.0.1';
|
|
|
|
var sendMessages = [
|
|
|
|
new Buffer("First message to send"),
|
|
|
|
new Buffer("Second message to send"),
|
|
|
|
new Buffer("Third message to send"),
|
|
|
|
new Buffer("Fourth message to send")
|
|
|
|
];
|
2010-08-20 09:49:27 +08:00
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
var listenSockets = [];
|
2010-08-20 09:49:27 +08:00
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
var sendSocket = dgram.createSocket('udp4')
|
2010-08-20 09:49:27 +08:00
|
|
|
|
|
|
|
sendSocket.on('close', function () {
|
|
|
|
console.error('sendSocket closed');
|
|
|
|
})
|
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
sendSocket.setBroadcast(true);
|
2010-08-20 09:49:27 +08:00
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
var i = 0;
|
2010-08-20 09:49:27 +08:00
|
|
|
|
|
|
|
sendSocket.sendNext = function () {
|
2010-08-12 05:03:56 +08:00
|
|
|
var buf = sendMessages[i++];
|
2010-08-20 09:49:27 +08:00
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
if (!buf) {
|
|
|
|
try { sendSocket.close(); }catch(e){}
|
|
|
|
return;
|
|
|
|
}
|
2010-08-20 09:49:27 +08:00
|
|
|
|
|
|
|
sendSocket.send(buf, 0, buf.length, common.PORT, LOCAL_BROADCAST_HOST, function (err) {
|
2010-08-12 05:03:56 +08:00
|
|
|
if (err) throw err;
|
2010-08-20 09:49:27 +08:00
|
|
|
console.error('sent %s to %s', sys.inspect(buf.toString()),
|
2010-08-12 05:03:56 +08:00
|
|
|
LOCAL_BROADCAST_HOST+common.PORT);
|
|
|
|
process.nextTick(sendSocket.sendNext);
|
|
|
|
});
|
2010-08-20 09:49:27 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
listener_count = 0;
|
2010-08-12 05:03:56 +08:00
|
|
|
|
|
|
|
function mkListener() {
|
|
|
|
var receivedMessages = [];
|
|
|
|
var listenSocket = dgram.createSocket('udp4')
|
2010-08-20 09:49:27 +08:00
|
|
|
|
|
|
|
listenSocket.on('message', function(buf, rinfo) {
|
|
|
|
console.error('received %s from %j', sys.inspect(buf.toString()), rinfo);
|
|
|
|
receivedMessages.push(buf);
|
|
|
|
|
|
|
|
if (receivedMessages.length == sendMessages.length) {
|
|
|
|
listenSocket.close();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
listenSocket.on('close', function () {
|
|
|
|
console.error('listenSocket closed -- checking received messages');
|
|
|
|
var count = 0;
|
|
|
|
receivedMessages.forEach(function(buf){
|
|
|
|
for (var i=0; i<sendMessages.length; ++i) {
|
|
|
|
if (buf.toString() === sendMessages[i].toString()) {
|
|
|
|
count++;
|
|
|
|
break;
|
2010-08-12 05:03:56 +08:00
|
|
|
}
|
|
|
|
}
|
2010-08-20 09:49:27 +08:00
|
|
|
});
|
|
|
|
console.error("count %d", count);
|
|
|
|
//assert.strictEqual(count, sendMessages.length);
|
|
|
|
})
|
|
|
|
|
|
|
|
listenSocket.on('listening', function() {
|
|
|
|
listenSockets.push(listenSocket);
|
|
|
|
if (listenSockets.length == 3) {
|
|
|
|
sendSocket.sendNext();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2010-08-12 05:03:56 +08:00
|
|
|
listenSocket.bind(common.PORT);
|
|
|
|
}
|
|
|
|
|
|
|
|
mkListener();
|
|
|
|
mkListener();
|
|
|
|
mkListener();
|
|
|
|
|