2011-11-23 21:44:51 +11:00
|
|
|
|
2012-06-30 16:43:17 +10:00
|
|
|
set env(LC_ALL) "C"
|
2011-11-23 22:48:49 +11:00
|
|
|
regexp "(.*\/)testsuite" $objdir objdir topdir
|
|
|
|
|
2012-01-02 17:39:41 +11:00
|
|
|
# These are the same as include/c.h
|
|
|
|
set usage_help "\\s*-h, --help\\s+display this help and exit\\s+"
|
|
|
|
set usage_version "\\s*-V, --version\\s+output version information and exit\\s+"
|
|
|
|
set usage_man "\\s*For more details see \\S+\\."
|
|
|
|
|
2014-07-01 18:51:21 +10:00
|
|
|
proc kill_process pid {
|
|
|
|
set cmdline "kill $pid"
|
|
|
|
if { [catch { exec /bin/sh -c $cmdline } msg]} {
|
|
|
|
warning "Could not kill process: $msg\n"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-11-30 23:11:35 +11:00
|
|
|
proc procps_v_version { tool } {
|
2011-11-23 22:48:49 +11:00
|
|
|
global topdir
|
2022-08-29 19:13:10 +10:00
|
|
|
set toolpath ${topdir}src/${tool}
|
2011-11-30 23:11:35 +11:00
|
|
|
set tmp [ exec $toolpath -V ]
|
2012-01-02 17:39:41 +11:00
|
|
|
regexp "from procps-ng (\[0-9.\]*)" $tmp tmp version
|
2011-11-30 23:11:35 +11:00
|
|
|
clone_output "$toolpath version $version\n"
|
2011-11-23 22:48:49 +11:00
|
|
|
}
|
|
|
|
|
2013-03-14 14:31:03 +01:00
|
|
|
proc free_version {} { procps_v_version free }
|
|
|
|
proc kill_version {} { procps_v_version kill }
|
|
|
|
proc pgrep_version {} { procps_v_version pgrep }
|
|
|
|
proc pkill_version {} { procps_v_version pkill }
|
|
|
|
proc pmap_version {} { procps_v_version pmap }
|
|
|
|
proc pwdx_version {} { procps_v_version pwdx }
|
|
|
|
proc sysctl_version {} { procps_v_version sysctl }
|
|
|
|
proc uptime_version {} { procps_v_version uptime }
|
|
|
|
proc vmstat_version {} { procps_v_version vmstat }
|
|
|
|
proc w_version {} { procps_v_version w }
|
2011-11-23 22:48:49 +11:00
|
|
|
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# common utilities
|
|
|
|
proc expect_continue { testname reg } {
|
|
|
|
expect {
|
|
|
|
-re "$reg" { }
|
|
|
|
eof { fail "$testname" }
|
|
|
|
timeout { fail "$testname" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
proc expect_pass { testname reg } {
|
|
|
|
expect {
|
|
|
|
-re "$reg" { pass "$testname" }
|
2011-12-01 22:42:23 +11:00
|
|
|
default { fail "$testname" }
|
2012-03-03 11:49:48 +11:00
|
|
|
timeout { fail "$testname" }
|
2011-11-23 22:48:49 +11:00
|
|
|
}
|
2011-11-23 21:44:51 +11:00
|
|
|
}
|
2011-11-27 15:30:04 +11:00
|
|
|
|
2020-04-28 19:40:07 +10:00
|
|
|
proc expect_pipeproc_pass { testname reg } {
|
|
|
|
global pipeproc_spawnid
|
|
|
|
|
|
|
|
expect {
|
|
|
|
-i $pipeproc_spawnid
|
|
|
|
-re "$reg" { pass "$testname" }
|
|
|
|
default { fail "$testname" }
|
|
|
|
timeout { fail "$testname (timeout)" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-11-27 15:30:04 +11:00
|
|
|
proc expect_blank { testname } {
|
|
|
|
expect {
|
|
|
|
-re "\\w" { fail "$testname" }
|
|
|
|
eof { pass "$testname" }
|
|
|
|
timeout { pass "$testname" }
|
|
|
|
}
|
|
|
|
}
|
2011-11-27 18:32:10 +11:00
|
|
|
|
2020-04-28 19:40:07 +10:00
|
|
|
proc expect_blank_continue { testname } {
|
|
|
|
expect {
|
|
|
|
-re "\\w" { fail "$testname" }
|
|
|
|
eof { }
|
|
|
|
timeout { pass "$testname (timeout)" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-01 22:42:23 +11:00
|
|
|
proc expect_table { test match_header match_items match_footer } {
|
|
|
|
expect {
|
|
|
|
-re "$match_header" {
|
|
|
|
expect {
|
|
|
|
-re "$match_items" {
|
|
|
|
expect {
|
|
|
|
-re "$match_footer" { pass "$test" }
|
|
|
|
default { fail "$test (footer)" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
default { fail "$test (items)" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
default { fail "$test (header)" }
|
|
|
|
}
|
|
|
|
}
|
2013-03-14 14:31:03 +01:00
|
|
|
|
2011-12-02 22:41:03 +11:00
|
|
|
proc expect_table_dsc { test match_header match_item } {
|
|
|
|
expect {
|
|
|
|
-re $match_header {}
|
|
|
|
default {
|
|
|
|
fail "$test (header)"
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
set do_loop 1
|
2013-03-26 13:22:30 +01:00
|
|
|
set last_value 99999999
|
2011-12-02 22:41:03 +11:00
|
|
|
set found_item 0
|
|
|
|
while { $do_loop ==1 } {
|
|
|
|
expect {
|
|
|
|
-re $match_item {
|
|
|
|
set current_value $expect_out(1,string)
|
|
|
|
if { $current_value > $last_value } {
|
|
|
|
fail "$test (sorting $current_value > $last_value)"
|
|
|
|
return
|
|
|
|
} else {
|
|
|
|
set found_item 1
|
|
|
|
set last_value $current_value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
default {
|
|
|
|
if { $found_item == 0 } {
|
|
|
|
fail "$test (items)"
|
|
|
|
} else {
|
|
|
|
pass $test
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#expect {
|
|
|
|
# -re $match_footer { pass $test }
|
|
|
|
# default { fail "$test (footer)" }
|
|
|
|
#}
|
|
|
|
}
|
|
|
|
|
2021-09-13 22:07:37 +10:00
|
|
|
proc expect_spawn_retval { test retval } {
|
|
|
|
foreach {pid spawnid os_error_flag value} [wait] break
|
|
|
|
|
|
|
|
if {$value == $retval} {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fail "$test (exit value)"
|
|
|
|
}
|
|
|
|
|
2020-04-28 19:40:07 +10:00
|
|
|
proc make_pipeproc { } {
|
|
|
|
global pipeproc_pid pipeproc_spawnid topdir
|
|
|
|
|
2022-08-29 20:40:45 +10:00
|
|
|
set testproc_realpath "${topdir}/src/tests/test_process"
|
2020-04-28 19:40:07 +10:00
|
|
|
|
|
|
|
set pipeproc_pid [ spawn $testproc_realpath ]
|
|
|
|
set pipeproc_spawnid $spawn_id
|
|
|
|
|
|
|
|
}
|
2011-11-27 18:32:10 +11:00
|
|
|
proc make_testproc { } {
|
2019-08-03 05:58:18 -04:00
|
|
|
global testproc_path testproc_comm testproc_arg_str testproc1_pid testproc2_pid topdir
|
2012-08-18 02:20:27 +02:00
|
|
|
|
2022-08-29 20:40:45 +10:00
|
|
|
set testproc_realpath "${topdir}/src/tests/test_process"
|
2015-06-13 15:04:31 +10:00
|
|
|
set testproc_comm "spcorp"
|
2011-11-30 23:11:35 +11:00
|
|
|
|
2011-11-27 18:32:10 +11:00
|
|
|
set testproc_path [ exec mktemp -u ]
|
2015-06-13 15:04:31 +10:00
|
|
|
exec ln -s $testproc_realpath $testproc_path
|
2011-11-30 23:11:35 +11:00
|
|
|
|
2011-11-27 18:32:10 +11:00
|
|
|
spawn readlink $testproc_path
|
|
|
|
expect {
|
2015-06-13 15:04:31 +10:00
|
|
|
-re "^$testproc_realpath\\s*$" { }
|
|
|
|
timeout { perror "test proc does not link to test process" }
|
|
|
|
eof { perror "test proc does not link to test process" }
|
2011-11-27 18:32:10 +11:00
|
|
|
}
|
2011-11-30 23:11:35 +11:00
|
|
|
|
2019-08-03 05:58:18 -04:00
|
|
|
# make a process with the argument set to a fraction of ARG_MAX length
|
|
|
|
# but small enough we do not run TCL out of memory for regular expressions
|
|
|
|
# nor do we get argument list too long (104857 was found to work on Ubuntu 18.04)
|
|
|
|
set max_arg_len [ expr min([ exec /usr/bin/getconf ARG_MAX ], 104857) ]
|
|
|
|
# ensure we have enough slack to launch the test prog and pgrep
|
|
|
|
set reserved_space [expr max([ string length $testproc_path ], [ string length $topdir ] + 10)]
|
|
|
|
set testproc_arg_str "a"
|
|
|
|
set i $reserved_space
|
|
|
|
while {$i<$max_arg_len} {
|
|
|
|
incr i
|
|
|
|
append testproc_arg_str "a"
|
|
|
|
}
|
|
|
|
set testproc1_pid [ exec $testproc_path $testproc_arg_str & ]
|
2015-06-13 15:04:31 +10:00
|
|
|
set testproc2_pid [ exec $testproc_path & ]
|
2011-11-27 18:32:10 +11:00
|
|
|
}
|
2014-07-01 18:51:21 +10:00
|
|
|
|
2022-04-26 22:04:05 +10:00
|
|
|
proc make_testshm_proc { } {
|
|
|
|
global testshmproc_pid testshm_spawnid topdir shmid
|
|
|
|
|
2022-08-29 20:40:45 +10:00
|
|
|
set testshm_realpath "${topdir}/src/tests/test_shm"
|
2022-04-26 22:04:05 +10:00
|
|
|
|
|
|
|
set testshmproc_pid [ spawn $testshm_realpath ]
|
|
|
|
set testshmproc_spawnid $spawn_id
|
|
|
|
expect {
|
|
|
|
-i $testshmproc_spawnid
|
2022-05-03 19:37:39 +10:00
|
|
|
-re "^SHMID: (\[0-9a-f\]+)" { set shmid $expect_out(1,string) }
|
|
|
|
default { set shmid "" }
|
2022-04-26 22:04:05 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
proc kill_testshm_proc { } {
|
|
|
|
global testshmproc_pid
|
|
|
|
|
|
|
|
kill_process $testshmproc_pid
|
|
|
|
}
|
|
|
|
|
2014-07-01 18:51:21 +10:00
|
|
|
proc kill_testproc { } {
|
|
|
|
global testproc_path testproc1_pid testproc2_pid
|
|
|
|
|
|
|
|
kill_process $testproc1_pid
|
|
|
|
kill_process $testproc2_pid
|
|
|
|
file delete $testproc_path
|
|
|
|
}
|
2015-05-09 17:48:12 +10:00
|
|
|
|
2020-04-28 19:40:07 +10:00
|
|
|
proc kill_pipeproc { } {
|
|
|
|
global pipeproc_pid
|
|
|
|
kill_process $pipeproc_pid
|
|
|
|
}
|
|
|
|
|
2015-05-09 17:48:12 +10:00
|
|
|
proc get_tty {} {
|
|
|
|
if { [catch { set raw_tty [ exec tty ] } msg]} {
|
|
|
|
warning "No TTY found"
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
regexp "/dev/(.+)" $raw_tty > tty
|
2022-03-22 19:53:28 +11:00
|
|
|
if { $tty == "tty" } {
|
|
|
|
warning "TTY is tty"
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2015-05-09 17:48:12 +10:00
|
|
|
return $tty
|
|
|
|
}
|