From: patthoyts Date: Tue, 20 Jun 2006 10:34:10 +0000 (+0000) Subject: Added new test file to run a child process as udp server. X-Git-Tag: tcludp-1_0_8~4 X-Git-Url: https://conference.privyetmir.co.uk/gitweb?a=commitdiff_plain;h=0ae396b17adc60ddcab93f334afe28824c946292;p=tcludp Added new test file to run a child process as udp server. --- diff --git a/ChangeLog b/ChangeLog index 6a8c339..367a387 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2006-06-20 Pat Thoyts + + * tests/udp-srv.test: Added new test file which runs a child + proces as a udp server. + 2006-05-15 Pat Thoyts * aclocal.m4: Added check for fcntl.h and the FD_CLOEXEC flag diff --git a/tests/udp-srv.test b/tests/udp-srv.test new file mode 100644 index 0000000..e3c5f30 --- /dev/null +++ b/tests/udp-srv.test @@ -0,0 +1,152 @@ +if {[lsearch [namespace children] ::tcltest] == -1} { + package require tcltest + namespace import -force ::tcltest::* +} + +package require udp + +set scriptName [makeFile {} udptest2.tcl] +set script { + # UDP Test Server + package require udp + proc Wait {n} { + set ::forever 0 + after $n {set ::forever 1} + vwait ::forever + } + + # If an error occurs during the tests, this process may end up not + # being closed down. To deal with this we create a 30s timeout. + proc DoTimeout {} { + set ::done 1 + puts stderr "udp-srv.test child process [pid] timed out." + flush stdout + } + + proc ReadSock {chan} { + set data [read $chan] + set peer [fconfigure $chan -peer] + puts [list $peer [string length $data] $data] + } + + proc ReadControl {chan} { + if {[eof $chan]} { + fileevent $chan readable {} + set ::done 1 + return + } + gets $chan line + if {[string equal [string trim $line] "quit"]} { + set ::done 1 + } + } + + set timeout [after 5000 ::DoTimeout] + fconfigure stdout -buffering line + fconfigure stdin -buffering line + set socket [udp_open] + fconfigure $socket -buffering none -encoding binary -translation binary + fileevent $socket readable [list ReadSock $socket] + fileevent stdin readable [list ReadControl stdin] + Wait 100 + puts ready + puts [fconfigure $socket -myport] + vwait ::done + after cancel $timeout + close $socket + Wait 100 + exit +} + +proc Wait {n} { + set ::forever 0 + after $n {set ::forever 1} + vwait ::forever +} + +proc createChildProcess {filename} { + file delete -force $filename + set f [open $filename w] + puts $f $::script + close $f + set p [open |[list [interpreter] $filename] r+] + fconfigure $p -buffering line + gets $p line + return $p +} + +proc closeChildProcess {pipe} { + puts $pipe quit + while {[gets $pipe line] != -1} { puts "EXTRA: $line" } + close $pipe + return +} + +test udp-srv-1 {basic server operation (ascii)} -constraints {} -setup { + set child [createChildProcess $::scriptName] + gets $child port +} -body { + set u [udp_open] + fconfigure $u -remote [list localhost $port] + puts -nonewline $u "abcdefgh" + close $u + Wait 100 + gets $child r + lindex $r 1 +} -cleanup { + closeChildProcess $child +} -result {8} + +test udp-srv-2 {basic server operation (binary)} -constraints {} -setup { + set child [createChildProcess $::scriptName] + gets $child port +} -body { + set u [udp_open] + fconfigure $u -remote [list localhost $port] + puts -nonewline $u "\0\1\2\3\4\5\6\7" + close $u + Wait 100 + gets $child r + lindex $r 1 +} -cleanup { + closeChildProcess $child +} -result {8} + +test udp-srv-3 {basic server operation (large packet)} -constraints {} -setup { + set child [createChildProcess $::scriptName] + gets $child port +} -body { + set u [udp_open] + fconfigure $u -remote [list localhost $port] + puts -nonewline $u [string repeat x 1024] + close $u + Wait 100 + gets $child r + lindex $r 1 +} -cleanup { + closeChildProcess $child +} -result {1024} + +test udp-srv-4 {basic server operation (short packet)} -constraints {} -setup { + set child [createChildProcess $::scriptName] + gets $child port +} -body { + set u [udp_open] + fconfigure $u -remote [list localhost $port] -buffering none + puts -nonewline $u "\0" + close $u + Wait 100 + gets $child r + lindex $r 1 +} -cleanup { + closeChildProcess $child +} -result {1} + +# ------------------------------------------------------------------------- +file delete -force $::scriptName +::tcltest::cleanupTests +return + +# Local variables: +# mode: tcl +# End: \ No newline at end of file