freebsd-dev/bin/timeout/tests/timeout_test.sh
Mateusz Piotrowski e7ab133648 timeout: Move from /usr/bin to /bin
timeout(1) is used by /etc/rc.d/zfskeys. Unfortunately, having
timeout(1) installed in /usr/bin causes problems when /usr is an
encrypted ZFS partition.

Implementing timeout(1) in sh(1) is not trivial. A more elegant solution
is to move timeout(1) to /bin so that it is available to early services
in the boot process.

PR:		265221
Reviewed by:	allanjude, des, imp
Approved by:	allanjude, des, imp
Reported by:	Ivan <r4@sovserv.ru>
Fixes:	33ff39796f Add zfskeys rc.d script for auto-loading encryption keys
MFC after:	1 week
Relnotes:	yes
Sponsored by:	Modirum MDPay
Sponsored by:	Klara Inc.
Differential Revision:	https://reviews.freebsd.org/D38344
2023-02-02 18:34:35 +01:00

216 lines
3.4 KiB
Bash

# $FreeBSD$
atf_test_case nominal
nominal_head()
{
atf_set "descr" "Basic tests on timeout(1) utility"
}
nominal_body()
{
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 5 true
}
atf_test_case time_unit
time_unit_head()
{
atf_set "descr" "Test parsing the default time unit"
}
time_unit_body()
{
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 1d true
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 1h true
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 1m true
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 1s true
}
atf_test_case no_timeout
no_timeout_head()
{
atf_set "descr" "Test disabled timeout"
}
no_timeout_body()
{
atf_check \
-o empty \
-e empty \
-s exit:0 \
timeout 0 true
}
atf_test_case exit_numbers
exit_numbers_head()
{
atf_set "descr" "Test exit numbers"
}
exit_numbers_body()
{
atf_check \
-o empty \
-e empty \
-s exit:2 \
-x timeout 5 sh -c \'exit 2\'
atf_check \
-o empty \
-e empty \
-s exit:124 \
timeout .1 sleep 1
# With preserv status exit should be 128 + TERM aka 143
atf_check \
-o empty \
-e empty \
-s exit:143 \
timeout --preserve-status .1 sleep 10
atf_check \
-o empty \
-e empty \
-s exit:124 \
timeout -s1 -k1 .1 sleep 10
atf_check \
-o empty \
-e empty \
-s exit:0 \
-x sh -c 'trap "" CHLD; exec timeout 10 true'
}
atf_test_case with_a_child
with_a_child_head()
{
atf_set "descr" "When starting with a child (coreutils bug#9098)"
}
with_a_child_body()
{
out=$(sleep .1 & exec timeout .5 sh -c 'sleep 2; echo foo')
status=$?
test "$out" = "" && test $status = 124 || atf_fail
}
atf_test_case invalid_timeout
invalid_timeout_head()
{
atf_set "descr" "Invalid timeout"
}
invalid_timeout_body()
{
atf_check \
-o empty \
-e inline:"timeout: invalid duration\n" \
-s exit:125 \
timeout invalid sleep 0
atf_check \
-o empty \
-e inline:"timeout: invalid duration\n" \
-s exit:125 \
timeout --kill-after=invalid 1 sleep 0
atf_check \
-o empty \
-e inline:"timeout: invalid duration\n" \
-s exit:125 \
timeout 42D sleep 0
atf_check \
-o empty \
-e inline:"timeout: invalid duration\n" \
-s exit:125 \
timeout 999999999999999999999999999999999999999999999999999999999999d sleep 0
atf_check \
-o empty \
-e inline:"timeout: invalid duration\n" \
-s exit:125 \
timeout 2.34e+5d sleep 0
}
atf_test_case invalid_signal
invalid_signal_head()
{
atf_set "descr" "Invalid signal"
}
invalid_signal_body()
{
atf_check \
-o empty \
-e inline:"timeout: invalid signal\n" \
-s exit:125 \
timeout --signal=invalid 1 sleep 0
}
atf_test_case invalid_command
invalid_command_head()
{
atf_set "descr" "Invalid command"
}
invalid_command_body()
{
atf_check \
-o empty \
-e inline:"timeout: exec(.): Permission denied\n" \
-s exit:126 \
timeout 10 .
}
atf_test_case no_such_command
no_such_command_head()
{
atf_set "descr" "No such command"
}
no_such_command_body()
{
atf_check \
-o empty \
-e inline:"timeout: exec(enoexists): No such file or directory\n" \
-s exit:127 \
timeout 10 enoexists
}
atf_init_test_cases()
{
atf_add_test_case nominal
atf_add_test_case time_unit
atf_add_test_case no_timeout
atf_add_test_case exit_numbers
atf_add_test_case with_a_child
atf_add_test_case invalid_timeout
atf_add_test_case invalid_signal
atf_add_test_case invalid_command
atf_add_test_case no_such_command
}