# This example will call the dd_reblock_1 function with
# an initial delay of .1 second and call it at most 6 times
# with a max delay of 3.2s (doubled each time), or a total of 6.3s
-# Note ensure you do _not_ quote the parameter to GNU sleep in
-# your function, as it may contain separate values that sleep
-# needs to accumulate.
# Further function arguments will be forwarded to the test function.
retry_delay_()
{
test "$time_fail" = 0
}
+detect_tail_mode_()
+{
+ touch tail.debug || framework_failure_
+ returns_ 124 timeout "$1" tail -n0 -F --debug tail.debug 2>tail.mode ||
+ framework_failure_
+ grep 'using .* mode' tail.mode >/dev/null
+}
+
+require_inotify_supported_()
+{
+ require_built_ tail timeout
+
+ retry_delay_ detect_tail_mode_ .1 4
+
+ # This may skip because:
+ # inotify is not available in this build
+ # inotify is not supported on this file system
+ # tail didn't print the debug info within 1.5s (unlikely)
+ grep 'using notification mode' tail.mode >/dev/null ||
+ skip_ 'inotify not detected'
+}
+
# Call this with a list of programs under test immediately after
# sourcing init.sh.
print_ver_()
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
print_ver_ tail
-
-grep '^#define HAVE_INOTIFY 1' "$CONFIG_HEADER" >/dev/null && is_local_dir_ . \
- || skip_ 'inotify is not supported'
-
-# There may be a mismatch between is_local_dir_ (gnulib's remoteness check),
-# and coreutils' is_local_fs_type(), so double check we're using inotify.
-touch file.strace
-require_strace_ 'inotify_add_watch'
-returns_ 124 timeout .1 strace -e inotify_add_watch -o strace.out \
- tail -F file.strace || fail=1
-grep 'inotify' strace.out || skip_ 'inotify not detected'
+require_inotify_supported_
# Terminate any background tail process
cleanup_() { kill $pid 2>/dev/null && wait $pid; }
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
print_ver_ tail
-grep '^#define HAVE_INOTIFY 1' "$CONFIG_HEADER" >/dev/null \
- || skip_ 'inotify support required'
+require_inotify_supported_
require_strace_ 'inotify_add_watch'
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
print_ver_ tail sleep
-
-grep '^#define HAVE_INOTIFY 1' "$CONFIG_HEADER" >/dev/null && is_local_dir_ . \
- || skip_ 'inotify is not supported'
+require_inotify_supported_
# Terminate any background gdb/tail process
cleanup_() {
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
print_ver_ tail sleep
-
-grep '^#define HAVE_INOTIFY 1' "$CONFIG_HEADER" >/dev/null && is_local_dir_ . \
- || skip_ 'inotify is not supported'
+require_inotify_supported_
# Terminate any background gdb/tail process
cleanup_() {