[BACK]Return to 135 CVS log [TXT][DIR] Up to [Development] / xfs-cmds / xfstests

File: [Development] / xfs-cmds / xfstests / 135 (download)

Revision 1.2, Mon Oct 16 15:46:05 2006 UTC (11 years ago) by ddiss.longdrop.melbourne.sgi.com
Branch: MAIN
Changes since 1.1: +10 -1 lines

run test on scratch dir
remove failure case for when scratch is not mounted before test
Merge of master-melb:xfs-cmds:27201a by kenmcd.

#! /bin/sh
# FSQA Test No. 133
#
# Concurrent I/O to same file to ensure no deadlocks
#
#-----------------------------------------------------------------------
#  Copyright (c) 2006 Silicon Graphics, Inc.  All Rights Reserved.
#-----------------------------------------------------------------------
#
# creator
owner=lachlan@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

# real QA test starts here
_supported_fs xfs
_supported_os Linux IRIX

_setup_testdir
_require_scratch
_scratch_mkfs_xfs >/dev/null 2>&1

_umount_mount()
{
    CWD=`pwd`
    cd /
    # pipe error into /dev/null, in case not mounted (after _require_scratch)
    umount $SCRATCH_MNT 2>/dev/null
    _scratch_mount
    cd "$CWD"
}



_umount_mount

cd $SCRATCH_MNT

# create file with async I/O
xfs_io -f -c 'pwrite -b 4k -S 0x12 0 4k' async_file > /dev/null

# create file with sync I/O
xfs_io -f -s -c 'pwrite -b 4k -S 0x34 0 4k' sync_file > /dev/null

# create file with sync I/O
xfs_io -f -d -c 'pwrite -b 4k -S 0x56 0 4k' direct_file > /dev/null

_umount_mount

# check file size and contents
od -Ad -x async_file
od -Ad -x sync_file
od -Ad -x direct_file

rm -f async_file sync_file direct_file

status=0
exit