X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre%2Ftests%2Fsanityn.sh;h=dbeba23d73aa22046ca10bb30dc2397b2bd4f421;hp=6f5236f9a09ab330aaefcc46a8ab95d4748e1b32;hb=69f76e8f1da3b3ba27853c4d98cfa82ccf09f1f9;hpb=65fe95f61b24e3103775670fca623a34ff4f92fa diff --git a/lustre/tests/sanityn.sh b/lustre/tests/sanityn.sh index 6f5236f..dbeba23d7 100644 --- a/lustre/tests/sanityn.sh +++ b/lustre/tests/sanityn.sh @@ -3,12 +3,13 @@ set -e ONLY=${ONLY:-"$*"} -# bug number for skipped test: 3192 15528/3811 16929 9977 15528/11549 18080 -ALWAYS_EXCEPT=" 14b 19 22 28 29 35 $SANITYN_EXCEPT" +# bug number for skipped test: 3192 LU-1205 15528/3811 16929 9977 15528/11549 18080 +ALWAYS_EXCEPT=" 14b 18c 19 22 28 29 35 $SANITYN_EXCEPT" # UPDATE THE COMMENT ABOVE WITH BUG NUMBERS WHEN CHANGING ALWAYS_EXCEPT! -# bug number for skipped test: 12652 12652 -grep -q 'Enterprise Server 10' /etc/SuSE-release && ALWAYS_EXCEPT="$ALWAYS_EXCEPT 11 14" || true +# bug number for skipped test: 12652 12652 +grep -q 'Enterprise Server 10' /etc/SuSE-release 2> /dev/null && + ALWAYS_EXCEPT="$ALWAYS_EXCEPT 11 14" || true # Tests that fail on uml [ "$UML" = "true" ] && EXCEPT="$EXCEPT 7" @@ -21,8 +22,6 @@ PATH=$PWD/$SRCDIR:$SRCDIR:$SRCDIR/../utils:$PATH SIZE=${SIZE:-40960} CHECKSTAT=${CHECKSTAT:-"checkstat -v"} -GETSTRIPE=${GETSTRIPE:-lfs getstripe} -SETSTRIPE=${SETSTRIPE:-lstripe} MCREATE=${MCREATE:-mcreate} OPENFILE=${OPENFILE:-openfile} OPENUNLINK=${OPENUNLINK:-openunlink} @@ -30,6 +29,7 @@ export TMP=${TMP:-/tmp} MOUNT_2=${MOUNT_2:-"yes"} CHECK_GRANT=${CHECK_GRANT:-"yes"} GRANT_CHECK_LIST=${GRANT_CHECK_LIST:-""} +TSTUSR=${TSTUSR:-"quota_usr"} SAVE_PWD=$PWD @@ -43,16 +43,13 @@ init_test_env $@ . ${CONFIG:=$LUSTRE/tests/cfg/$NAME.sh} init_logging -[ "$SLOW" = "no" ] && EXCEPT_SLOW="12 16 23 33a" +[ "$SLOW" = "no" ] && EXCEPT_SLOW="12 23 33a" -SANITYLOG=${TESTSUITELOG:-$TMP/$(basename $0 .sh).log} FAIL_ON_ERROR=false SETUP=${SETUP:-:} TRACE=${TRACE:-""} -[ "$SANITYLOG" ] && rm -f $SANITYLOG || true - check_and_setup_lustre LOVNAME=`lctl get_param -n llite.*.lov.common_name | tail -n 1` @@ -137,8 +134,9 @@ test_2e() { run_test 2e "check chmod on root is propagated to others" test_3() { - ( cd $DIR1 ; ln -s this/is/good $tfile ) - [ "this/is/good" = "`perl -e 'print readlink("'$DIR2/$tfile'");'`" ] || + local target="this/is/good" + ln -s $target $DIR1/$tfile || error "ln -s $target $DIR1/$tfile failed" + [ "$(ls -l $DIR2/$tfile | sed -e 's/.* -> //')" = "$target" ] || error "link $DIR2/$tfile not as expected" } run_test 3 "symlink on one mtpt, readlink on another ===========" @@ -241,7 +239,6 @@ test_12() { run_test 12 "test lock ordering (link, stat, unlink) ===========" test_13() { # bug 2451 - directory coherency - rm -rf $DIR1/d13 mkdir $DIR1/d13 || error cd $DIR1/d13 || error ls @@ -353,7 +350,17 @@ test_17() { # bug 3513, 3667 run_test 17 "resource creation/LVB creation race ===============" test_18() { - $LUSTRE/tests/mmap_sanity -d $MOUNT1 -m $MOUNT2 + # turn e.g. ALWAYS_EXCEPT="18c" into "-e 3" + local idx + local excepts= + for idx in {a..z}; do + local ptr=EXCEPT_ALWAYS_18$idx + [ x${!ptr} = xtrue ] || continue + + excepts="$excepts -e $(($(printf %d \'$idx)-96))" + done + + $LUSTRE/tests/mmap_sanity -d $MOUNT1 -m $MOUNT2 $excepts sync; sleep 1; sync } run_test 18 "mmap sanity check =================================" @@ -454,7 +461,7 @@ test_24a() { # OSC=`lctl dl | awk '/-osc-/ {print $4}' | head -n 1` lctl --device %$OSC deactivate lfs df -i || error "lfs df -i with deactivated OSC failed" - lctl --device %$OSC recover + lctl --device %$OSC activate lfs df || error "lfs df with reactivated OSC failed" } run_test 24a "lfs df [-ih] [path] test =========================" @@ -467,21 +474,25 @@ test_24b() { run_test 24b "lfs df should show both filesystems ===============" test_25() { - [ `lctl get_param -n mdc.*-mdc-*.connect_flags | grep -c acl` -lt 2 ] && \ - skip "must have acl, skipping" && return + [ `lctl get_param -n mdc.*-mdc-*.connect_flags | grep -c acl` -lt 2 ] && + skip "must have acl, skipping" && return mkdir -p $DIR1/$tdir touch $DIR1/$tdir/f1 || error "touch $DIR1/$tdir/f1" chmod 0755 $DIR1/$tdir/f1 || error "chmod 0755 $DIR1/$tdir/f1" $RUNAS $CHECKSTAT $DIR2/$tdir/f1 || error "checkstat $DIR2/$tdir/f1 #1" - setfacl -m u:$RUNAS_ID:--- -m g:$RUNAS_GID:--- $DIR1/$tdir || error "setfacl $DIR2/$tdir #1" + setfacl -m u:$RUNAS_ID:--- -m g:$RUNAS_GID:--- $DIR1/$tdir || + error "setfacl $DIR2/$tdir #1" $RUNAS $CHECKSTAT $DIR2/$tdir/f1 && error "checkstat $DIR2/$tdir/f1 #2" - setfacl -m u:$RUNAS_ID:r-x -m g:$RUNAS_GID:r-x $DIR1/$tdir || error "setfacl $DIR2/$tdir #2" + setfacl -m u:$RUNAS_ID:r-x -m g:$RUNAS_GID:r-x $DIR1/$tdir || + error "setfacl $DIR2/$tdir #2" $RUNAS $CHECKSTAT $DIR2/$tdir/f1 || error "checkstat $DIR2/$tdir/f1 #3" - setfacl -m u:$RUNAS_ID:--- -m g:$RUNAS_GID:--- $DIR1/$tdir || error "setfacl $DIR2/$tdir #3" + setfacl -m u:$RUNAS_ID:--- -m g:$RUNAS_GID:--- $DIR1/$tdir || + error "setfacl $DIR2/$tdir #3" $RUNAS $CHECKSTAT $DIR2/$tdir/f1 && error "checkstat $DIR2/$tdir/f1 #4" - setfacl -x u:$RUNAS_ID: -x g:$RUNAS_GID: $DIR1/$tdir || error "setfacl $DIR2/$tdir #4" + setfacl -x u:$RUNAS_ID: -x g:$RUNAS_GID: $DIR1/$tdir || + error "setfacl $DIR2/$tdir #4" $RUNAS $CHECKSTAT $DIR2/$tdir/f1 || error "checkstat $DIR2/$tdir/f1 #5" rm -rf $DIR1/$tdir @@ -533,8 +544,8 @@ test_28() { # bug 9977 ECHO_UUID="ECHO_osc1_UUID" tOST=`$LCTL dl | | awk '/-osc-|OSC.*MNT/ { print $4 }' | head -1` - lfs setstripe $DIR1/$tfile -s 1048576 -i 0 -c 2 - tOBJID=`lfs getstripe $DIR1/$tfile |grep "^[[:space:]]\+1" |awk '{print $2}'` + $LFS setstripe $DIR1/$tfile -S 1048576 -i 0 -c 2 + tOBJID=`$LFS getstripe $DIR1/$tfile | awk '$1 == 1 {print $2}'` dd if=/dev/zero of=$DIR1/$tfile bs=1024k count=2 $LCTL <<-EOF @@ -543,7 +554,7 @@ test_28() { # bug 9977 setup $tOST EOF - tECHOID=`$LCTL dl | grep $ECHO_UUID | awk '{print $1}'` + tECHOID=`$LCTL dl | grep $ECHO_UUID | awk '{ print $1 }'` $LCTL --device $tECHOID destroy "${tOBJID}:0" $LCTL <<-EOF @@ -633,7 +644,8 @@ test_32a() { # bug 11270 enable_lockless_truncate 1 rm -f $DIR1/$tfile lfs setstripe -c -1 $DIR1/$tfile - dd if=/dev/zero of=$DIR1/$tfile count=10 bs=1M > /dev/null 2>&1 + dd if=/dev/zero of=$DIR1/$tfile count=$OSTCOUNT bs=$STRIPE_BYTES > \ + /dev/null 2>&1 clear_osc_stats log "checking cached lockless truncate" @@ -713,7 +725,7 @@ print_jbd_stat () { local stat=0 for mds in ${mdts//,/ }; do varsvc=${mds}_svc - dev=$(basename $(do_facet $mds lctl get_param -n osd.${!varsvc}.mntdev)) + dev=$(basename $(do_facet $mds lctl get_param -n osd*.${!varsvc}.mntdev)) val=$(do_facet $mds "procfile=/proc/fs/jbd/$dev/info; [ -f \\\$procfile ] || procfile=/proc/fs/jbd2/$dev/info; [ -f \\\$procfile ] || procfile=/proc/fs/jbd2/${dev}\:\\\*/info; @@ -1034,6 +1046,7 @@ run_test 39c "check truncate mtime update ======================" check_pdo_conflict() { local pid=$1 local conflict=0 + sleep 1 # to ensure OP1 is finished on client if OP2 is blocked by OP1 if [[ `ps --pid $pid | wc -l` == 1 ]]; then conflict=1 echo "Conflict" @@ -1873,11 +1886,57 @@ test_50() { } run_test 50 "osc lvb attrs: enqueue vs. CP AST ==============" +test_60() { + # Create a file + mkdir -p $DIR1/$tdir + file1=$DIR1/$tdir/file + file2=$DIR2/$tdir/file + + echo orig > $file2 || error "Could not create $file2" + version=$($LFS data_version $file1) + + # Append data + echo append >> $file2 || error "Could not append to $file2" + version2=$($LFS data_version $file1) + [ "$version" != "$version2" ] || + error "append did not change data version: $version" + + # Overwrite data + echo overwrite > $file2 || error "Could not overwrite $file2" + version3=$($LFS data_version $file1) + [ "$version2" != "$version3" ] || + error "overwrite did not change data version: $version2" + + # Truncate before EOF + $TRUNCATE $file2 3 || error "Could not truncate $file2" + version4=$($LFS data_version $file1) + [ "$version3" != "$version4" ] || + error "truncate did not change data version: $version3" + + # Truncate after EOF + $TRUNCATE $file2 123456 || error "Could not truncate $file2" + version5=$($LFS data_version $file1) + [ "$version4" != "$version5" ] || + error "truncate did not change data version: $version4" + + # Chmod do not change version + chmod 400 $file2 || error "Could not chmod 400 $file2" + version6=$($LFS data_version $file1) + [ "$version5" == "$version6" ] || + error "chmod should not change data version: $version5 != $version6" + + # Chown do not change version + chown $TSTUSR $file2 || error "Could not chown $TSTUSR $file2" + version7=$($LFS data_version $file1) + [ "$version5" == "$version7" ] || + error "chown should not change data version: $version5 != $version7" +} +run_test 60 "Verify data_version behaviour" + log "cleanup: ======================================================" [ "$(mount | grep $MOUNT2)" ] && umount $MOUNT2 -check_and_cleanup_lustre -echo '=========================== finished ===============================' -[ -f "$SANITYLOG" ] && cat $SANITYLOG && grep -q FAIL $SANITYLOG && exit 1 || true -echo "$0: completed" +complete $(basename $0) $SECONDS +check_and_cleanup_lustre +exit_status