Files
apfstests/tests/generic/245
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

56 lines
1.1 KiB
Bash
Executable File

#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2010 Christoph Hellwig. All Rights Reserved.
#
# FS QA Test No. 245
#
# Check that directory renames onto non-empty targets fail
#
# Based on a bug report and testcase from Vlado Plaga <rechner@vlado-do.de>
#
seq=`basename $0`
seqres=$RESULT_DIR/$seq
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
# get standard environment, filters and checks
. ./common/rc
. ./common/filter
# real QA test starts here
_supported_fs generic
_require_test
dir=$TEST_DIR/test-mv
_cleanup()
{
rm -rf $dir
}
# According to the rename(2) manpage you can get either EEXIST or ENOTEMPTY as an
# error for trying to rename a non-empty directory, so just catch the error for
# ENOTMEMPTY and replace it with the EEXIST output so that either result passes
_filter_directory_not_empty()
{
sed -e "s,Directory not empty,File exists,g"
}
trap "_cleanup ; exit \$status" 0 1 2 3 15
mkdir $dir
mkdir $dir/aa
mkdir $dir/ab
touch $dir/aa/1
mkdir $dir/ab/aa
touch $dir/ab/aa/2
mv $dir/ab/aa/ $dir 2>&1 | _filter_test_dir | _filter_directory_not_empty
status=0
exit $status