mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
aa31b54565
There is already logic in 075 to gracefully skip nfs for fsx invocations with -x (xfs-specific preallocation) - just extend this to any non-xfs filesystem, and add to test 112 as well. Later we can change this behavior to use fallocate and include more filesystems but this gets some fsx coverage for now. Test 127 doesn't seem to have anything xfs-specific, so mark that as generic too. Signed-off-by: Eric Sandeen <sandeen@redhat.com> Reviewed-by: Christoph Hellwig <hch@lst.de>
126 lines
2.9 KiB
Bash
Executable File
126 lines
2.9 KiB
Bash
Executable File
#! /bin/sh
|
|
# FSQA Test No. 127
|
|
#
|
|
# fsx tests modified from CXFSQA tests
|
|
# - fsx_00_lite
|
|
# - fsx_05_lite_mmap
|
|
# - fsx_10_std,
|
|
# - fsx_15_std_mmap
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
# Copyright (c) 2006 Silicon Graphics, Inc. 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
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
#
|
|
# creator
|
|
owner=allanr@sgi.com
|
|
|
|
seq=`basename $0`
|
|
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()
|
|
{
|
|
_cleanup_testdir
|
|
}
|
|
|
|
# get standard environment, filters and checks
|
|
. ./common.rc
|
|
. ./common.filter
|
|
|
|
FSX_FILE_SIZE=262144
|
|
FSX_ARGS="-q -l $FSX_FILE_SIZE -o 65536 -S 191110531 -N 100000"
|
|
|
|
_fsx_lite_nommap()
|
|
{
|
|
echo "=== FSX Light Mode, No Memory Mapping ==="
|
|
dd if=/dev/zero of=$testdir/fsx_lite_nommap bs=${FSX_FILE_SIZE} count=1 > /dev/null 2>&1
|
|
if ! ltp/fsx $FSX_ARGS -L -R -W $testdir/fsx_lite_nommap > $tmp.output 2>&1
|
|
then
|
|
echo "ltp/fsx $FSX_ARGS -L -R -W $testdir/fsx_lite_nommap"
|
|
cat $tmp.output
|
|
return 1
|
|
fi
|
|
cat $tmp.output
|
|
return 0
|
|
}
|
|
|
|
_fsx_lite_mmap()
|
|
{
|
|
echo "=== FSX Light Mode, Memory Mapping ==="
|
|
dd if=/dev/zero of=$testdir/fsx_lite_mmap bs=${FSX_FILE_SIZE} count=1 > /dev/null 2>&1
|
|
if ! ltp/fsx $FSX_ARGS -L $testdir/fsx_lite_mmap > $tmp.output 2>&1
|
|
then
|
|
echo "ltp/fsx $FSX_ARGS -L fsx_lite_mmap"
|
|
cat $tmp.output
|
|
return 1
|
|
fi
|
|
cat $tmp.output
|
|
return 0
|
|
}
|
|
|
|
_fsx_std_nommap()
|
|
{
|
|
echo "=== FSX Standard Mode, No Memory Mapping ==="
|
|
if ! ltp/fsx $FSX_ARGS -R -W $testdir/fsx_std_nommap > $tmp.output 2>&1
|
|
then
|
|
echo "ltp/fsx $FSX_ARGS -R -W fsx_std_nommap"
|
|
cat $tmp.output
|
|
return 1
|
|
fi
|
|
cat $tmp.output
|
|
return 0
|
|
}
|
|
|
|
_fsx_std_mmap()
|
|
{
|
|
echo "=== FSX Standard Mode, Memory Mapping ==="
|
|
if ! ltp/fsx $FSX_ARGS $testdir/fsx_std_mmap > $tmp.output 2>&1
|
|
then
|
|
echo "ltp/fsx $FSX_ARGS fsx_std_mmap"
|
|
cat $tmp.output
|
|
return 1
|
|
fi
|
|
cat $tmp.output
|
|
return 0
|
|
}
|
|
|
|
# real QA test starts here
|
|
_supported_fs generic
|
|
_supported_os Linux
|
|
|
|
_setup_testdir
|
|
|
|
_fsx_lite_nommap
|
|
_fsx_lite_mmap
|
|
|
|
_fsx_std_nommap
|
|
_fsx_std_mmap
|
|
|
|
#flush cache after write
|
|
FSX_ARGS="-f $FSX_ARGS"
|
|
_fsx_std_nommap
|
|
_fsx_std_mmap
|
|
|
|
|
|
status=0
|
|
_cleanup
|
|
exit
|