]> git.ipfire.org Git - thirdparty/util-linux.git/commit
tests/helpers/test_sigstate.c: explicitly reset SIGINT to default action after trapping
authorHongxu Jia <hongxu.jia@windriver.com>
Mon, 28 Jul 2025 12:35:13 +0000 (20:35 +0800)
committerHongxu Jia <hongxu.jia@windriver.com>
Mon, 28 Jul 2025 13:17:11 +0000 (06:17 -0700)
commit6d46bbc0896b963486546d5d1b3d9241a2d5d0f8
tree3c2de633a2bf2573086ab440c02b5fe0becc537b
parent4aded4674f34db836d0178e9557f73c4fc301e12
tests/helpers/test_sigstate.c: explicitly reset SIGINT to default action after trapping

After upgrading bash to 5.3 to contain commit [1], if SIGINT was trapped in
asynchronous subshell, bash called set_signal_async_ignored to make sure
processes that are created by this asynchronous subshell to ignore SIGINT.

And it caused test case `kill/decode' failed, the signal INT was existed in
both of Blocked and Ignored

$ ./tests/run.sh --use-system-commands --parsable --show-diff   kill/decode
...
diff-{{{
|--- /usr/lib/util-linux/ptest/tests/expected/kill/decode        2011-04-05 23:00:00.000000000 +0000
|+++ /usr/lib/util-linux/ptest/tests/output/kill/decode  2025-07-28 12:09:46.279000000 +0000
@@ -16,5 +16,5 @@
 Pending (thread): INT ILL
 Pending (process): USR1
 Blocked: INT ILL ABRT FPE USR1 SEGV TERM
-Ignored: HUP QUIT TRAP PIPE ALRM
+Ignored: HUP INT QUIT TRAP PIPE ALRM
 Caught: ILL USR1
}}}-diff
...

Explicitly reset SIGINT to default action after trapping, then the
test case `kill/decode' works on both of old (<5.3) and new (>=5.3) bash

[1] https://cgit.git.savannah.gnu.org/cgit/bash.git/commit/?h=devel&id=a5d2617c7a7e602ace1f4149987cdfd075c4e762

Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
tests/helpers/test_sigstate.c