diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2020-10-24 04:26:43 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2021-01-01 14:30:58 +0100 |
commit | 71afe6c513a54f5524d5a27dcfcaa77ec5046dfb (patch) | |
tree | a7c6a5d4d364b0f9c9751ceb5c1cc2b1bce34753 | |
parent | 0f668aad7ff7ee55141c93498636921b4a52f2eb (diff) | |
download | busybox-w32-71afe6c513a54f5524d5a27dcfcaa77ec5046dfb.tar.gz busybox-w32-71afe6c513a54f5524d5a27dcfcaa77ec5046dfb.tar.bz2 busybox-w32-71afe6c513a54f5524d5a27dcfcaa77ec5046dfb.zip |
hush: output bash-compat killing signal names
This significantly syncronises ash-signals and hush-signals tests.
function old new delta
process_wait_result 449 450 +1
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | shell/ash_test/ash-signals/usage.right | 14 | ||||
-rwxr-xr-x | shell/ash_test/ash-signals/usage.tests | 23 | ||||
-rw-r--r-- | shell/hush.c | 4 | ||||
-rw-r--r-- | shell/hush_test/hush-misc/sig_exitcode.right | 4 | ||||
-rw-r--r-- | shell/hush_test/hush-signals/catch.right | 2 | ||||
-rw-r--r-- | shell/hush_test/hush-signals/signal1.right | 20 | ||||
-rwxr-xr-x | shell/hush_test/hush-signals/signal1.tests | 28 | ||||
-rw-r--r-- | shell/hush_test/hush-signals/signal_read2.right | 2 | ||||
-rw-r--r-- | shell/hush_test/hush-signals/subshell.right | 2 |
9 files changed, 92 insertions, 7 deletions
diff --git a/shell/ash_test/ash-signals/usage.right b/shell/ash_test/ash-signals/usage.right new file mode 100644 index 000000000..c0dbd6c3c --- /dev/null +++ b/shell/ash_test/ash-signals/usage.right | |||
@@ -0,0 +1,14 @@ | |||
1 | ___ | ||
2 | ___ | ||
3 | ___ | ||
4 | trap -- 'a' EXIT | ||
5 | trap -- 'a' INT | ||
6 | trap -- 'a' USR1 | ||
7 | trap -- 'a' USR2 | ||
8 | ___ | ||
9 | ___ | ||
10 | trap -- 'a' USR1 | ||
11 | trap -- 'a' USR2 | ||
12 | ___ | ||
13 | ___ | ||
14 | trap -- 'a' USR2 | ||
diff --git a/shell/ash_test/ash-signals/usage.tests b/shell/ash_test/ash-signals/usage.tests new file mode 100755 index 000000000..d29c6e74a --- /dev/null +++ b/shell/ash_test/ash-signals/usage.tests | |||
@@ -0,0 +1,23 @@ | |||
1 | # no output -- default state | ||
2 | echo ___ | ||
3 | trap | ||
4 | |||
5 | # assign some traps | ||
6 | echo ___ | ||
7 | trap "a" EXIT INT USR1 USR2 | ||
8 | |||
9 | # show them all | ||
10 | echo ___ | ||
11 | trap | ||
12 | |||
13 | # clear one | ||
14 | echo ___ | ||
15 | trap 0 INT | ||
16 | echo ___ | ||
17 | trap | ||
18 | |||
19 | # clear another | ||
20 | echo ___ | ||
21 | trap "-" USR1 | ||
22 | echo ___ | ||
23 | trap | ||
diff --git a/shell/hush.c b/shell/hush.c index 2b34b7da5..bc6e6014f 100644 --- a/shell/hush.c +++ b/shell/hush.c | |||
@@ -8704,8 +8704,8 @@ static int process_wait_result(struct pipe *fg_pipe, pid_t childpid, int status) | |||
8704 | */ | 8704 | */ |
8705 | && i == fg_pipe->num_cmds-1 | 8705 | && i == fg_pipe->num_cmds-1 |
8706 | ) { | 8706 | ) { |
8707 | /* TODO: use strsignal() instead for bash compat? but that's bloat... */ | 8707 | /* strsignal() is for bash compat. ~600 bloat versus bbox's get_signame() */ |
8708 | puts(sig == SIGINT || sig == SIGPIPE ? "" : get_signame(sig)); | 8708 | puts(sig == SIGINT || sig == SIGPIPE ? "" : strsignal(sig)); |
8709 | } | 8709 | } |
8710 | /* TODO: if (WCOREDUMP(status)) + " (core dumped)"; */ | 8710 | /* TODO: if (WCOREDUMP(status)) + " (core dumped)"; */ |
8711 | /* TODO: MIPS has 128 sigs (1..128), what if sig==128 here? | 8711 | /* TODO: MIPS has 128 sigs (1..128), what if sig==128 here? |
diff --git a/shell/hush_test/hush-misc/sig_exitcode.right b/shell/hush_test/hush-misc/sig_exitcode.right index d5f000a08..7cbc1072d 100644 --- a/shell/hush_test/hush-misc/sig_exitcode.right +++ b/shell/hush_test/hush-misc/sig_exitcode.right | |||
@@ -1,5 +1,5 @@ | |||
1 | KILL | 1 | Killed |
2 | 137:137 | 2 | 137:137 |
3 | KILL | 3 | Killed |
4 | 0:0 | 4 | 0:0 |
5 | Done | 5 | Done |
diff --git a/shell/hush_test/hush-signals/catch.right b/shell/hush_test/hush-signals/catch.right index 80a062c4b..68530c6e7 100644 --- a/shell/hush_test/hush-signals/catch.right +++ b/shell/hush_test/hush-signals/catch.right | |||
@@ -2,4 +2,4 @@ sending USR2 | |||
2 | caught | 2 | caught |
3 | sending USR2 | 3 | sending USR2 |
4 | sending USR2 | 4 | sending USR2 |
5 | USR2 | 5 | User defined signal 2 |
diff --git a/shell/hush_test/hush-signals/signal1.right b/shell/hush_test/hush-signals/signal1.right new file mode 100644 index 000000000..cf403ac62 --- /dev/null +++ b/shell/hush_test/hush-signals/signal1.right | |||
@@ -0,0 +1,20 @@ | |||
1 | got signal | ||
2 | trap -- 'echo got signal' USR1 | ||
3 | sent 1 signal | ||
4 | got signal | ||
5 | wait interrupted | ||
6 | trap -- 'echo got signal' USR1 | ||
7 | sent 2 signal | ||
8 | got signal | ||
9 | wait interrupted | ||
10 | trap -- 'echo got signal' USR1 | ||
11 | sent 3 signal | ||
12 | got signal | ||
13 | wait interrupted | ||
14 | trap -- 'echo got signal' USR1 | ||
15 | sent 4 signal | ||
16 | got signal | ||
17 | wait interrupted | ||
18 | trap -- 'echo got signal' USR1 | ||
19 | sent 5 signal | ||
20 | sleep completed | ||
diff --git a/shell/hush_test/hush-signals/signal1.tests b/shell/hush_test/hush-signals/signal1.tests new file mode 100755 index 000000000..61943467a --- /dev/null +++ b/shell/hush_test/hush-signals/signal1.tests | |||
@@ -0,0 +1,28 @@ | |||
1 | trap "echo got signal" USR1 | ||
2 | |||
3 | for try in 1 2 3 4 5; do | ||
4 | kill -USR1 $$ | ||
5 | sleep 0.2 | ||
6 | echo "sent $try signal" | ||
7 | done & | ||
8 | |||
9 | # Ensure "wait" has something to wait for | ||
10 | sleep 2 & | ||
11 | |||
12 | # Ensure we do not execute "trap" below before "kill -USR1" above | ||
13 | # (was getting failure on loaded machine without this) | ||
14 | sleep 0.1 | ||
15 | |||
16 | sleeping=true | ||
17 | while $sleeping; do | ||
18 | trap | ||
19 | if wait %%; then | ||
20 | echo "sleep completed" | ||
21 | sleeping=false | ||
22 | elif [ $? = 127 ]; then | ||
23 | echo "BUG: no processes to wait for?!" | ||
24 | sleeping=false | ||
25 | else | ||
26 | echo "wait interrupted" | ||
27 | fi | ||
28 | done | ||
diff --git a/shell/hush_test/hush-signals/signal_read2.right b/shell/hush_test/hush-signals/signal_read2.right index 71a6bc16d..87d8da304 100644 --- a/shell/hush_test/hush-signals/signal_read2.right +++ b/shell/hush_test/hush-signals/signal_read2.right | |||
@@ -1,2 +1,2 @@ | |||
1 | HUP | 1 | Hangup |
2 | Done:129 | 2 | Done:129 |
diff --git a/shell/hush_test/hush-signals/subshell.right b/shell/hush_test/hush-signals/subshell.right index f865b932b..248fcc41a 100644 --- a/shell/hush_test/hush-signals/subshell.right +++ b/shell/hush_test/hush-signals/subshell.right | |||
@@ -17,5 +17,5 @@ Ok | |||
17 | trap -- '' HUP | 17 | trap -- '' HUP |
18 | trap -- '' QUIT | 18 | trap -- '' QUIT |
19 | trap -- '' SYS | 19 | trap -- '' SYS |
20 | TERM | 20 | Terminated |
21 | Done | 21 | Done |