2014-09-23 00:14:04 +00:00
BEGIN {
lines = 9
fail = 0
inode = "?"
port_l = "?"
port_r = "?"
r_i = "[1-9][0-9]*"
r_port = "[1-9][0-9][0-9][0-9]+"
r_localhost = "127\\.0\\.0\\.1"
2014-11-22 19:03:33 +09:00
r_bind = "^bind\\(0<(TCP|socket):\\[(" r_i ")\\]>, {sa_family=AF_INET, sin_port=htons\\(0\\), sin_addr=inet_addr\\(\"" r_localhost "\"\\)}, " r_i "\\) += 0$"
2014-09-23 00:14:04 +00:00
r_listen = "^/$"
r_getsockname = "^getsockname\\(0<" r_localhost ":(" r_port ")>, {sa_family=AF_INET, sin_port=htons\\((" r_port ")\\), sin_addr=inet_addr\\(\"" r_localhost "\"\\)}, \\[" r_i "\\]\\) += 0$"
r_accept = "^/$"
r_close0 = "^/$"
r_recv = "^/$"
r_recvfrom = "^/$"
r_close1 = "^/$"
}
NR == 1 && /^socket\(PF_INET, SOCK_STREAM, IPPROTO_IP\) += 0$/ { next }
NR == 2 {
if ( match ( $ 0 , r_bind , a ) ) {
2014-11-22 19:03:33 +09:00
inode = a [ 2 ]
r_listen = "^listen\\(0<(TCP|socket):\\[" inode "\\]>, 5\\) += 0$"
2014-09-23 00:14:04 +00:00
next
}
}
NR == 3 { if ( match ( $ 0 , r_listen ) ) next }
NR == 4 {
if ( match ( $ 0 , r_getsockname , a ) && a [ 1 ] == a [ 2 ] ) {
port_l = a [ 1 ]
r_accept = "^accept\\(0<" r_localhost ":" port_l ">, {sa_family=AF_INET, sin_port=htons\\((" r_port ")\\), sin_addr=inet_addr\\(\"" r_localhost "\"\\)}, \\[" r_i "\\]\\) += 1<" r_localhost ":" port_l "->" r_localhost ":(" r_port ")>$"
r_close0 = "^close\\(0<" r_localhost ":" port_l ">) += 0$"
next
}
}
NR == 5 {
if ( match ( $ 0 , r_accept , a ) && a [ 1 ] == a [ 2 ] ) {
port_r = a [ 1 ]
r_recv = "^recv\\(1<" r_localhost ":" port_l "->" r_localhost ":" port_r ">, \"data\", 5, MSG_WAITALL\\) += 4$"
r_recvfrom = "^recvfrom\\(1<" r_localhost ":" port_l "->" r_localhost ":" port_r ">, \"data\", 5, MSG_WAITALL, NULL, NULL\\) += 4$"
r_close1 = "^close\\(1<" r_localhost ":" port_l "->" r_localhost ":" port_r ">) += 0$"
next
}
}
NR == 6 { if ( match ( $ 0 , r_close0 ) ) next }
NR == 7 { if ( match ( $ 0 , r_recv ) || match ( $ 0 , r_recvfrom ) ) next }
NR == 8 { if ( match ( $ 0 , r_close1 ) ) next }
NR == lines && /^\+\+\+ exited with 0 \+\+\+$/ { next }
{
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
}
}