2015-11-17 08:40:08 +11:00
|
|
|
#! /bin/bash
|
2018-06-09 11:35:42 +10:00
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
# Copyright (c) 2015, Oracle and/or its affiliates. All Rights Reserved.
|
|
|
|
|
#
|
2015-11-17 08:40:08 +11:00
|
|
|
# FS QA Test No. 172
|
|
|
|
|
#
|
|
|
|
|
# Reflink a file that uses more than half of the space, then try to observe
|
|
|
|
|
# ENOSPC while copy-on-writing the file via the page cache.
|
|
|
|
|
#
|
2016-02-10 00:33:10 -08:00
|
|
|
seq=`basename $0`
|
|
|
|
|
seqres=$RESULT_DIR/$seq
|
2015-11-17 08:40:08 +11:00
|
|
|
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 /
|
2016-02-10 00:33:10 -08:00
|
|
|
rm -rf $tmp.* $testdir1
|
2015-11-17 08:40:08 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# get standard environment, filters and checks
|
|
|
|
|
. ./common/rc
|
2016-11-02 12:07:27 +08:00
|
|
|
. ./common/populate
|
2015-11-17 08:40:08 +11:00
|
|
|
. ./common/filter
|
|
|
|
|
. ./common/attr
|
|
|
|
|
. ./common/reflink
|
|
|
|
|
|
|
|
|
|
# real QA test starts here
|
|
|
|
|
_supported_os Linux
|
|
|
|
|
_require_scratch_reflink
|
|
|
|
|
_require_cp_reflink
|
|
|
|
|
|
2016-02-10 00:33:10 -08:00
|
|
|
rm -f $seqres.full
|
2015-11-17 08:40:08 +11:00
|
|
|
|
|
|
|
|
echo "Format and mount"
|
2016-02-10 00:33:10 -08:00
|
|
|
_scratch_mkfs > $seqres.full 2>&1
|
|
|
|
|
_scratch_mount >> $seqres.full 2>&1
|
2015-11-17 08:40:08 +11:00
|
|
|
|
2016-02-10 00:33:10 -08:00
|
|
|
testdir=$SCRATCH_MNT/test-$seq
|
|
|
|
|
mkdir $testdir
|
2015-11-17 08:40:08 +11:00
|
|
|
|
|
|
|
|
echo "Reformat with appropriate size"
|
2017-01-04 17:04:48 -08:00
|
|
|
blksz="$(_get_block_size $testdir)"
|
2016-02-10 00:33:10 -08:00
|
|
|
umount $SCRATCH_MNT
|
2016-08-31 19:50:55 +08:00
|
|
|
|
|
|
|
|
file_size=$((168 * 1024 * 1024))
|
|
|
|
|
fs_size=$((256 * 1024 * 1024))
|
|
|
|
|
_scratch_mkfs_sized $fs_size >> $seqres.full 2>&1
|
2016-02-10 00:33:10 -08:00
|
|
|
_scratch_mount >> $seqres.full 2>&1
|
|
|
|
|
rm -rf $testdir
|
|
|
|
|
mkdir $testdir
|
2015-11-17 08:40:08 +11:00
|
|
|
|
|
|
|
|
echo "Create a big file and reflink it"
|
2016-08-31 19:50:55 +08:00
|
|
|
_pwrite_byte 0x61 0 $file_size $testdir/bigfile >> $seqres.full 2>&1
|
2016-02-10 00:33:10 -08:00
|
|
|
_cp_reflink $testdir/bigfile $testdir/clonefile
|
2015-11-17 08:40:08 +11:00
|
|
|
sync
|
|
|
|
|
|
|
|
|
|
echo "Allocate the rest of the space"
|
2016-11-02 12:07:27 +08:00
|
|
|
_fill_fs $fs_size $testdir/space $blksz 0 >> $seqres.full 2>&1
|
2015-11-17 08:40:08 +11:00
|
|
|
sync
|
|
|
|
|
|
|
|
|
|
echo "CoW the big file"
|
2016-11-03 08:15:25 +11:00
|
|
|
out="$(_pwrite_byte 0x62 0 $file_size $testdir/bigfile 2>&1 | \
|
|
|
|
|
_filter_xfs_io_error)"
|
2016-02-10 00:33:10 -08:00
|
|
|
echo ${out} | grep -q "No space left on device" || echo "CoW should have failed with ENOSPC"
|
|
|
|
|
echo ${out} >> $seqres.full 2>&1
|
|
|
|
|
echo ${out}
|
2015-11-17 08:40:08 +11:00
|
|
|
|
|
|
|
|
echo "Remount and try CoW again"
|
2016-02-19 10:44:53 +11:00
|
|
|
_scratch_cycle_mount
|
2015-11-17 08:40:08 +11:00
|
|
|
|
2016-11-03 08:15:25 +11:00
|
|
|
out="$(_pwrite_byte 0x62 0 $file_size $testdir/bigfile 2>&1 | \
|
|
|
|
|
_filter_xfs_io_error)"
|
2016-02-10 00:33:10 -08:00
|
|
|
echo ${out} | grep -q "No space left on device" || echo "CoW should have failed with ENOSPC"
|
|
|
|
|
echo ${out} >> $seqres.full 2>&1
|
|
|
|
|
echo ${out}
|
2015-11-17 08:40:08 +11:00
|
|
|
|
|
|
|
|
# success, all done
|
|
|
|
|
status=0
|
|
|
|
|
exit
|