Files
apfstests/tests/generic/416
T
Darrick J. Wong a860a167d8 common: kill _supported_os
fstests only supports Linux, so get rid of this unnecessary predicate.

Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Eryu Guan <guaneryu@gmail.com>
2020-09-21 01:16:50 +08:00

84 lines
1.7 KiB
Bash
Executable File

#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2017 Fujitsu. All Rights Reserved.
#
# FS QA Test 416
#
# Test fs behavior when large write request can't be met by one single extent
#
# Inspired by a bug in a btrfs fix, which doesn't get exposed by current test
# cases
#
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 -f $tmp.*
}
# get standard environment, filters and checks
. ./common/rc
. ./common/filter
# remove previous $seqres.full before test
rm -f $seqres.full
# real QA test starts here
# Modify as appropriate.
_supported_fs generic
_require_scratch
fs_size=$((128 * 1024 * 1024))
page_size=$(get_page_size)
# We will never reach this number though
nr_files=$(($fs_size / $page_size))
# Use small fs to make the fill more faster
_scratch_mkfs_sized $fs_size >> $seqres.full 2>&1
_scratch_mount
fill_fs()
{
dir=$1
for i in $(seq -w $nr_files); do
# xfs_io can't return correct value when it hit ENOSPC, use
# dd here to detect ENOSPC
dd if=/dev/zero of=$SCRATCH_MNT/$i bs=$page_size count=1 \
&> /dev/null
if [ $? -ne 0 ]; then
break
fi
done
}
fill_fs $SCRATCH_MNT
# remount to sync every thing into fs, and drop all cache
_scratch_remount
# remove all files with odd file names, which should free near half
# of the space
rm $SCRATCH_MNT/*[13579]
sync
# We should be able to write at least 1/8 of the whole fs size
# The number 1/8 is for btrfs, which only has about 47M for data.
# And half of the 47M is already taken up, so only 1/8 is safe here
$XFS_IO_PROG -f -c "pwrite 0 $(($fs_size / 8))" $SCRATCH_MNT/large_file | \
_filter_xfs_io
# success, all done
status=0
exit