}
run_test 17n "run e2fsck against master/slave MDT which contains remote dir"
+test_17o() {
+ local WDIR=$DIR/${tdir}o
+ local mdt_index
+ local mdtdevname
+ local rc=0
+
+ mkdir -p $WDIR
+ mdt_index=$($LFS getstripe -M $WDIR)
+ mdt_index=$((mdt_index+1))
+ mdtdevname=$(mdsdevname $mdt_index)
+
+ touch $WDIR/$tfile
+ stop mds${mdt_index}
+ start mds${mdt_index} $mdtdevname $MDS_MOUNT_OPTS
+
+ #define OBD_FAIL_OSD_LMA_INCOMPAT 0x194
+ do_facet mds${mdt_index} lctl set_param fail_loc=0x194
+ ls -l $WDIR/$tfile && rc=1
+ do_facet mds${mdt_index} lctl set_param fail_loc=0
+ [[ $rc -ne 0 ]] && error "stat file should fail"
+ true
+}
+run_test 17o "stat file with incompat LMA feature"
+
test_18() {
touch $DIR/f || error "Failed to touch $DIR/f: $?"
ls $DIR || error "Failed to ls $DIR: $?"
mrename $remote_src $remote_tgt &&
error "rename remote dirs should not work!"
+ # If target dir does not exists, it should succeed
+ rm -rf $remote_tgt
+ mrename $remote_src $remote_tgt ||
+ error "rename remote dirs(tgt dir does not exists) failed!"
+
rm -rf $DIR/$tdir || error "Can not delete directories"
}
run_test 24z "rename one remote dir to another remote dir should fail"
test_27f() {
test_mkdir -p $DIR/d27
$SETSTRIPE -S 100 -i 0 -c 1 $DIR/d27/fbad && error "setstripe failed"
- dd if=/dev/zero of=$DIR/d27/f12 bs=4k count=4 || error "dd failed"
+ dd if=/dev/zero of=$DIR/d27/fbad bs=4k count=4 || error "dd failed"
$GETSTRIPE $DIR/d27/fbad || error "$GETSTRIPE failed"
}
run_test 27f "setstripe with bad stripe size (should return error)"
run_test 27t "check that utils parse path correctly"
test_27u() { # bug 4900
- [ "$OSTCOUNT" -lt "2" ] && skip_env "too few OSTs" && return
- remote_mds_nodsh && skip "remote MDS with nodsh" && return
+ [ "$OSTCOUNT" -lt "2" ] && skip_env "too few OSTs" && return
+ remote_mds_nodsh && skip "remote MDS with nodsh" && return
+ local index
+ local list=$(comma_list $(mdts_nodes))
#define OBD_FAIL_MDS_OSC_PRECREATE 0x139
- do_facet $SINGLEMDS lctl set_param fail_loc=0x139
- test_mkdir -p $DIR/$tdir
+ do_nodes $list $LCTL set_param fail_loc=0x139
+ test_mkdir -p $DIR/$tdir
rm -rf $DIR/$tdir/*
- createmany -o $DIR/$tdir/t- 1000
- do_facet $SINGLEMDS lctl set_param fail_loc=0
+ createmany -o $DIR/$tdir/t- 1000
+ do_nodes $list $LCTL set_param fail_loc=0
- TLOG=$DIR/$tfile.getstripe
- $GETSTRIPE $DIR/$tdir > $TLOG
- OBJS=`awk -vobj=0 '($1 == 0) { obj += 1 } END { print obj;}' $TLOG`
- unlinkmany $DIR/$tdir/t- 1000
- [ $OBJS -gt 0 ] && \
- error "$OBJS objects created on OST-0. See $TLOG" || pass
+ TLOG=$DIR/$tfile.getstripe
+ $GETSTRIPE $DIR/$tdir > $TLOG
+ OBJS=`awk -vobj=0 '($1 == 0) { obj += 1 } END { print obj;}' $TLOG`
+ unlinkmany $DIR/$tdir/t- 1000
+ [ $OBJS -gt 0 ] && \
+ error "$OBJS objects created on OST-0. See $TLOG" || pass
}
run_test 27u "skip object creation on OSC w/o objects =========="
[ "$obdidx" = "obdidx" ] && have_obdidx=true && continue
$have_obdidx || continue
- local ost=$((obdidx + 1))
- local dev=$(ostdevname $ost)
+ local ost=$((obdidx + 1))
+ local dev=$(ostdevname $ost)
+ local oid_hex
if [ $(facet_fstype ost$ost) != ldiskfs ]; then
echo "Currently only works with ldiskfs-based OSTs"
stop ost$ost
do_facet ost$ost mount -t $(facet_fstype ost$ost) $opts $dev $dir ||
{ error "mounting $dev as $FSTYPE failed"; return 3; }
- local obj_file=$(do_facet ost$ost find $dir/O/$seq -name $oid)
+
+ seq=$(echo $seq | sed -e "s/^0x//g")
+ if [ $seq == 0 ]; then
+ oid_hex=$(echo $oid)
+ else
+ oid_hex=$(echo $hex | sed -e "s/^0x//g")
+ fi
+ local obj_file=$(do_facet ost$ost find $dir/O/$seq -name $oid_hex)
local ff=$(do_facet ost$ost $LL_DECODE_FILTER_FID $obj_file)
do_facet ost$ost umount -d $dir
start ost$ost $dev $OST_MOUNT_OPTS
# re-enable when debugfs will understand new filter_fid
- #seq=$(echo $seq | sed -e "s/^0x//g")
- #if [ $seq == 0 ]; then
- # oid_hex=$(echo $oid)
- #else
- # oid_hex=$(echo $hex | sed -e "s/^0x//g")
- #fi
- #local obj_file="O/$seq/d$((oid %32))/$oid_hex"
#local ff=$(do_facet ost$ost "$DEBUGFS -c -R 'stat $obj_file' \
# $dev 2>/dev/null" | grep "parent=")
declare -a ost_idx
local index
+ local found
local i
local j
ost_idx=($($GETSTRIPE $tfile$i |
tail -n $((OSTCOUNT + 1)) | awk '{print $1}'))
echo ${ost_idx[@]}
+
# check the layout
- for j in $(seq 0 $((OSTCOUNT - 1))); do
- index=$(((i + j) % OSTCOUNT))
- [ ${ost_idx[$j]} -eq $index ] || error
+ [ ${#ost_idx[@]} -eq $OSTCOUNT ] ||
+ error "${#ost_idx[@]} != $OSTCOUNT"
+
+ for index in $(seq 0 $((OSTCOUNT - 1))); do
+ found=0
+ for j in $(echo ${ost_idx[@]}); do
+ if [ $index -eq $j ]; then
+ found=1
+ break
+ fi
+ done
+ [ $found = 1 ] ||
+ error "Can not find $index in ${ost_idx[@]}"
done
done
}
for ostnum in $(seq $OSTCOUNT); do
# test-framework's OST numbering is one-based, while Lustre's
# is zero-based
- ostname=$(printf "$FSNAME-OST%.4d" $((ostnum - 1)))
+ ostname=$(printf "$FSNAME-OST%.4x" $((ostnum - 1)))
# Parsing llobdstat's output sucks; we could grep the /proc
# path, but that's likely to not be as portable as using the
# llobdstat utility. So we parse lctl output instead.
# Total up write_bytes after writing. We'd better find non-zeros.
for ostnum in $(seq $OSTCOUNT); do
- ostname=$(printf "$FSNAME-OST%.4d" $((ostnum - 1)))
+ ostname=$(printf "$FSNAME-OST%.4x" $((ostnum - 1)))
write_bytes=$(do_facet ost$ostnum lctl get_param -n \
obdfilter/$ostname/stats |
awk '/^write_bytes/ {print $7}' )
if $all_zeros
then
for ostnum in $(seq $OSTCOUNT); do
- ostname=$(printf "$FSNAME-OST%.4d" $((ostnum - 1)))
+ ostname=$(printf "$FSNAME-OST%.4x" $((ostnum - 1)))
echo "Check that write_bytes is present in obdfilter/*/stats:"
do_facet ost$ostnum lctl get_param -n \
obdfilter/$ostname/stats
remote_ost_nodsh && skip "remote OST with nodsh" && return
local param
+ local param_seq
local ostname
local mds_last
+ local mds_last_seq
local ost_last
+ local ost_last_seq
+ local ost_last_id
local ostnum
local node
+ local found=0
# only test MDT0000
local mdtosc=$(get_mdtosc_proc_path $SINGLEMDS)
for value in $(do_facet $SINGLEMDS lctl get_param osc.$mdtosc.prealloc_last_id) ; do
- param=`echo ${value[0]} | cut -d "=" -f1`
- ostname=`echo $param | cut -d "." -f2 | cut -d - -f 1-2`
- mds_last=$(do_facet $SINGLEMDS lctl get_param -n $param)
+ param=$(echo ${value[0]} | cut -d "=" -f1)
+ ostname=$(echo $param | cut -d "." -f2 | cut -d - -f 1-2)
+ param_seq=$(echo ${param} |
+ sed -e s/prealloc_last_id/prealloc_last_seq/g)
+ mds_last_seq=$(do_facet $SINGLEMDS lctl get_param -n $param_seq)
+ mds_last=$(do_facet $SINGLEMDS lctl get_param -n $param)
+
ostnum=$(index_from_ostuuid ${ostname}_UUID)
node=$(facet_active_host ost$((ostnum+1)))
param="obdfilter.$ostname.last_id"
- ost_last=$(do_node $node lctl get_param -n $param | head -n 1)
- echo "$ostname.last_id=$ost_last ; MDS.last_id=$mds_last"
- if [ $ost_last != $mds_last ]; then
- error "$ostname.last_id=$ost_last ; MDS.last_id=$mds_last"
- fi
+ for ost_last in $(do_node $node lctl get_param -n $param) ; do
+ echo "$ostname.last_id=$ost_last ;MDS.last_id=$mds_last"
+ ost_last_id=$(echo $ost_last | awk -F':' '{print $2}' |
+ sed -e "s/^0x//g")
+ ost_last_seq=$(echo $ost_last | awk -F':' '{print $1}')
+ if [ $ost_last_seq = $mds_last_seq ]; then
+ if [ $ost_last_id != $mds_last ]; then
+ error "$ost_last != $mds_last_id"
+ else
+ found=1
+ break
+ fi
+ fi
+ done
done
+ [ $found = 0 ] && error "can not match last_seq/last_id for $mdtosc"
+ return 0
}
run_test 53 "verify that MDS and OSTs agree on pre-creation ===="
[ $NUMS -eq $EXPECTED ] ||
error "\"$CMD\" wrong: found $NUMS, expected $EXPECTED"
- EXPECTED=$(((NUMDIRS + 1) * NUMFILES + ONESTRIPE))
- CMD="$LFIND -stripe-index 0,1 -type f $TDIR"
- NUMS=$($CMD | wc -l)
- [ $NUMS -eq $EXPECTED ] ||
- error "\"$CMD\" wrong: found $NUMS, expected $EXPECTED"
+ if [ $OSTCOUNT -gt 1 ]; then
+ EXPECTED=$(((NUMDIRS + 1) * NUMFILES + ONESTRIPE))
+ CMD="$LFIND -stripe-index 0,1 -type f $TDIR"
+ NUMS=$($CMD | wc -l)
+ [ $NUMS -eq $EXPECTED ] ||
+ error "\"$CMD\" wrong: found $NUMS, expected $EXPECTED"
+ fi
}
run_test 56u "check lfs find -stripe-index works"
local default_size=`$GETSTRIPE -S $test_kdir`
local default_count=`$GETSTRIPE -c $test_kdir`
local default_offset=`$GETSTRIPE -i $test_kdir`
- $SETSTRIPE -S 65536 -i 1 -c $OSTCOUNT $test_kdir ||
+ $SETSTRIPE -S 65536 -i 0 -c $OSTCOUNT $test_kdir ||
error 'dir setstripe failed'
setfattr -n trusted.lov $test_kdir
local stripe_size=`$GETSTRIPE -S $test_kdir`
test_mkdir -p $DIR/$tdir
[ -z "`lctl get_param -n mdc.*.connect_flags | grep early_lock_cancel`" ] && \
skip "no early lock cancel on server" && return 0
- lru_resize_disable mdc
- lru_resize_disable osc
- cancel_lru_locks mdc
+
+ lru_resize_disable mdc
+ lru_resize_disable osc
+ cancel_lru_locks mdc
+ # asynchronous object destroy at MDT could cause bl ast to client
+ cancel_lru_locks osc
+
stat $DIR/$tdir > /dev/null
can1=`lctl get_param -n ldlm.services.ldlm_canceld.stats | awk '/ldlm_cancel/ {print $2}'`
blk1=`lctl get_param -n ldlm.services.ldlm_cbd.stats | awk '/ldlm_bl_callback/ {print $2}'`
[ "$OSTCOUNT" -lt "2" ] &&
skip_env "skipping FIEMAP on 2-stripe file test" && return
+ [ "$OSTCOUNT" -ge "10" ] &&
+ skip_env "skipping FIEMAP with >= 10 OSTs" && return
+
local filefrag_op=$(filefrag -e 2>&1 | grep "invalid option")
[ -n "$filefrag_op" ] && skip_env "filefrag does not support FIEMAP" &&
return
[ "$OSTCOUNT" -lt "2" ] &&
skip_env "skipping FIEMAP on 2-stripe file" && return
+ [ "$OSTCOUNT" -ge "10" ] &&
+ skip_env "skipping FIEMAP with >= 10 OSTs" && return
+
filefrag_op=$(filefrag -e 2>&1 | grep "invalid option")
[ -n "$filefrag_op" ] && skip "filefrag does not support FIEMAP" &&
return
test_130d() {
[ "$OSTCOUNT" -lt "3" ] && skip_env "skipping FIEMAP on N-stripe file test" && return
+ [ "$OSTCOUNT" -ge "10" ] &&
+ skip_env "skipping FIEMAP with >= 10 OSTs" && return
+
filefrag_op=$(filefrag -e 2>&1 | grep "invalid option")
[ -n "$filefrag_op" ] && skip "filefrag does not support FIEMAP" && return
test_130e() {
[ "$OSTCOUNT" -lt "2" ] && skip_env "skipping continuation FIEMAP test" && return
+ [ "$OSTCOUNT" -ge "10" ] &&
+ skip_env "skipping FIEMAP with >= 10 OSTs" && return
+
filefrag_op=$(filefrag -e 2>&1 | grep "invalid option")
[ -n "$filefrag_op" ] && skip "filefrag does not support FIEMAP" && return
test_133d() {
[ $PARALLEL == "yes" ] && skip "skip parallel run" && return
- remote_ost_nodsh && skip "remote OST with nodsh" && return
- remote_mds_nodsh && skip "remote MDS with nodsh" && return
- do_facet $SINGLEMDS $LCTL list_param mdt.*.rename_stats ||
- { skip "MDS doesn't support rename stats"; return; }
+ remote_ost_nodsh && skip "remote OST with nodsh" && return
+ remote_mds_nodsh && skip "remote MDS with nodsh" && return
+ do_facet $SINGLEMDS $LCTL list_param mdt.*.rename_stats ||
+ { skip "MDS doesn't support rename stats"; return; }
- local testdir1=$DIR/${tdir}/stats_testdir1
- local testdir2=$DIR/${tdir}/stats_testdir2
+ local testdir1=$DIR/${tdir}/stats_testdir1
+ local testdir2=$DIR/${tdir}/stats_testdir2
- do_facet $SINGLEMDS $LCTL set_param mdt.*.rename_stats=clear
+ do_facet $SINGLEMDS $LCTL set_param mdt.*.rename_stats=clear
- test_mkdir -p ${testdir1} || error "mkdir failed"
- test_mkdir -p ${testdir2} || error "mkdir failed"
+ mkdir -p ${testdir1} || error "mkdir failed"
+ mkdir -p ${testdir2} || error "mkdir failed"
- createmany -o $testdir1/test 512 || error "createmany failed"
+ createmany -o $testdir1/test 512 || error "createmany failed"
# check samedir rename size
mv ${testdir1}/test0 ${testdir1}/test_0
echo "source rename dir size: ${testdir1_size}"
echo "target rename dir size: ${testdir2_size}"
- local cmd="do_facet $SINGLEMDS $LCTL get_param mdt.*.rename_stats"
- eval $cmd || error "$cmd failed"
- local samedir=$($cmd | grep 'same_dir')
- local same_sample=$(get_rename_size $testdir1_size)
- [ -z "$samedir" ] && error "samedir_rename_size count error"
- [ "$same_sample" -eq 1 ] || error "samedir_rename_size error $same_sample"
- echo "Check same dir rename stats success"
+ local cmd="do_facet $SINGLEMDS $LCTL get_param mdt.*.rename_stats"
+ eval $cmd || error "$cmd failed"
+ local samedir=$($cmd | grep 'same_dir')
+ local same_sample=$(get_rename_size $testdir1_size)
+ [ -z "$samedir" ] && error "samedir_rename_size count error"
+ [ "$same_sample" -eq 1 ] || error "samedir_rename_size error $same_sample"
+ echo "Check same dir rename stats success"
- do_facet $SINGLEMDS $LCTL set_param mdt.*.rename_stats=clear
+ do_facet $SINGLEMDS $LCTL set_param mdt.*.rename_stats=clear
- # check crossdir rename size
- mv ${testdir1}/test_0 ${testdir2}/test_0
+ # check crossdir rename size
+ mv ${testdir1}/test_0 ${testdir2}/test_0
testdir1_size=$(ls -l $DIR/${tdir} |
awk '/stats_testdir1/ {print $5}')
echo "source rename dir size: ${testdir1_size}"
echo "target rename dir size: ${testdir2_size}"
- eval $cmd || error "$cmd failed"
- local crossdir=$($cmd | grep 'crossdir')
- local src_sample=$(get_rename_size $testdir1_size crossdir_src)
- local tgt_sample=$(get_rename_size $testdir2_size crossdir_tgt)
- [ -z "$crossdir" ] && error "crossdir_rename_size count error"
- [ "$src_sample" -eq 1 ] || error "crossdir_rename_size error $src_sample"
- [ "$tgt_sample" -eq 1 ] || error "crossdir_rename_size error $tgt_sample"
- echo "Check cross dir rename stats success"
- rm -rf $DIR/${tdir}
+ eval $cmd || error "$cmd failed"
+ local crossdir=$($cmd | grep 'crossdir')
+ local src_sample=$(get_rename_size $testdir1_size crossdir_src)
+ local tgt_sample=$(get_rename_size $testdir2_size crossdir_tgt)
+ [ -z "$crossdir" ] && error "crossdir_rename_size count error"
+ [ "$src_sample" -eq 1 ] || error "crossdir_rename_size error $src_sample"
+ [ "$tgt_sample" -eq 1 ] || error "crossdir_rename_size error $tgt_sample"
+ echo "Check cross dir rename stats success"
+ rm -rf $DIR/${tdir}
}
run_test 133d "Verifying rename_stats ========================================"
error "touch $MOUNT/.lustre/fid/$tfile should fail."
echo "setxattr to $MOUNT/.lustre/fid"
- setfattr -n trusted.name1 -v value1 $MOUNT/.lustre/fid &&
- error "setxattr should fail."
+ setfattr -n trusted.name1 -v value1 $MOUNT/.lustre/fid
echo "listxattr for $MOUNT/.lustre/fid"
- getfattr -d -m "^trusted" $MOUNT/.lustre/fid &&
- error "listxattr should fail."
+ getfattr -d -m "^trusted" $MOUNT/.lustre/fid
echo "delxattr from $MOUNT/.lustre/fid"
- setfattr -x trusted.name1 $MOUNT/.lustre/fid &&
- error "delxattr should fail."
+ setfattr -x trusted.name1 $MOUNT/.lustre/fid
echo "touch invalid fid: $MOUNT/.lustre/fid/[0x200000400:0x2:0x3]"
touch $MOUNT/.lustre/fid/[0x200000400:0x2:0x3] &&
mrename $MOUNT/.lustre $MOUNT/.lustre/fid/$fid/.lustre &&
error "rename .lustre to itself should fail."
+ 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"
+
+ 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"
+
$OPENFILE -f O_LOV_DELAY_CREATE:O_CREAT $test_dir/$tfile-2
fid=$($LFS path2fid $test_dir/$tfile-2)
echo "cp /etc/passwd $MOUNT/.lustre/fid/$fid"
error "dot lustre permission check $fid failed"
rm -rf $MOUNT/.lustre && error ".lustre is not allowed to be unlinked"
- chmod 777 $MOUNT/.lustre && error ".lustre is not allowed to be chmod"
touch $MOUNT/.lustre/file &&
error "creation is not allowed under .lustre"
}
run_test 184c "Concurrent write and layout swap"
+test_184d() {
+ check_swap_layouts_support && return 0
+
+ local file1=$DIR/$tdir/$tfile-1
+ local file2=$DIR/$tdir/$tfile-2
+ local file3=$DIR/$tdir/$tfile-3
+ local lovea1
+ local lovea2
+
+ mkdir -p $DIR/$tdir
+ touch $file1 || error "create $file1 failed"
+ $OPENFILE -f O_CREAT:O_LOV_DELAY_CREATE $file2 ||
+ error "create $file2 failed"
+ $OPENFILE -f O_CREAT:O_LOV_DELAY_CREATE $file3 ||
+ error "create $file3 failed"
+ lovea1=$($LFS getstripe $file1 | sed 1d)
+
+ $LFS swap_layouts $file2 $file3 ||
+ error "swap $file2 $file3 layouts failed"
+ $LFS swap_layouts $file1 $file2 ||
+ error "swap $file1 $file2 layouts failed"
+
+ lovea2=$($LFS getstripe $file2 | sed 1d)
+ [ "$lovea1" == "$lovea2" ] || error "lovea $lovea1 != $lovea2"
+
+ lovea1=$(getfattr -n trusted.lov $file1 | grep ^trusted)
+ [ -z $lovea1 ] || error "$file1 shouldn't have lovea"
+}
+run_test 184d "allow stripeless layouts swap"
+
+
test_185() { # LU-2441
mkdir -p $DIR/$tdir || error "creating dir $DIR/$tdir"
touch $DIR/$tdir/spoo
test_216() { # bug 20317
[ $PARALLEL == "yes" ] && skip "skip parallel run" && return
- remote_ost_nodsh && skip "remote OST with nodsh" && return
- local node
- local p="$TMP/sanityN-$TESTNAME.parameters"
- save_lustre_params $HOSTNAME "osc.*.contention_seconds" > $p
- for node in $(osts_nodes); do
- save_lustre_params $node "ldlm.namespaces.filter-*.max_nolock_bytes" >> $p
- save_lustre_params $node "ldlm.namespaces.filter-*.contended_locks" >> $p
- save_lustre_params $node "ldlm.namespaces.filter-*.contention_seconds" >> $p
- done
- clear_osc_stats
+ remote_ost_nodsh && skip "remote OST with nodsh" && return
+
+ local node
+ local facets=$(get_facets OST)
+ local p="$TMP/$TESTSUITE-$TESTNAME.parameters"
+
+ save_lustre_params client "osc.*.contention_seconds" > $p
+ save_lustre_params $facets \
+ "ldlm.namespaces.filter-*.max_nolock_bytes" >> $p
+ save_lustre_params $facets \
+ "ldlm.namespaces.filter-*.contended_locks" >> $p
+ save_lustre_params $facets \
+ "ldlm.namespaces.filter-*.contention_seconds" >> $p
+ clear_osc_stats
# agressive lockless i/o settings
for node in $(osts_nodes); do
MDSSURVEY=${MDSSURVEY:-$(which mds-survey 2>/dev/null || true)}
test_225a () {
[ $PARALLEL == "yes" ] && skip "skip parallel run" && return
- if [ -z ${MDSSURVEY} ]; then
- skip_env "mds-survey not found" && return
- fi
+ if [ -z ${MDSSURVEY} ]; then
+ skip_env "mds-survey not found" && return
+ fi
+
+ [ $MDSCOUNT -ge 2 ] &&
+ skip "skipping now for more than one MDT" && return
+
[ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.2.51) ] ||
{ skip "Need MDS version at least 2.2.51"; return; }
test_225b () {
[ $PARALLEL == "yes" ] && skip "skip parallel run" && return
- if [ -z ${MDSSURVEY} ]; then
- skip_env "mds-survey not found" && return
- fi
- [ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.2.51) ] ||
- { skip "Need MDS version at least 2.2.51"; return; }
- if [ $($LCTL dl | grep -c osc) -eq 0 ]; then
- skip_env "Need to mount OST to test" && return
- fi
+ if [ -z ${MDSSURVEY} ]; then
+ skip_env "mds-survey not found" && return
+ fi
+ [ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.2.51) ] ||
+ { skip "Need MDS version at least 2.2.51"; return; }
+
+ if [ $($LCTL dl | grep -c osc) -eq 0 ]; then
+ skip_env "Need to mount OST to test" && return
+ fi
+ [ $MDSCOUNT -ge 2 ] &&
+ skip "skipping now for more than one MDT" && return
local mds=$(facet_host $SINGLEMDS)
local target=$(do_nodes $mds 'lctl dl' | \
awk "{if (\$2 == \"UP\" && \$3 == \"mdt\") {print \$4}}")