blob: b5bb901e1d33f43da2a50f09d17d078c08b9e594 [file] [log] [blame]
BEGIN {
lines = 6
fail = 0
addrlen = length(addr) + 3
r_i = "[1-9][0-9]*"
r_socket = "^socket\\(PF_(LOCAL|UNIX|FILE), SOCK_STREAM, 0\\) += 1<UNIX:\\[(" r_i ")\\]>$"
r_close_listen = "^close\\(0<UNIX:[" r_i ",\"" addr "\"]>\\) += 0$"
}
NR == 1 {
if (match($0, r_socket, a)) {
inode = a[2]
r_connect = "^connect\\(1<UNIX:\\[" inode "\\]>, \\{sa_family=AF_(LOCAL|UNIX|FILE), sun_path=\"" addr "\"\\}, " addrlen "\\) += 0$"
next
}
}
NR == 2 {if (match($0, r_close_listen)) next}
NR == 3 {
if (r_connect != "" && match($0, r_connect)) {
r_close_connected = "^close\\(1<UNIX:\\[(" r_i ")->" r_i "\\]>\\) += 0$"
next
}
}
NR == 4 && /^--- SIGUSR1 / {next}
NR == 5 {
if (inode != "" && r_close_connected != "" && match($0, r_close_connected, a) && a[1] == inode) {
next
}
}
NR == lines && $0 == "+++ 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
}
}