From 29cd838eab01ed7110f3ccb2e8c6a35c8a31dbcc Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 11 Apr 2024 10:21:29 +0200 Subject: Adding upstream version 1:0.1.9998svn3589+dfsg. Signed-off-by: Daniel Baumann --- src/grep/tests/big-hole | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100755 src/grep/tests/big-hole (limited to 'src/grep/tests/big-hole') diff --git a/src/grep/tests/big-hole b/src/grep/tests/big-hole new file mode 100755 index 0000000..eac077f --- /dev/null +++ b/src/grep/tests/big-hole @@ -0,0 +1,29 @@ +#!/bin/sh +# Check that grep --binary-file=without-match quickly skips files with holes. + +. "${srcdir=.}/init.sh"; path_prepend_ ../src + +expensive_ + +# Skip this test if there is no usable SEEK_HOLE support, +# as is the case with linux-3.5.0 on ext4 and tmpfs file systems. +$PERL -e '$f=*STDERR; sysseek($f,2**22,0); syswrite($f,"a");' \ + -e 'exit ("0 but true" ne sysseek($f,0,4))' 2> seek-hole-test \ + || skip_ "this system/FS lacks SEEK_HOLE support" + +# Try to make this test not THAT expensive, on typical hosts. +virtual_memory_KiB=10240 +if echo x | (ulimit -v $virtual_memory_KiB && grep x) >/dev/null 2>&1; then + ulimit -v $virtual_memory_KiB +fi + +# Create a file that starts with at least a buffer's worth of text, +# but has a big hole later. +(${AWK-awk} 'BEGIN{ for (i=0;i<1000;i++) printf "%080d\n", 0 }' < /dev/null + echo x | dd bs=1024k seek=8000000 +) >8T-or-so || skip_ 'cannot create big sparse file' + +grep --binary-file=without-match x 8T-or-so >/dev/null +test $? -eq 1 || fail=1 + +Exit $fail -- cgit v1.2.3