common/xfs: refactor commands to select a particular xfs backing device
[xfstests-dev.git] / tests / generic / 223
index f150dc935fb07053a9679f8c5e146ba19387ae6e..078fd72573044122f97ad1c26c56138d280e9e75 100755 (executable)
@@ -1,27 +1,11 @@
 #! /bin/bash
-# FS QA Test No. 223
-#
-# File alignment tests
-#
-#-----------------------------------------------------------------------
+# SPDX-License-Identifier: GPL-2.0
 # Copyright (c) 2010 Eric Sandeen.  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
+# FS QA Test No. 223
 #
-#-----------------------------------------------------------------------
+# File alignment tests
 #
-
 seq=`basename $0`
 seqres=$RESULT_DIR/$seq
 echo "QA output created by $seq"
@@ -43,7 +27,6 @@ trap "_cleanup ; exit \$status" 0 1 2 3 15
 
 # real QA test starts here
 _supported_fs generic
-_supported_os Linux
 
 _require_scratch
 _require_xfs_io_command "falloc"
@@ -57,10 +40,15 @@ for SUNIT_K in 8 16 32 64 128; do
        let SUNIT_BLOCKS=$SUNIT_BYTES/$BLOCKSIZE
 
        echo "=== mkfs with su $SUNIT_BLOCKS blocks x 4 ==="
-       export MKFS_OPTIONS=""
        _scratch_mkfs_geom $SUNIT_BYTES 4 $BLOCKSIZE >> $seqres.full 2>&1
        _scratch_mount
 
+       # This test checks for stripe alignments of space allocations on the
+       # filesystem.  Make sure all files get created on the main device,
+       # which for XFS means no rt files.
+       test "$FSTYP" = "xfs" && \
+               _xfs_force_bdev data $SCRATCH_MNT
+
        for SIZE_MULT in 1 2 8 64 256; do
                let SIZE=$SIZE_MULT*$SUNIT_BYTES
 
@@ -72,9 +60,9 @@ for SUNIT_K in 8 16 32 64 128; do
                        $XFS_IO_PROG -f -c "pwrite -b $SIZE 0 $SIZE" \
                                $SCRATCH_MNT/file-$FILE-$SIZE-write \
                                        >> $seqres.full 2>&1
-                       src/t_stripealign $SCRATCH_MNT/file-$FILE-$SIZE-falloc \
+                       $here/src/t_stripealign $SCRATCH_MNT/file-$FILE-$SIZE-falloc \
                                $SUNIT_BLOCKS | _filter_scratch
-                       src/t_stripealign $SCRATCH_MNT/file-$FILE-$SIZE-write \
+                       $here/src/t_stripealign $SCRATCH_MNT/file-$FILE-$SIZE-write \
                                $SUNIT_BLOCKS | _filter_scratch
                done
        done
@@ -82,7 +70,7 @@ for SUNIT_K in 8 16 32 64 128; do
        echo "=== Testing size 1g falloc on ${SUNIT_K}k stripe ==="
        $XFS_IO_PROG -f -c "falloc 0 1g" \
            $SCRATCH_MNT/file-1g-falloc >> $seqres.full 2>&1
-       src/t_stripealign $SCRATCH_MNT/file-1g-falloc $SUNIT_BLOCKS \
+       $here/src/t_stripealign $SCRATCH_MNT/file-1g-falloc $SUNIT_BLOCKS \
            | _filter_scratch
 
        rm -f $SCRATCH_MNT/file-1g-falloc | _filter_scratch
@@ -90,7 +78,7 @@ for SUNIT_K in 8 16 32 64 128; do
        echo "=== Testing size 1073745920 falloc on ${SUNIT_K}k stripe ==="
        $XFS_IO_PROG -f -c "falloc 0 1073745920" \
                $SCRATCH_MNT/file-1073745920-falloc >> $seqres.full 2>&1
-       src/t_stripealign $SCRATCH_MNT/file-1073745920-falloc \
+       $here/src/t_stripealign $SCRATCH_MNT/file-1073745920-falloc \
                $SUNIT_BLOCKS | _filter_scratch
 
        _scratch_unmount