xfs: fix old fuzz test invocations of xfs_repair
[xfstests-dev.git] / tests / generic / 334
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2016 Oracle, Inc.  All Rights Reserved.
4 #
5 # FS QA Test No. 334
6 #
7 # Test for races or FS corruption when trying to hit ENOSPC while writing
8 # to a file that's also the source of a reflink operation.
9 #
10 seq=`basename $0`
11 seqres=$RESULT_DIR/$seq
12 echo "QA output created by $seq"
13
14 here=`pwd`
15 tmp=/tmp/$$
16 status=1        # failure is the default!
17 trap "_cleanup; exit \$status" 0 1 2 3 7 15
18
19 _cleanup()
20 {
21     cd /
22     rm -rf $tmp.* $finished_file $abort_file
23     wait
24 }
25
26 # get standard environment, filters and checks
27 . ./common/rc
28 . ./common/filter
29 . ./common/reflink
30
31 # real QA test starts here
32 _require_scratch_reflink
33 _require_cp_reflink
34
35 echo "Format and mount"
36 _scratch_mkfs_sized $((400 * 1048576)) > $seqres.full 2>&1
37 _scratch_mount >> $seqres.full 2>&1
38
39 testdir=$SCRATCH_MNT/test-$seq
40 finished_file=/tmp/finished
41 rm -rf $finished_file
42 abort_file=/tmp/abort
43 rm -rf $abort_file
44 mkdir $testdir
45
46 loops=1024
47 nr_loops=$((loops - 1))
48 blksz=65536
49
50 echo "Initialize file"
51 echo >> $seqres.full
52 _pwrite_byte 0x61 0 $((loops * blksz)) $testdir/file1 >> $seqres.full
53 _scratch_cycle_mount
54
55 # Snapshot creator...
56 snappy() {
57         n=0
58         while [ ! -e $finished_file ]; do
59                 out="$(_cp_reflink $testdir/file1 $testdir/snap_$n 2>&1)"
60                 res=$?
61                 echo $out | grep -q "No space left" && break
62                 test -n "$out" && echo $out
63                 test $res -ne 0 && break
64                 n=$((n + 1))
65         done
66         touch $abort_file
67 }
68
69 echo "Snapshot a file undergoing buffered rewrite"
70 snappy &
71 seq 1 1000 | while read j; do
72         seq $nr_loops -1 0 | while read i; do
73                 out="$(_pwrite_byte 0x63 $((i * blksz)) $blksz $testdir/file1 2>&1)"
74                 echo $out >> $seqres.full
75                 echo $out | grep -q "No space left" && touch $abort_file
76                 echo $out | grep -qi "error" && touch $abort_file
77                 test -e $abort_file && break
78         done
79         test -e $abort_file && break
80 done
81 touch $finished_file
82 wait
83
84 # success, all done
85 status=0
86 exit