osd-contiki/tools/cooja/contiki_tests/ip_sky_telnet_ping.js

45 lines
1.2 KiB
JavaScript
Raw Normal View History

TIMEOUT(30000);
2009-01-08 16:41:48 +00:00
/* conf */
nrReplies = 0;
ipAddress = "172.16.1.0";
osName = java.lang.System.getProperty("os.name").toLowerCase();
if (osName.startsWith("win")) {
pingCmd = "ping -n 10 " + ipAddress;
} else {
pingCmd = "ping -c 10 " + ipAddress;
}
replyMsg = "from " + ipAddress;
2009-01-08 16:41:48 +00:00
/* mote startup */
WAIT_UNTIL(msg.contains('Sky telnet process'));
/* override simulation delay, test times out is too fast otherwise */
mote.getSimulation().setDelayTime(1);
2009-01-08 16:41:48 +00:00
/* start ping process */
var runnableObj = new Object();
runnableObj.run = function() {
pingProcess = new java.lang.Runtime.getRuntime().exec(pingCmd);
log.log("cmd> " + pingCmd + "\n");
stdIn = new java.io.BufferedReader(new java.io.InputStreamReader(pingProcess.getInputStream()));
while ((line = stdIn.readLine()) != null) {
log.log("> " + line + "\n");
if (line.contains(replyMsg)) {
2009-01-08 16:41:48 +00:00
nrReplies++;
//log.log("reply #" + nrReplies + "\n");
}
}
pingProcess.destroy();
2009-01-08 16:41:48 +00:00
if (nrReplies > 5) {
log.testOK(); /* Report test success and quit */
} else {
2009-01-08 16:41:48 +00:00
log.log("Only " + nrReplies + "/10 ping replies was received\n");
log.testFailed();
}
}
var thread = new java.lang.Thread(new java.lang.Runnable(runnableObj));
thread.start();