xfs/{263,106}: erase max warnings printout
[xfstests-dev.git] / tests / generic / 164
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2015 Oracle, Inc.  All Rights Reserved.
4 #
5 # FS QA Test No. 164
6 #
7 # Test for races or FS corruption between reflink and buffered I/O reading the
8 # target file.
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
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 _supported_os Linux
33 _require_scratch_reflink
34 _require_cp_reflink
35
36 echo "Format and mount"
37 _scratch_mkfs > $seqres.full 2>&1
38 _scratch_mount >> $seqres.full 2>&1
39
40 testdir=$SCRATCH_MNT/test-$seq
41 finished_file=/tmp/finished
42 rm -rf $finished_file
43 mkdir $testdir
44
45 loops=512
46 nr_loops=$((loops - 1))
47 blksz=65536
48
49 echo "Initialize files"
50 echo >> $seqres.full
51 _pwrite_byte 0x61 0 $((loops * blksz)) $testdir/file1 >> $seqres.full
52 _pwrite_byte 0x62 0 $((loops * blksz)) $testdir/file2 >> $seqres.full
53 _cp_reflink $testdir/file1 $testdir/file3
54 _scratch_cycle_mount
55
56 fbytes() {
57         egrep -v '(61 61 61 61 61 61 61 61 61 61 61 61 61 61 61 61|62 62 62 62 62 62 62 62 62 62 62 62 62 62 62 62)'
58 }
59
60 reader() {
61         while [ ! -e $finished_file ]; do
62                 _read_range $testdir/file3 0 $((loops * blksz)) | fbytes
63         done
64 }
65
66 echo "Reflink and reread the files!"
67 reader &
68 for i in `seq 1 2`; do
69         seq $nr_loops -1 0 | while read i; do
70                 _reflink_range  $testdir/file1 $((i * blksz)) \
71                                 $testdir/file3 $((i * blksz)) $blksz >> $seqres.full
72                 [ $? -ne 0 ] && break
73         done
74         seq $nr_loops -1 0 | while read i; do
75                 _reflink_range  $testdir/file2 $((i * blksz)) \
76                                 $testdir/file3 $((i * blksz)) $blksz >> $seqres.full
77                 [ $? -ne 0 ] && break
78         done
79 done
80 echo "Finished reflinking"
81 touch $finished_file
82 wait
83
84 # success, all done
85 status=0
86 exit