]> www.infradead.org Git - users/hch/xfstests-dev.git/commitdiff
generic/256: constrain runtime with TIME_FACTOR
authorDarrick J. Wong <djwong@kernel.org>
Wed, 7 Feb 2024 02:18:39 +0000 (18:18 -0800)
committerZorro Lang <zlang@kernel.org>
Fri, 9 Feb 2024 05:27:17 +0000 (13:27 +0800)
This test runs 500 iterations of a "fill the fs and try to punch" test.
Hole punching can be particularly slow if, say, the filesystem is
mounted with -odiscard and the DISCARD operation takes a very long time.
In extreme cases, I can see test runtimes of 4+ hours.

Constrain the runtime of _test_full_fs_punch by establishing a deadline
of (30 seconds * TIME_FACTOR) and breaking out of the for loop if the
test goes beyond the time budget.  This keeps the runtime within the
customary 30 seconds.

Signed-off-by: "Darrick J. Wong" <djwong@kernel.org>
Reviewed-by: Andrey Albershteyn <aalbersh@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Zorro Lang <zlang@kernel.org>
tests/generic/256

index 808a730f3ad6c348373073c0bdcb5730af9c540c..ea6cc2938a5ab31c1c82aa56d0232ad901aa1375 100755 (executable)
@@ -44,6 +44,8 @@ _test_full_fs_punch()
        local file_len=$(( $(( $hole_len + $hole_interval )) * $iterations ))
        local path=`dirname $file_name`
        local hole_offset=0
+       local start_time
+       local stop_time
 
        if [ $# -ne 5 ]
        then
@@ -57,6 +59,9 @@ _test_full_fs_punch()
                -c "fsync" $file_name &> /dev/null
        chmod 666 $file_name
 
+       start_time="$(date +%s)"
+       stop_time=$(( start_time + (30 * TIME_FACTOR) ))
+
        # All files are created as a non root user to prevent reserved blocks
        # from being consumed.
        _fill_fs $(( 1024 * 1024 * 1024 )) $path/fill $block_size 1 \
@@ -64,6 +69,8 @@ _test_full_fs_punch()
 
        for (( i=0; i<$iterations; i++ ))
        do
+               test "$(date +%s)" -ge "$stop_time" && break
+
                # This part must not be done as root in order to
                # test that reserved blocks are used when needed
                _user_do "$XFS_IO_PROG -f -c \"fpunch $hole_offset $hole_len\" $file_name"