X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre%2Ftests%2Fsanity.sh;h=11c521bcec72bc5073889b74940579917f08580a;hp=3f8badb51da6853c5d284ea7ab62d482b709c2ee;hb=8af655855c79ecafea9918a54082d512b63b11f2;hpb=aed82035c0d194347f5cab17ebd48f355c379b1b diff --git a/lustre/tests/sanity.sh b/lustre/tests/sanity.sh index 3f8badb..11c521b 100644 --- a/lustre/tests/sanity.sh +++ b/lustre/tests/sanity.sh @@ -1114,6 +1114,21 @@ test_24z() { } run_test 24z "rename one remote dir to another remote dir should fail" +test_24A() { # LU-3182 + local NFILES=5000 + + mkdir -p $DIR/$tdir + createmany -m $DIR/$tdir/$tfile $NFILES + local t=`ls $DIR/$tdir | wc -l` + local u=`ls $DIR/$tdir | sort -u | wc -l` + if [ $t -ne $NFILES -o $u -ne $NFILES ] ; then + error "Expected $NFILES files, got $t ($u unique)" + fi + + rm -rf $DIR/$tdir || error "Can not delete directories" +} +run_test 24A "readdir() returns correct number of entries." + test_25a() { echo '== symlink sanity =============================================' @@ -1171,7 +1186,7 @@ test_26f() { test_mkdir -p $DIR/$tdir test_mkdir $DIR/$tdir/$tfile || error "mkdir $DIR/$tdir/$tfile failed" cd $DIR/$tdir/$tfile || error "cd $DIR/$tdir/$tfile failed" - test_mkdir -p lndir bar1 || error "mkdir lndir/bar1 failed" + test_mkdir -p lndir/bar1 || error "mkdir lndir/bar1 failed" test_mkdir $DIR/$tdir/$tfile/$tfile || error "mkdir $tfile failed" cd $tfile || error "cd $tfile failed" ln -s .. dotdot || error "ln dotdot failed" @@ -2111,6 +2126,29 @@ test_31n() { } run_test 31n "check link count of unlinked file" +link_one() { + local TEMPNAME=$(mktemp $1_XXXXXX) + mlink $TEMPNAME $1 2> /dev/null && + echo "$BASHPID: link $TEMPNAME to $1 succeeded" + munlink $TEMPNAME +} + +test_31o() { # LU-2901 + mkdir -p $DIR/$tdir + for LOOP in $(seq 100); do + rm -f $DIR/$tdir/$tfile* + for THREAD in $(seq 8); do + link_one $DIR/$tdir/$tfile.$LOOP & + done + wait + local LINKS=$(ls -1 $DIR/$tdir | grep -c $tfile.$LOOP) + [ $LINKS -gt 1 ] && ls $DIR/$tdir && + error "$LINKS duplicate links to $tfile.$LOOP" && + break || true + done +} +run_test 31o "duplicate hard links with same filename" + cleanup_test32_mount() { trap 0 $UMOUNT $DIR/$tdir/ext2-mountpoint @@ -3314,13 +3352,13 @@ test_43a() { test_mkdir -p $DIR/$tdir cp -p `which $MULTIOP` $DIR/$tdir/multiop || cp -p multiop $DIR/$tdir/multiop - MULTIOP_PROG=$DIR/$tdir/multiop multiop_bg_pause $TMP/test43.junk O_c || + MULTIOP_PROG=$DIR/$tdir/multiop multiop_bg_pause $TMP/$tfile.junk O_c || return 1 MULTIOP_PID=$! $MULTIOP $DIR/$tdir/multiop Oc && error "expected error, got success" kill -USR1 $MULTIOP_PID || return 2 wait $MULTIOP_PID || return 3 - rm $TMP/test43.junk + rm $TMP/$tfile.junk $DIR/$tdir/multiop } run_test 43a "open(RDWR) of file being executed should return -ETXTBSY" @@ -3329,13 +3367,13 @@ test_43b() { test_mkdir -p $DIR/$tdir cp -p `which $MULTIOP` $DIR/$tdir/multiop || cp -p multiop $DIR/$tdir/multiop - MULTIOP_PROG=$DIR/$tdir/multiop multiop_bg_pause $TMP/test43.junk O_c || + MULTIOP_PROG=$DIR/$tdir/multiop multiop_bg_pause $TMP/$tfile.junk O_c || return 1 MULTIOP_PID=$! $TRUNCATE $DIR/$tdir/multiop 0 && error "expected error, got success" kill -USR1 $MULTIOP_PID || return 2 wait $MULTIOP_PID || return 3 - rm $TMP/test43.junk + rm $TMP/$tfile.junk $DIR/$tdir/multiop } run_test 43b "truncate of file being executed should return -ETXTBSY" @@ -4586,7 +4624,8 @@ TEST60_HEAD="test_60 run $RANDOM" test_60a() { [ $PARALLEL == "yes" ] && skip "skip parallel run" && return remote_mgs_nodsh && skip "remote MGS with nodsh" && return - [ ! -f run-llog.sh ] && skip_env "missing subtest run-llog.sh" && return + do_facet mgs "! which run-llog.sh &> /dev/null" && + skip_env "missing subtest run-llog.sh" && return log "$TEST60_HEAD - from kernel mode" do_facet mgs sh run-llog.sh } @@ -7166,7 +7205,8 @@ test_120c() { skip "no early lock cancel on server" && return 0 lru_resize_disable mdc lru_resize_disable osc - test_mkdir -p $DIR/$tdir/d1 $DIR/$tdir/d2 + test_mkdir -p $DIR/$tdir/d1 + test_mkdir -p $DIR/$tdir/d2 touch $DIR/$tdir/d1/f1 cancel_lru_locks mdc stat $DIR/$tdir/d1 $DIR/$tdir/d2 $DIR/$tdir/d1/f1 > /dev/null @@ -7239,7 +7279,8 @@ test_120f() { test_mkdir -p $DIR/$tdir lru_resize_disable mdc lru_resize_disable osc - test_mkdir -p $DIR/$tdir/d1 $DIR/$tdir/d2 + test_mkdir -p $DIR/$tdir/d1 + test_mkdir -p $DIR/$tdir/d2 dd if=/dev/zero of=$DIR/$tdir/d1/f1 count=1 dd if=/dev/zero of=$DIR/$tdir/d2/f2 count=1 cancel_lru_locks mdc @@ -8774,20 +8815,23 @@ dot_lustre_fid_permission_check() { mrename $test_dir/$tdir $MOUNT/.lustre/fid && error "rename to $MOUNT/.lustre/fid should fail." - local old_obf_mode=$(stat --format="%a" $DIR/.lustre/fid) - local new_obf_mode=777 + if [ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.3.51) ] + then # LU-3547 + local old_obf_mode=$(stat --format="%a" $DIR/.lustre/fid) + local new_obf_mode=777 - echo "change mode of $DIR/.lustre/fid to $new_obf_mode" - chmod $new_obf_mode $DIR/.lustre/fid || - error "chmod $new_obf_mode $DIR/.lustre/fid failed" + echo "change mode of $DIR/.lustre/fid to $new_obf_mode" + chmod $new_obf_mode $DIR/.lustre/fid || + error "chmod $new_obf_mode $DIR/.lustre/fid failed" - local obf_mode=$(stat --format=%a $DIR/.lustre/fid) - [ $obf_mode -eq $new_obf_mode ] || - error "stat $DIR/.lustre/fid returned wrong mode $obf_mode" + local obf_mode=$(stat --format=%a $DIR/.lustre/fid) + [ $obf_mode -eq $new_obf_mode ] || + error "stat $DIR/.lustre/fid returned wrong mode $obf_mode" - echo "restore mode of $DIR/.lustre/fid to $old_obf_mode" - chmod $old_obf_mode $DIR/.lustre/fid || - error "chmod $old_obf_mode $DIR/.lustre/fid failed" + echo "restore mode of $DIR/.lustre/fid to $old_obf_mode" + chmod $old_obf_mode $DIR/.lustre/fid || + error "chmod $old_obf_mode $DIR/.lustre/fid failed" + fi $OPENFILE -f O_LOV_DELAY_CREATE:O_CREAT $test_dir/$tfile-2 fid=$($LFS path2fid $test_dir/$tfile-2) @@ -9123,113 +9167,121 @@ run_test 156 "Verification of tunables ============================" #Changelogs err17935 () { - if [ $MDSCOUNT -gt 1 ]; then - error_ignore 17935 $* - else - error $* - fi + if [ $MDSCOUNT -gt 1 ]; then + error_ignore 17935 $* + else + error $* + fi } changelog_chmask() { - MASK=$(do_facet $SINGLEMDS $LCTL get_param mdd.$MDT0.changelog_mask |\ - grep -c $1) + local CL_MASK_PARAM="mdd.$MDT0.changelog_mask" - if [ $MASK -eq 1 ]; then - do_facet $SINGLEMDS $LCTL set_param mdd.$MDT0.changelog_mask="-$1" - else - do_facet $SINGLEMDS $LCTL set_param mdd.$MDT0.changelog_mask="+$1" - fi + MASK=$(do_facet $SINGLEMDS $LCTL get_param $CL_MASK_PARAM| grep -c "$1") + + if [ $MASK -eq 1 ]; then + do_facet $SINGLEMDS $LCTL set_param $CL_MASK_PARAM="-$1" + else + do_facet $SINGLEMDS $LCTL set_param $CL_MASK_PARAM="+$1" + fi } test_160() { [ $PARALLEL == "yes" ] && skip "skip parallel run" && return - remote_mds_nodsh && skip "remote MDS with nodsh" && return - [ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.2.0) ] || - { skip "Need MDS version at least 2.2.0"; return; } - USER=$(do_facet $SINGLEMDS $LCTL --device $MDT0 changelog_register -n) - echo "Registered as changelog user $USER" - do_facet $SINGLEMDS $LCTL get_param -n mdd.$MDT0.changelog_users | \ - grep -q $USER || error "User $USER not found in changelog_users" - - # change something - test_mkdir -p $DIR/$tdir/pics/2008/zachy - touch $DIR/$tdir/pics/2008/zachy/timestamp - cp /etc/hosts $DIR/$tdir/pics/2008/zachy/pic1.jpg - mv $DIR/$tdir/pics/2008/zachy $DIR/$tdir/pics/zach - ln $DIR/$tdir/pics/zach/pic1.jpg $DIR/$tdir/pics/2008/portland.jpg - ln -s $DIR/$tdir/pics/2008/portland.jpg $DIR/$tdir/pics/desktop.jpg - rm $DIR/$tdir/pics/desktop.jpg - - $LFS changelog $MDT0 | tail -5 - - echo "verifying changelog mask" - changelog_chmask "MKDIR" - changelog_chmask "CLOSE" - - test_mkdir -p $DIR/$tdir/pics/zach/sofia - echo "zzzzzz" > $DIR/$tdir/pics/zach/file - - changelog_chmask "MKDIR" - changelog_chmask "CLOSE" - - test_mkdir -p $DIR/$tdir/pics/2008/sofia - echo "zzzzzz" > $DIR/$tdir/pics/zach/file - - $LFS changelog $MDT0 - MKDIRS=$($LFS changelog $MDT0 | tail -5 | grep -c "MKDIR") - CLOSES=$($LFS changelog $MDT0 | tail -5 | grep -c "CLOSE") - [ $MKDIRS -eq 1 ] || err17935 "MKDIR changelog mask count $DIRS != 1" - [ $CLOSES -eq 1 ] || err17935 "CLOSE changelog mask count $DIRS != 1" - - # verify contents - echo "verifying target fid" - fidc=$($LFS changelog $MDT0 | grep timestamp | grep "CREAT" | \ - tail -1 | awk '{print $6}') - fidf=$($LFS path2fid $DIR/$tdir/pics/zach/timestamp) - [ "$fidc" == "t=$fidf" ] || \ - err17935 "fid in changelog $fidc != file fid $fidf" - echo "verifying parent fid" - fidc=$($LFS changelog $MDT0 | grep timestamp | grep "CREAT" | \ - tail -1 | awk '{print $7}') - fidf=$($LFS path2fid $DIR/$tdir/pics/zach) - [ "$fidc" == "p=$fidf" ] || \ - err17935 "pfid in changelog $fidc != dir fid $fidf" - - USER_REC1=$(do_facet $SINGLEMDS $LCTL get_param -n \ - mdd.$MDT0.changelog_users | grep $USER | awk '{print $2}') - $LFS changelog_clear $MDT0 $USER $(($USER_REC1 + 5)) - USER_REC2=$(do_facet $SINGLEMDS $LCTL get_param -n \ - mdd.$MDT0.changelog_users | grep $USER | awk '{print $2}') - echo "verifying user clear: $(( $USER_REC1 + 5 )) == $USER_REC2" - [ $USER_REC2 == $(($USER_REC1 + 5)) ] || \ - err17935 "user index should be $(($USER_REC1 + 5)); is $USER_REC2" - - MIN_REC=$(do_facet $SINGLEMDS $LCTL get_param mdd.$MDT0.changelog_users | \ - awk 'min == "" || $2 < min {min = $2}; END {print min}') - FIRST_REC=$($LFS changelog $MDT0 | head -1 | awk '{print $1}') - echo "verifying min purge: $(( $MIN_REC + 1 )) == $FIRST_REC" - [ $FIRST_REC == $(($MIN_REC + 1)) ] || \ - err17935 "first index should be $(($MIN_REC + 1)); is $FIRST_REC" - - echo "verifying user deregister" - do_facet $SINGLEMDS $LCTL --device $MDT0 changelog_deregister $USER - do_facet $SINGLEMDS $LCTL get_param -n mdd.$MDT0.changelog_users | \ - grep -q $USER && error "User $USER still found in changelog_users" - - USERS=$(( $(do_facet $SINGLEMDS $LCTL get_param -n \ - mdd.$MDT0.changelog_users | wc -l) - 2 )) - if [ $USERS -eq 0 ]; then - LAST_REC1=$(do_facet $SINGLEMDS $LCTL get_param -n \ - mdd.$MDT0.changelog_users | head -1 | awk '{print $3}') - touch $DIR/$tdir/chloe - LAST_REC2=$(do_facet $SINGLEMDS $LCTL get_param -n \ - mdd.$MDT0.changelog_users | head -1 | awk '{print $3}') - echo "verify changelogs are off if we were the only user: $LAST_REC1 == $LAST_REC2" - [ $LAST_REC1 == $LAST_REC2 ] || error "changelogs not off" - else - echo "$USERS other changelog users; can't verify off" - fi + remote_mds_nodsh && skip "remote MDS with nodsh" && return + [ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.2.0) ] || + { skip "Need MDS version at least 2.2.0"; return; } + + local CL_USERS="mdd.$MDT0.changelog_users" + local GET_CL_USERS="do_facet $SINGLEMDS $LCTL get_param -n $CL_USERS" + USER=$(do_facet $SINGLEMDS $LCTL --device $MDT0 changelog_register -n) + echo "Registered as changelog user $USER" + $GET_CL_USERS | grep -q $USER || + error "User $USER not found in changelog_users" + + # change something + test_mkdir -p $DIR/$tdir/pics/2008/zachy + touch $DIR/$tdir/pics/2008/zachy/timestamp + cp /etc/hosts $DIR/$tdir/pics/2008/zachy/pic1.jpg + mv $DIR/$tdir/pics/2008/zachy $DIR/$tdir/pics/zach + ln $DIR/$tdir/pics/zach/pic1.jpg $DIR/$tdir/pics/2008/portland.jpg + ln -s $DIR/$tdir/pics/2008/portland.jpg $DIR/$tdir/pics/desktop.jpg + rm $DIR/$tdir/pics/desktop.jpg + + $LFS changelog $MDT0 | tail -5 + + echo "verifying changelog mask" + changelog_chmask "MKDIR" + changelog_chmask "CLOSE" + + test_mkdir -p $DIR/$tdir/pics/zach/sofia + echo "zzzzzz" > $DIR/$tdir/pics/zach/file + + changelog_chmask "MKDIR" + changelog_chmask "CLOSE" + + test_mkdir -p $DIR/$tdir/pics/2008/sofia + echo "zzzzzz" > $DIR/$tdir/pics/zach/file + + $LFS changelog $MDT0 + MKDIRS=$($LFS changelog $MDT0 | tail -5 | grep -c "MKDIR") + CLOSES=$($LFS changelog $MDT0 | tail -5 | grep -c "CLOSE") + [ $MKDIRS -eq 1 ] || err17935 "MKDIR changelog mask count $DIRS != 1" + [ $CLOSES -eq 1 ] || err17935 "CLOSE changelog mask count $DIRS != 1" + + # verify contents + echo "verifying target fid" + fidc=$($LFS changelog $MDT0|awk '/CREAT.*timestamp$/{print $6}'|tail -1) + fidf=$($LFS path2fid $DIR/$tdir/pics/zach/timestamp) + [ "$fidc" == "t=$fidf" ] || + err17935 "fid in changelog $fidc != file fid $fidf" + echo "verifying parent fid" + fidc=$($LFS changelog $MDT0|awk '/CREAT.*timestamp$/{print $7}'|tail -1) + fidf=$($LFS path2fid $DIR/$tdir/pics/zach) + [ "$fidc" == "p=$fidf" ] || + err17935 "pfid in changelog $fidc != dir fid $fidf" + + USER_REC1=$($GET_CL_USERS | awk "\$1 == \"$USER\" {print \$2}") + $LFS changelog_clear $MDT0 $USER $(($USER_REC1 + 5)) + USER_REC2=$($GET_CL_USERS | awk "\$1 == \"$USER\" {print \$2}") + echo "verifying user clear: $(( $USER_REC1 + 5 )) == $USER_REC2" + [ $USER_REC2 == $(($USER_REC1 + 5)) ] || + err17935 "user index expected $(($USER_REC1 + 5)) is $USER_REC2" + + MIN_REC=$($GET_CL_USERS | + awk 'min == "" || $2 < min {min = $2}; END {print min}') + FIRST_REC=$($LFS changelog $MDT0 | head -1 | awk '{print $1}') + echo "verifying min purge: $(( $MIN_REC + 1 )) == $FIRST_REC" + [ $FIRST_REC == $(($MIN_REC + 1)) ] || + err17935 "first index should be $(($MIN_REC + 1)) is $FIRST_REC" + + # LU-3446 changelog index reset on MDT restart + local MDT_DEV=$(mdsdevname ${SINGLEMDS//mds/}) + CUR_REC1=$($GET_CL_USERS | head -1 | cut -f3 -d' ') + $LFS changelog_clear $MDT0 $USER 0 + stop $SINGLEMDS || error "Fail to stop MDT." + start $SINGLEMDS $MDT_DEV $MDS_MOUNT_OPTS || error "Fail to start MDT." + CUR_REC2=$($GET_CL_USERS | head -1 | cut -f3 -d' ') + echo "verifying index survives MDT restart: $CUR_REC1 == $CUR_REC2" + [ $CUR_REC1 == $CUR_REC2 ] || + err17935 "current index should be $CUR_REC1 is $CUR_REC2" + + echo "verifying user deregister" + do_facet $SINGLEMDS $LCTL --device $MDT0 changelog_deregister $USER + $GET_CL_USERS | grep -q $USER && + error "User $USER still in changelog_users" + + USERS=$(( $($GET_CL_USERS | wc -l) - 2 )) + if [ $USERS -eq 0 ]; then + LAST_REC1=$($GET_CL_USERS | head -1 | cut -f3 -d' ') + touch $DIR/$tdir/chloe + LAST_REC2=$($GET_CL_USERS | head -1 | cut -f3 -d' ') + echo "verify changelogs are off: $LAST_REC1 == $LAST_REC2" + [ $LAST_REC1 == $LAST_REC2 ] || error "changelogs not off" + else + echo "$USERS other changelog users; can't verify off" + fi } run_test 160 "changelog sanity" @@ -11107,12 +11159,15 @@ test_228c() { } run_test 228c "NOT shrink the last entry in OI index node to recycle idle leaf" -test_229() { # LU-2482 +test_229() { # LU-2482, LU-3448 [ $PARALLEL == "yes" ] && skip "skip parallel run" && return + [ $OSTCOUNT -lt 2 ] && skip "needs >= 2 OSTs" && return + + rm -f $DIR/$tfile - # Create a file with a release layout (stripe count = 0) + # Create a file with a released layout and stripe count 2. $MULTIOP $DIR/$tfile H2c || - error "failed to create file w. released layout" + error "failed to create file with released layout" $GETSTRIPE -v $DIR/$tfile @@ -11124,8 +11179,13 @@ test_229() { # LU-2482 [ $stripe_count -eq 2 ] || error "stripe count not 2 ($stripe_count)" stat $DIR/$tfile || error "failed to stat released file" - $TRUNCATE $DIR/$tfile 200000 - $CHECKSTAT -s 200000 $DIR/$tfile || error + # Truncate should fail. + $TRUNCATE $DIR/$tfile 200000 && + error "truncate of released file should fail" + + # Ensure that nothing happened anyway. + $CHECKSTAT -s 0 $DIR/$tfile || + error "released file size should not change" # Stripe count should be no change after truncate stripe_count=$($GETSTRIPE -c $DIR/$tfile) || error "getstripe failed" @@ -11133,7 +11193,7 @@ test_229() { # LU-2482 rm $DIR/$tfile || error "failed to remove released file" } -run_test 229 "getstripe/stat/rm work on released files (stripe count = 0)" +run_test 229 "getstripe/stat/rm work on released files (stripe count = 2)" test_230a() { [ $PARALLEL == "yes" ] && skip "skip parallel run" && return