]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
tests: cp/sparse-perf: make more robust and add zfs comments
authorPádraig Brady <P@draigBrady.com>
Sat, 25 Sep 2021 13:23:37 +0000 (14:23 +0100)
committerPádraig Brady <P@draigBrady.com>
Sat, 25 Sep 2021 21:40:01 +0000 (22:40 +0100)
* init.cfg (seek_data_capable_): Add a timeout to ensure failure for
slow lseek(...SEEK_DATA) calls (even if that syscall isn't interrupted).
* tests/cp/sparse-perf.sh: Run the SEEK_DATA check on the
1TiB empty file to exclude both FreeBSD 9.1 which takes 35s,
and ZFS which requires a delay of about 5s between file creation
and use of SEEK_DATA to correctly determine it's empty (return ENXIO).
Also remove the stat size checks as they invalidate the test
due to cp never writing data due to it being always zeros,
and thus converted to holes in the output.

init.cfg
tests/cp/sparse-perf.sh

index 714854648f087883876203c877fb230fc2288df5..b92f717f59ef2d466951d4acbd9f3f27c8d6f796 100644 (file)
--- a/init.cfg
+++ b/init.cfg
@@ -540,7 +540,14 @@ seek_data_capable_()
       warn_ 'seek_data_capable_: python missing: assuming not SEEK_DATA capable'
       return 1
   fi
-  $PYTHON_ "$abs_srcdir"/tests/seek-data-capable "$@"
+
+  # Use timeout if available to skip cases where SEEK_DATA takes a long time.
+  # We saw FreeBSD 9.1 take 35s to return from SEEK_DATA for a 1TiB empty file.
+  # Note lseek() is uninterruptible on FreeBSD 9.1, but it does eventually
+  # return, and the timeout will ensure a failure return from the process.
+  timeout --version >/dev/null && TIMEOUT_='timeout 10'
+
+  $TIMEOUT_ $PYTHON_ "$abs_srcdir"/tests/seek-data-capable "$@"
 }
 
 # Skip the current test if "." lacks d_type support.
index fafbf22753cd441448bd71aebc1f69401e7ba55f..019d7ae946e4b3ade6f9b599dab4c72ba164ea29 100755 (executable)
@@ -1,7 +1,7 @@
 #!/bin/sh
 # ensure that a sparse file is copied efficiently, by default
 
-# Copyright (C) 2011-2021 Free Software Foundation, Inc.
+# Copyright (C) 2021 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
 . "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
 print_ver_ cp
 
-touch sparse_chk
-seek_data_capable_ sparse_chk ||
-  skip_ "this file system lacks SEEK_DATA support"
-
 # Create a large-but-sparse file.
 timeout 10 truncate -s1T f ||
   skip_ "unable to create a 1 TiB sparse file"
 
-# Nothing can read (much less write) that many bytes in so little time.
-timeout 10 cp --reflink=never f f2
-ret=$?
-if test $ret -eq 124; then  # timeout
-  # Only fail if we allocated more data
-  # as we've seen SEEK_DATA taking 35s on some freebsd VMs
-  test $(stat -c%b f2) -gt $(stat -c%b f) && fail=1 ||
-    skip_ "SEEK_DATA timed out"
-elif test $ret -ne 0; then
-  fail=1
-fi
+# Note zfs with zfs_dmu_offset_next_sync=0 (the default)
+# will generally skip here, due to needing about 5 seconds
+# between the creation of the file and the use of SEEK_DATA,
+# for it to determine it's an empty file (return ENXIO).
+seek_data_capable_ f ||
+  skip_ "this file system lacks appropriate SEEK_DATA support"
+
+# Nothing can read that many bytes in so little time.
+timeout 10 cp --reflink=never f f2 || fail=1
 
 # Ensure that the sparse file copied through SEEK_DATA has the same size
 # in bytes as the original.