[Clfs-support] 10.66. Gzip-1.6 test error "zgrep-signal" "chroot method"
Robin
rc.rattusrattus at gmail.com
Sat Mar 15 12:58:05 PDT 2014
On 15 March 2014 19:21, William Harrington <kb0iic at berzerkula.org> wrote:
>
> On Mar 15, 2014, at 1:24 PM, Robin wrote:
>
>> ERROR: zgrep-signal
>
>
> Yeah, I posted this back in August:
>
> http://lists.cross-lfs.org/pipermail/clfs-dev-cross-lfs.org/2013-August/001580.html
>
> Although my latest tests with our systemd branch show all passed tests:
>
> http://cross-lfs.org/~kb0iic/CLFS-GIT-SYSTEMD/build-logs/x86/test-logs/159-gzip
> http://cross-lfs.org/~kb0iic/CLFS-GIT-SYSTEMD/build-logs/x86_64-64/test-logs/161-gzip
>
>
> But muiltilib fails, still:
>
> http://cross-lfs.org/~kb0iic/CLFS-GIT-SYSTEMD/build-logs/x86_64/test-logs/185-gzip
>
> My guess is we need to use the multilib arch wrapper script for perl so it
> finds the suitable perl.
>
> Are we needing USE_ARCH=64 make check ?
>
> Can you confirm this?
>
> Sincerely,
>
> William Harrington
Cleared and rebuilt, USE_ARCH=64 make check still fails on zgrep-signal
Is the patch from
https://lists.debian.org/debian-68k/2013/06/msg00056.html worth
trying:
/snip
Thanks for confirming it. This prompted me to look at the code again
(my! I haven't used Perl in a year and a half! time to brush off
some of that rust...) and I found a race condition that could explain
the bug. I pushed the following patch; can you please give it a try?
(Hmm, I now see a typo "becausee" in a comment; I'll fix that.)
>From 4c0bc4089a762ffef20ad9e0311e634e44b4cfdd Mon Sep 17 00:00:00 2001
From: Paul Eggert <eggert at cs.ucla.edu>
Date: Wed, 19 Jun 2013 08:46:29 -0700
Subject: [PATCH] tests: zgrep-signal race condition fix
* tests/zgrep-signal: Check that Perl supports dup2.
(exec_with_SIGPIPE_SIGDFL): Remove.
(write_to_dangling_pipe): Simplify by moving more of it into Perl.
Fix race condition, where subcommand writes to a pipe before the ":"
command exits. Problem reported by Thorsten Glaser in
<http://lists.gnu.org/archive/html/bug-gzip/2013-06/msg00028.html>.
---
tests/zgrep-signal | 38 +++++++++++++++++++++++---------------
1 file changed, 23 insertions(+), 15 deletions(-)
diff --git a/tests/zgrep-signal b/tests/zgrep-signal
index 3a9c089..5475e5e 100755
--- a/tests/zgrep-signal
+++ b/tests/zgrep-signal
@@ -23,34 +23,42 @@
echo a | gzip -c > f.gz || framework_failure_
test "x$PERL" = x && PERL=perl
-("$PERL" -e 'use warnings') >/dev/null 2>&1 || skip_ "no suitable perl found"
+("$PERL" -e 'use POSIX qw(dup2)') >/dev/null 2>&1 ||
+ skip_ "no suitable perl found"
-exec_with_SIGPIPE_SIG_DFL () {
+# Run the arguments as a command, in a process where stdout is a
+# dangling pipe and SIGPIPE has the default signal-handling action.
+# This can't be done portably in the shell, becausee if SIGPIPE is
+# ignored when the shell is entered, the shell might refuse to trap
+# it. Fall back on Perl+POSIX, if available. Take care to close the
+# pipe's read end before running the program; the equivalent of the
+# shell's "command | :" has a race condition in that COMMAND could
+# write before ":" exits.
+write_to_dangling_pipe () {
program=${1?}
shift
args=
for arg; do
args="$args, '$arg'"
done
- "$PERL" -e "\$SIG{PIPE} = 'DEFAULT'; exec '$program'$args"
+ "$PERL" -e '
+ use POSIX qw(dup2);
+ $SIG{PIPE} = "DEFAULT";
+ pipe my ($read_end, $write_end) or die "pipe: $!\n";
+ dup2 fileno $write_end, 1 or die "dup2: $!\n";
+ close $read_end or die "close: $!\n";
+ exec '"'$program'$args"';
+ '
}
-write_to_dangling_pipe () {
- exec 3>&1
- (
- exec_with_SIGPIPE_SIG_DFL "$@"
- echo $? >&3
- ) | : || framework_failure_
-}
-
-signal_status=$(write_to_dangling_pipe cat f.gz f.gz)
+write_to_dangling_pipe cat f.gz f.gz
+signal_status=$?
test 128 -lt $signal_status ||
framework_failure_ 'signal handling busted on this host'
fail=0
-st=$(write_to_dangling_pipe zgrep a f.gz f.gz)
-
-test $st = $signal_status || fail=1
+write_to_dangling_pipe zgrep a f.gz f.gz
+test $? -eq $signal_status || fail=1
Exit $fail
--
1.7.11.7
Thanks
--
rob
More information about the Clfs-support
mailing list