mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
c041421687
For historical reasons beyond my knowledge xfstests tries to abuse the scratch device as test device for nfs and udf. Because not all test have inherited the right usage of the _setup_testdir and _cleanup_testdir helpers this leads to lots of unessecary test failures. Remove the special casing, which gets nfs down to a minimal number of failures. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Eric Sandeen <sandeen@redhat.com> Sugned-off-by: Dave Chinner <david@fromorbit.com>
110 lines
3.4 KiB
Bash
Executable File
110 lines
3.4 KiB
Bash
Executable File
#! /bin/bash
|
|
# FSQA Test No. 168
|
|
#
|
|
# Check for DMAPI destroy events when removing files without attributes
|
|
# See PV960928 for details
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
# Copyright (c) 2007 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
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
#
|
|
|
|
seq=`basename $0`
|
|
seqres=$RESULT_DIR/$seq
|
|
echo "QA output created by $seq"
|
|
|
|
here=`pwd`
|
|
tmp=/tmp/$$
|
|
rm -f $seqres.full
|
|
status=1 # failure is the default!
|
|
trap "exit \$status" 0 1 2 3 15
|
|
|
|
_filter_dmapi_print_event() {
|
|
$PERL_PROG -ne '
|
|
# replace session/file specific output with generic placeholders
|
|
s/token\s+\d+/token TOKEN/g ;
|
|
s/sequence\s+\d+/sequence SEQ/g ;
|
|
s/^\s+parent\s+dir\s+\w+/parent dir PARENT_DIR/g ;
|
|
s/^\s+name\s+.*/name FILE_NAME/g ;
|
|
s/^\s+mode\s+bits\s+mode\s+\d+:\s+/mode bits mode MODE: /g ;
|
|
s/perm\s+[\w|-]+\s[\w|-]+\s[\w|-]+/perm PERMISSIONS/g ;
|
|
s/,\s+type\s+.*/, type FILE_TYPE/g ;
|
|
s/^\s+object\s+\w+/object OBJECT/g ;
|
|
s/^\s+new\s+object\s+\w+/new object OBJECT/g ;
|
|
s/^\s+handle\s+\w+/handle HANDLE/g ;
|
|
|
|
# when print_event is killed, the following is output. trim it
|
|
s/^\s*print_event: Processing any undelivered event messages.*\n//g ;
|
|
s/^\s*print_event: Shutting down the session.*\n//g ;
|
|
|
|
# trim blank lines
|
|
s/^\s*\n//g ;
|
|
print ;'
|
|
}
|
|
|
|
# get standard environment, filters and checks
|
|
. ./common/rc
|
|
. ./common/filter
|
|
. ./common/dmapi
|
|
|
|
# real QA test starts here
|
|
_supported_fs xfs
|
|
_supported_os Linux
|
|
|
|
_require_scratch
|
|
_scratch_mkfs_xfs >/dev/null 2>&1
|
|
_dmapi_scratch_mount
|
|
|
|
qa_file_noattr=$SCRATCH_MNT/dmapi_file_noattr
|
|
qa_file_withattr=$SCRATCH_MNT/dmapi_file_withattr
|
|
|
|
# run dmapi print_event in background to capture events triggered during test
|
|
${DMAPI_QASUITE1_DIR}cmd/print_event $SCRATCH_MNT > $tmp.print_event_out 2>&1 &
|
|
dmapi_print_event_pid=$!
|
|
|
|
# give time for print_event to start capturing events
|
|
sleep 2
|
|
|
|
# enable DMAPI set_return_on_destroy for $SCRATCH_MNT
|
|
${DMAPI_COMMON_DIR}cmd/set_return_on_destroy -F $SCRATCH_MNT ATTR_NAME_1
|
|
|
|
echo "# create file"
|
|
touch $qa_file_noattr
|
|
echo "# remove file"
|
|
rm -f $qa_file_noattr
|
|
|
|
echo "# create file"
|
|
touch $qa_file_withattr
|
|
echo "# set dmapi attributes on file"
|
|
${DMAPI_QASUITE1_DIR}cmd/set_dmattr $qa_file_withattr ATTR_NAME_1 ATTR_VALUE_1
|
|
echo "# remove file"
|
|
rm -f $qa_file_withattr
|
|
|
|
# kill off background dmapi print_event process
|
|
kill $dmapi_print_event_pid
|
|
# give dmapi print_event time to finish writing out any events not yet output
|
|
wait
|
|
|
|
# dmapi destroy events are asyncronous, don't rely on fixed ordering of events
|
|
# in print_event output, use sort.
|
|
echo "# here comes the dmapi print_event filtered and sorted output"
|
|
cat $tmp.print_event_out | tee -a $seqres.full | _filter_dmapi_print_event | LC_COLLATE=POSIX sort
|
|
rm $tmp.print_event_out
|
|
|
|
status=0
|
|
exit
|