]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
tail: add a test to exercise abort-inducing flaw in tail -F
authorJim Meyering <meyering@redhat.com>
Mon, 28 Dec 2009 14:42:10 +0000 (15:42 +0100)
committerJim Meyering <meyering@redhat.com>
Tue, 29 Dec 2009 16:01:54 +0000 (17:01 +0100)
* tests/tail-2/inotify-hash-abuse: New file, derived from
a report by Rob Wortman.
* tests/Makefile.am (TESTS): Add it.
Improved by: Pádraig Brady.

THANKS
tests/Makefile.am
tests/tail-2/inotify-hash-abuse [new file with mode: 0755]

diff --git a/THANKS b/THANKS
index 668d59f3e5e5f0b448abfad0b4a4db1fe0988102..86be25230b0502471ace499915ad7726b10e97c9 100644 (file)
--- a/THANKS
+++ b/THANKS
@@ -512,6 +512,7 @@ Richard Sharman                     rsharman@magmacom.com
 Rick Sladkey                        jrs@world.std.com
 Rik Faith                           faith@cs.unc.edu
 Risto Kankkunen                     kankkune@lingsoft.fi
+Rob Wortman                         wyrm@haell.com
 Robert H. de Vries                  robert@and.nl
 Robert Lindgren                     robert@orcafat.com
 Robert Millan                       zeratul2@wanadoo.es
index 93d4275cde4540d812fed8887e8884e403902f5f..35ea8b234c5d8be9d807d977e7b2347091ff1038 100644 (file)
@@ -80,6 +80,7 @@ TESTS =                                               \
   rm/ext3-perf                                 \
   rm/cycle                                     \
   cp/link-heap                                 \
+  tail-2/inotify-hash-abuse                    \
   tail-2/inotify-rotate                                \
   chmod/no-x                                   \
   chgrp/basic                                  \
diff --git a/tests/tail-2/inotify-hash-abuse b/tests/tail-2/inotify-hash-abuse
new file mode 100755 (executable)
index 0000000..bc86398
--- /dev/null
@@ -0,0 +1,69 @@
+#!/bin/sh
+# Exercise an abort-inducing flaw in inotify-enabled tail -F.
+
+# Copyright (C) 2009 Free Software Foundation, Inc.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+if test "$VERBOSE" = yes; then
+  set -x
+  tail --version
+fi
+
+. $srcdir/test-lib.sh
+
+# 9 is a magic number, related to internal details of tail.c and hash.c
+n=9
+seq $n | xargs touch || framework_failure
+
+debug='---disable-inotify -s .01'
+debug=
+tail $debug -qF $(seq $n) > out 2>&1 & pid=$!
+
+# Wait until tail has started...
+echo x > $n
+until grep '^x$' out >/dev/null 2>&1; do :; done
+
+mv 1 f || fail=1
+
+# Wait for this diagnostic:
+# tail: `1' has become inaccessible: No such file or directory
+until grep inaccessible out >/dev/null 2>&1; do :; done
+
+# Trigger the bug.  Before the fix, this would provoke the abort.
+echo a > 1 || fail=1
+
+# Wait up to 2s for the buggy tail to die,
+# or for the "tail: `1' has appeared;  following end of new file" output
+dead=0
+for i in $(seq 10); do
+  kill -0 $pid || { dead=1; break; }
+  grep 'has appeared;' out > /dev/null && break
+  sleep .2
+done
+
+# Fixed tail will not have aborted.  Kill it.
+test $dead = 0 && kill -HUP $pid
+
+wait $pid
+st=$?
+
+case $st in
+  129) ;;
+  *) echo tail died via unexpected signal: $st; fail=1;;
+esac
+
+cat out
+
+Exit $fail