From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: X-Spam-Status: No, score=-4.0 required=3.0 tests=ALL_TRUSTED,BAYES_00 shortcircuit=no autolearn=ham autolearn_force=no version=3.4.2 Received: from localhost (dcvr.yhbt.net [127.0.0.1]) by dcvr.yhbt.net (Postfix) with ESMTP id BF6E11FA01 for ; Sat, 30 Oct 2021 08:11:44 +0000 (UTC) From: Eric Wong To: meta@public-inbox.org Subject: [PATCH 3/5] lei_xsearch: quiet error message on SIG{PIPE,TERM} Date: Sat, 30 Oct 2021 08:11:42 +0000 Message-Id: <20211030081144.1080-4-e@80x24.org> In-Reply-To: <20211030081144.1080-1-e@80x24.org> References: <20211030081144.1080-1-e@80x24.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit List-Id: SIGPIPE and SIGTERM are common and user-induced, so they're not worth warning on. Add the value of "$?", though, since it can help users notice other errors (e.g. SIGSEGV). --- lib/PublicInbox/LeiXSearch.pm | 5 ++++- t/lei-sigpipe.t | 7 +++++-- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/lib/PublicInbox/LeiXSearch.pm b/lib/PublicInbox/LeiXSearch.pm index 2a037f2bd79b..29df07e0c8a8 100644 --- a/lib/PublicInbox/LeiXSearch.pm +++ b/lib/PublicInbox/LeiXSearch.pm @@ -409,7 +409,10 @@ sub git { $_[0]->{git} // die 'BUG: git uninitialized' } sub xsearch_done_wait { # dwaitpid callback my ($arg, $pid) = @_; my ($wq, $lei) = @$arg; - $lei->child_error($?, 'non-fatal error from '.ref($wq)) if $?; + return if !$?; + my $s = $? & 127; + return $lei->child_error($?) if $s == 13 || $s == 15; + $lei->child_error($?, 'non-fatal error from '.ref($wq)." \$?=$?"); } sub query_done { # EOF callback for main daemon diff --git a/t/lei-sigpipe.t b/t/lei-sigpipe.t index f84d6d22ec4d..d9738b07bd8e 100644 --- a/t/lei-sigpipe.t +++ b/t/lei-sigpipe.t @@ -8,7 +8,7 @@ use POSIX qw(WTERMSIG WIFSIGNALED SIGPIPE); test_lei(sub { my $f = "$ENV{HOME}/big.eml"; my $imported; - for my $out ([], [qw(-f mboxcl2)]) { + for my $out ([], [qw(-f mboxcl2)], [qw(-f text)]) { pipe(my ($r, $w)) or BAIL_OUT $!; my $size = 65536; if ($^O eq 'linux' && fcntl($w, 1031, 4096)) { @@ -27,7 +27,7 @@ EOM } lei_ok(qw(import), $f) if $imported++ == 0; - open my $errfh, '>>', "$ENV{HOME}/stderr.log" or xbail $!; + open my $errfh, '+>', "$ENV{HOME}/stderr.log" or xbail $!; my $opt = { run_mode => 0, 2 => $errfh, 1 => $w }; my $cmd = [qw(lei q -q -t), @$out, 'z:1..']; my $tp = start_script($cmd, undef, $opt); @@ -37,6 +37,9 @@ EOM $tp->join; ok(WIFSIGNALED($?), "signaled @$out"); is(WTERMSIG($?), SIGPIPE, "got SIGPIPE @$out"); + seek($errfh, 0, 0) or xbail $!; + my $s = do { local $/; <$errfh> }; + is($s, '', "quiet after sigpipe @$out"); } });