2014-09-23 00:14:04 +00:00
BEGIN {
lines = 5
fail = 0
r_i = "[1-9][0-9]*"
r_port = "[1-9][0-9][0-9][0-9]+"
r_localhost = "127\\.0\\.0\\.1"
2015-01-13 00:06:09 +00:00
r_connect = "^connect\\(0<TCP:\\[" r_i "\\]>, \\{sa_family=AF_INET, sin_port=htons\\((" r_port ")\\), sin_addr=inet_addr\\(\"" r_localhost "\"\\)\\}, " r_i ") += 0$"
2014-09-23 00:14:04 +00:00
}
NR == 1 && /^socket\(PF_INET, SOCK_STREAM, IPPROTO_IP\) += 0$/ { next }
NR == 2 {
if ( match ( $ 0 , r_connect , a ) ) {
2014-12-26 23:29:26 +00:00
port_r = a [ 1 ]
r_send = "^send\\(0<TCP:\\[" r_localhost ":(" r_port ")->" r_localhost ":" port_r "\\]>, \"data\", 4, MSG_DONTROUTE\\) += 4$"
r_sendto = "^sendto\\(0<TCP:\\[" r_localhost ":(" r_port ")->" r_localhost ":" port_r "\\]>, \"data\", 4, MSG_DONTROUTE, NULL, 0\\) += 4$"
2014-09-23 00:14:04 +00:00
next
}
}
NR == 3 {
2014-12-26 23:29:26 +00:00
if ( r_send != "" && ( match ( $ 0 , r_send , a ) || match ( $ 0 , r_sendto , a ) ) ) {
2014-09-23 00:14:04 +00:00
port_l = a [ 1 ]
2014-12-26 23:29:26 +00:00
r_close = "^close\\(0<TCP:\\[" r_localhost ":" port_l "->" r_localhost ":" port_r "\\]>\\) += 0$"
2014-09-23 00:14:04 +00:00
next
}
}
2014-12-26 23:29:26 +00:00
NR == 4 { if ( r_close != "" && match ( $ 0 , r_close ) ) next }
2014-09-23 00:14:04 +00:00
2014-12-26 23:29:26 +00:00
NR == lines && $ 0 == "+++ exited with 0 +++" { next }
2014-09-23 00:14:04 +00:00
{
print "Line " NR " does not match: " $ 0
fail = 1
}
END {
if ( NR != lines ) {
print "Expected " lines " lines, found " NR " line(s)."
print ""
exit 1
}
if ( fail ) {
print ""
exit 1
}
}