6f61e51e865fd15a2680ec6ad01e6685058a0c04
[xfstests-dev.git] / tests / ext4 / 271
1 #! /bin/bash
2 # FSQA Test No. 271
3 #
4 # Regression testcase for d583fb87a3ff0 (ext4 extent corruption)
5 #
6 #-----------------------------------------------------------------------
7 # Copyright (c) 2006 Silicon Graphics, Inc.  All Rights Reserved.
8 #
9 # This program is free software; you can redistribute it and/or
10 # modify it under the terms of the GNU General Public License as
11 # published by the Free Software Foundation.
12 #
13 # This program is distributed in the hope that it would be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 # GNU General Public License for more details.
17 #
18 # You should have received a copy of the GNU General Public License
19 # along with this program; if not, write the Free Software Foundation,
20 # Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
21 #
22 #-----------------------------------------------------------------------
23 #
24
25 seq=`basename $0`
26 seqres=$RESULT_DIR/$seq
27 echo "QA output created by $seq"
28
29 here=`pwd`
30 tmp=/tmp/$$
31 status=1        # failure is the default!
32 trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
33
34 # get standard environment, filters and checks
35 . ./common/rc
36 . ./common/filter
37
38 # real QA test starts here
39 _supported_fs ext4
40 _supported_os Linux
41 _require_scratch
42 # this test needs no journal to be loaded, skip on journal related mount
43 # options, otherwise mount would fail with "-o noload" mount option
44 _exclude_scratch_mount_option "data" "commit" "journal_checksum" \
45                               "journal_async_commit"
46
47 rm -f $seqres.full
48 _scratch_mkfs_sized $((128 * 1024 * 1024)) >> $seqres.full 2>&1
49
50 # -onoload and EXT4_SYNC_FL on file is important becase result in
51 # metadata sync writes inside ext4_handle_dirty_metadata()
52 _scratch_mount -onoload
53 touch $SCRATCH_MNT/file
54 $CHATTR_PROG +S $SCRATCH_MNT/file
55 # Create sparse file 
56 for ((i = 0; i < 21; i++))
57 do
58     dd if=/dev/zero of=$SCRATCH_MNT/file bs=4k count=1 seek=$((i*10))
59 done
60 # truncate last extent
61 $XFS_IO_PROG -f -c "truncate $((4096*200))" $SCRATCH_MNT/file
62
63 if ! _scratch_unmount; then
64         echo "failed to umount"
65         status=1
66         exit
67 fi
68 echo "Check filesystem"
69 status=0
70 exit