Results for builtin-trap.test.sh

statusdashbashmkshashosh
pass 1822182016
ok 10211
N-I 30000
BUG 11320
FAIL 00006
total2323232323
casedashbashmkshashoshdescription
0pass pass pass pass pass trap accepts/ignores --
1pass pass pass pass pass Register invalid trap
2pass pass pass pass pass Remove invalid trap
3N-I pass pass pass pass SIGINT and INT are aliases
details
4N-I pass BUG BUG FAIL trap without args prints traps, like trap -p
detailsdetailsdetailsdetails
5pass pass pass pass ok trap 'echo hi' KILL (regression test, caught by smoosh suite)
details
6ok pass BUG ok pass Invalid trap invocation
detailsdetailsdetails
7BUG BUG BUG BUG pass exit 1 when trap code string is invalid
detailsdetailsdetailsdetails
8pass pass pass pass pass trap EXIT calling exit
9pass pass pass pass pass trap EXIT return status ignored
10pass pass ok pass pass trap EXIT with PARSE error
details
11pass pass pass pass pass trap EXIT with PARSE error and explicit exit
12pass pass pass pass pass trap EXIT with explicit exit
13pass pass pass pass pass trap EXIT with command sub / subshell / pipeline
14pass pass pass pass pass trap 0 is equivalent to EXIT
15N-I pass pass pass pass trap 1 is equivalent to SIGHUP; HUP is equivalent to SIGHUP
details
16pass pass pass pass pass eval in the exit trap (regression for issue #293)
17pass pass pass pass FAIL exit codes for traps are isolated
details
18pass pass pass pass FAIL traps are cleared in subshell (started with &)
details
19pass pass pass pass FAIL trap USR1, sleep, SIGINT: non-interactively
details
20pass pass ok pass FAIL trap INT, sleep, SIGINT: non-interactively
detailsdetails
21pass pass pass pass FAIL trap EXIT, sleep, SIGINT: non-interactively
details
22pass pass pass pass pass Remove trap with an unsigned integer
94 passed, 5 OK, 3 not implemented, 7 BUG, 6 failed, 0 timeouts, 0 cases skipped
6 failed under osh

Details on runs that didn't PASS

dash3 SIGINT and INT are aliases

stdout:
1
0
stderr:
trap: SIGINT: bad trap
dash4 trap without args prints traps, like trap -p

stdout:
stderr: 
mksh4 trap without args prints traps, like trap -p

stdout:
status=0
status=1
stderr:
ash4 trap without args prints traps, like trap -p

stdout:
status=0
status=1
stderr:
osh4 trap without args prints traps, like trap -p

[osh stdout] Expected "status=0\ntrap -- 'true' EXIT\nstatus=0\n", got 'status=0\nstatus=1\n'

stdout:
status=0
status=1
stderr:
  trap | grep EXIT
  ^~~~
[ -c flag ]:6: 'trap' requires a code string
osh5 trap 'echo hi' KILL (regression test, caught by smoosh suite)

stdout:
status=1
status=1
status=1
status=0
stderr:
  trap 'echo hi' 9
                 ^
[ stdin ]:1: Signal '9' can't be handled
  trap 'echo hi' KILL
                 ^~~~
[ stdin ]:4: Invalid signal or hook 'KILL'
  trap 'echo hi' STOP
                 ^~~~
[ stdin ]:7: Signal 'STOP' can't be handled
dash6 Invalid trap invocation

stdout:
status=1
stderr:
trap: foo: bad trap
mksh6 Invalid trap invocation

stdout:
status=0
stderr:
ash6 Invalid trap invocation

stdout:
status=1
stderr:
ash: trap: line 1: foo: invalid signal specification
dash7 exit 1 when trap code string is invalid

stdout:
status=0
stderr:
dash: 1: Syntax error: end of file unexpected
bash7 exit 1 when trap code string is invalid

stdout:
status=0
stderr:
bash: exit trap: line 1: syntax error near unexpected token `newline'
bash: exit trap: line 1: `echo <'
mksh7 exit 1 when trap code string is invalid

stdout:
status=0
stderr:
mksh: syntax error: unexpected EOF
ash7 exit 1 when trap code string is invalid

stdout:
status=0
stderr:
ash: syntax error: unexpected end of file
mksh10 trap EXIT with PARSE error

stdout:
FAILED
stderr:
mksh: <stdin>[2]: syntax error: 'newline' unexpected
dash15 trap 1 is equivalent to SIGHUP; HUP is equivalent to SIGHUP

stdout:
status=1
status=0
status=0
status=0
stderr:
trap: SIGHUP: bad trap
osh17 exit codes for traps are isolated

[osh stdout] Expected 'before=0\nUSR1 trap status=0\nafter=0\n', got 'before=0\n'
[osh status] Expected 0, got 1
[osh stderr] Found 'Traceback (most recent'

stdout:
before=0
stderr:
Traceback (most recent call last):
  File "/home/uke/oil/bin/oils_for_unix.py", line 201, in <module>
    sys.exit(main(sys.argv))
  File "/home/uke/oil/bin/oils_for_unix.py", line 170, in main
    return AppBundleMain(argv)
  File "/home/uke/oil/bin/oils_for_unix.py", line 140, in AppBundleMain
    return shell.Main('osh', arg_r, environ, login_shell, loader, readline)
  File "/home/uke/oil/core/shell.py", line 1240, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/uke/oil/core/main_loop.py", line 365, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 2051, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1585, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 874, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 546, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 385, in RunSimpleCommand
    status = p.RunProcess(self.waiter, trace.External(cmd_val.argv))
  File "/home/uke/oil/core/process.py", line 1193, in RunProcess
    return self.Wait(waiter)
  File "/home/uke/oil/core/process.py", line 1122, in Wait
    if waiter.WaitForOne() == W1_ECHILD:
  File "/home/uke/oil/core/process.py", line 1908, in WaitForOne
    pid, status = pyos.WaitPid(waitpid_options)
  File "/home/uke/oil/core/pyos.py", line 64, in WaitPid
    if e.errno == EINTR and gSignalSafe.PollUntrappedSigInt():
AttributeError: 'NoneType' object has no attribute 'PollUntrappedSigInt'
osh18 traps are cleared in subshell (started with &)

[osh stdout] Expected 'SIGURG\nbegin child\nend child\nwait status 0\n' Got ''
[osh status] Expected 0, got 1
[osh stderr] Found 'Traceback (most recent'

stdout:
stderr: 
Traceback (most recent call last):
  File "/home/uke/oil/bin/oils_for_unix.py", line 201, in <module>
    sys.exit(main(sys.argv))
  File "/home/uke/oil/bin/oils_for_unix.py", line 170, in main
    return AppBundleMain(argv)
  File "/home/uke/oil/bin/oils_for_unix.py", line 140, in AppBundleMain
    return shell.Main('osh', arg_r, environ, login_shell, loader, readline)
  File "/home/uke/oil/core/shell.py", line 1240, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/uke/oil/core/main_loop.py", line 365, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 2051, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1585, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 874, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 546, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 385, in RunSimpleCommand
    status = p.RunProcess(self.waiter, trace.External(cmd_val.argv))
  File "/home/uke/oil/core/process.py", line 1193, in RunProcess
    return self.Wait(waiter)
  File "/home/uke/oil/core/process.py", line 1122, in Wait
    if waiter.WaitForOne() == W1_ECHILD:
  File "/home/uke/oil/core/process.py", line 1908, in WaitForOne
    pid, status = pyos.WaitPid(waitpid_options)
  File "/home/uke/oil/core/pyos.py", line 64, in WaitPid
    if e.errno == EINTR and gSignalSafe.PollUntrappedSigInt():
AttributeError: 'NoneType' object has no attribute 'PollUntrappedSigInt'
osh19 trap USR1, sleep, SIGINT: non-interactively

[osh stdout] Expected 'usr1\nstatus=0\n', got 'status=0\n'
[osh stderr] Found 'Traceback (most recent'

stdout:
status=0
stderr:
Traceback (most recent call last):
  File "/home/uke/oil/bin/oils_for_unix.py", line 201, in <module>
    sys.exit(main(sys.argv))
  File "/home/uke/oil/bin/oils_for_unix.py", line 170, in main
    return AppBundleMain(argv)
  File "/home/uke/oil/bin/oils_for_unix.py", line 140, in AppBundleMain
    return shell.Main('osh', arg_r, environ, login_shell, loader, readline)
  File "/home/uke/oil/core/shell.py", line 1240, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/uke/oil/core/main_loop.py", line 365, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 2051, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1696, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1927, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1585, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 874, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 546, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 385, in RunSimpleCommand
    status = p.RunProcess(self.waiter, trace.External(cmd_val.argv))
  File "/home/uke/oil/core/process.py", line 1193, in RunProcess
    return self.Wait(waiter)
  File "/home/uke/oil/core/process.py", line 1122, in Wait
    if waiter.WaitForOne() == W1_ECHILD:
  File "/home/uke/oil/core/process.py", line 1908, in WaitForOne
    pid, status = pyos.WaitPid(waitpid_options)
  File "/home/uke/oil/core/pyos.py", line 64, in WaitPid
    if e.errno == EINTR and gSignalSafe.PollUntrappedSigInt():
AttributeError: 'NoneType' object has no attribute 'PollUntrappedSigInt'
mksh20 trap INT, sleep, SIGINT: non-interactively

stdout:
mksh
stderr:
osh20 trap INT, sleep, SIGINT: non-interactively

[osh stdout] Expected 'int\nstatus=0\n', got 'status=0\n'
[osh stderr] Found 'Traceback (most recent'

stdout:
status=0
stderr:
Traceback (most recent call last):
  File "/home/uke/oil/bin/oils_for_unix.py", line 201, in <module>
    sys.exit(main(sys.argv))
  File "/home/uke/oil/bin/oils_for_unix.py", line 170, in main
    return AppBundleMain(argv)
  File "/home/uke/oil/bin/oils_for_unix.py", line 140, in AppBundleMain
    return shell.Main('osh', arg_r, environ, login_shell, loader, readline)
  File "/home/uke/oil/core/shell.py", line 1240, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/uke/oil/core/main_loop.py", line 365, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 2051, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1696, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1927, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1585, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 874, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 546, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 385, in RunSimpleCommand
    status = p.RunProcess(self.waiter, trace.External(cmd_val.argv))
  File "/home/uke/oil/core/process.py", line 1193, in RunProcess
    return self.Wait(waiter)
  File "/home/uke/oil/core/process.py", line 1122, in Wait
    if waiter.WaitForOne() == W1_ECHILD:
  File "/home/uke/oil/core/process.py", line 1908, in WaitForOne
    pid, status = pyos.WaitPid(waitpid_options)
  File "/home/uke/oil/core/pyos.py", line 64, in WaitPid
    if e.errno == EINTR and gSignalSafe.PollUntrappedSigInt():
AttributeError: 'NoneType' object has no attribute 'PollUntrappedSigInt'
osh21 trap EXIT, sleep, SIGINT: non-interactively

[osh stdout] Expected 'on exit\nstatus=0\n', got 'status=0\n'
[osh stderr] Found 'Traceback (most recent'

stdout:
status=0
stderr:
Traceback (most recent call last):
  File "/home/uke/oil/bin/oils_for_unix.py", line 201, in <module>
    sys.exit(main(sys.argv))
  File "/home/uke/oil/bin/oils_for_unix.py", line 170, in main
    return AppBundleMain(argv)
  File "/home/uke/oil/bin/oils_for_unix.py", line 140, in AppBundleMain
    return shell.Main('osh', arg_r, environ, login_shell, loader, readline)
  File "/home/uke/oil/core/shell.py", line 1240, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/uke/oil/core/main_loop.py", line 365, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 2051, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1696, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1927, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1850, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1585, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 874, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 546, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 385, in RunSimpleCommand
    status = p.RunProcess(self.waiter, trace.External(cmd_val.argv))
  File "/home/uke/oil/core/process.py", line 1193, in RunProcess
    return self.Wait(waiter)
  File "/home/uke/oil/core/process.py", line 1122, in Wait
    if waiter.WaitForOne() == W1_ECHILD:
  File "/home/uke/oil/core/process.py", line 1908, in WaitForOne
    pid, status = pyos.WaitPid(waitpid_options)
  File "/home/uke/oil/core/pyos.py", line 64, in WaitPid
    if e.errno == EINTR and gSignalSafe.PollUntrappedSigInt():
AttributeError: 'NoneType' object has no attribute 'PollUntrappedSigInt'