Files
apfstests/tests/xfs/332
T
Eryu Guan c61fa13e94 xfs: renumber tests after merge
Tests were merged with high seq numbers to avoid conflicts with
other tests. Now renumber them to contiguous numbers, as all other
tests have been merged correctly. This is easier to do than
assigning the final seq numbers at commit time.

Signed-off-by: Eryu Guan <eguan@redhat.com>
2016-10-08 14:02:04 +08:00

93 lines
2.5 KiB
Bash
Executable File

#! /bin/bash
# FS QA Test No. 332
#
# Make sure query_range returns -EINVAL if lowkey > highkey.
#
#-----------------------------------------------------------------------
# Copyright (c) 2016, Oracle and/or its affiliates. All Rights Reserved.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it would be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write the Free Software Foundation,
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#-----------------------------------------------------------------------
seq=`basename "$0"`
seqres="$RESULT_DIR/$seq"
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15
_cleanup()
{
cd /
rm -rf "$tmp".*
}
# get standard environment, filters and checks
. ./common/rc
. ./common/filter
. ./common/attr
# real QA test starts here
_supported_os Linux
_supported_fs xfs
_require_xfs_scratch_rmapbt
_require_command "$XFS_DB_PROG" "xfs_db"
_require_xfs_io_command "falloc"
_require_xfs_io_command "fpunch"
_require_xfs_io_command "fzero"
_require_xfs_io_command "fcollapse"
_require_xfs_io_command "finsert"
rm -f "$seqres.full"
echo "Format and mount"
_scratch_mkfs > "$seqres.full" 2>&1
_scratch_mount
blksz=65536
blocks=16
len=$((blocks * blksz))
echo "Create some files"
$XFS_IO_PROG -f -c "falloc 0 $len" -c "pwrite -S 0x68 -b 1048576 0 $len" $SCRATCH_MNT/f1 >> $seqres.full
echo "Manipulate file"
$XFS_IO_PROG -c "fpunch $blksz $blksz" \
-c "fzero $((3 * blksz)) $blksz" \
-c "pwrite -S 0x69 $((5 * blksz)) $blksz" \
-c "fpunch $((7 * blksz)) $blksz" \
-c "fsync" \
-c "pwrite -S 0x70 $((7 * blksz)) $blksz" \
-c "fcollapse $((9 * blksz)) $blksz" \
-c "finsert $((10 * blksz)) $blksz" $SCRATCH_MNT/f1 >> $seqres.full
echo "Check file"
md5sum $SCRATCH_MNT/f1 | _filter_scratch
od -tx1 -Ad -c $SCRATCH_MNT/f1 >> $seqres.full
echo "Unmount"
_scratch_unmount
echo "Try a regular fsmap"
_scratch_xfs_db -c 'fsmap' >> $seqres.full
_scratch_xfs_db -c 'fsmap 0 5' >> $seqres.full
echo "Try a bad fsmap"
_scratch_xfs_db -c 'fsmap 5 4'
# success, all done
status=0
exit