set -e
ONLY=${ONLY:-"$*"}
-# bug number for skipped test: 9977/LU-7105
-# LU-7105
-ALWAYS_EXCEPT=" 28 $SANITYN_EXCEPT"
-# UPDATE THE COMMENT ABOVE WITH BUG NUMBERS WHEN CHANGING ALWAYS_EXCEPT!
-
-SRCDIR=$(dirname $0)
-PATH=$PWD/$SRCDIR:$SRCDIR:$SRCDIR/../utils:$PATH
SIZE=${SIZE:-40960}
-CHECKSTAT=${CHECKSTAT:-"checkstat -v"}
OPENFILE=${OPENFILE:-openfile}
OPENUNLINK=${OPENUNLINK:-openunlink}
-export MULTIOP=${MULTIOP:-multiop}
export TMP=${TMP:-/tmp}
MOUNT_2=${MOUNT_2:-"yes"}
CHECK_GRANT=${CHECK_GRANT:-"yes"}
GRANT_CHECK_LIST=${GRANT_CHECK_LIST:-""}
-SAVE_PWD=$PWD
-
-export NAME=${NAME:-local}
-
-LUSTRE=${LUSTRE:-`dirname $0`/..}
+LUSTRE=${LUSTRE:-$(dirname $0)/..}
. $LUSTRE/tests/test-framework.sh
-CLEANUP=${CLEANUP:-:}
-SETUP=${SETUP:-:}
init_test_env $@
-. ${CONFIG:=$LUSTRE/tests/cfg/$NAME.sh}
-get_lustre_env
init_logging
-if [ $(facet_fstype $SINGLEMDS) = "zfs" ]; then
-# bug number for skipped test:
- ALWAYS_EXCEPT="$ALWAYS_EXCEPT "
-# LU-2829 / LU-2887 - make allowances for ZFS slowness
+ALWAYS_EXCEPT="$SANITYN_EXCEPT "
+# bug number for skipped test: LU-7105
+ALWAYS_EXCEPT+=" 28"
+# UPDATE THE COMMENT ABOVE WITH BUG NUMBERS WHEN CHANGING ALWAYS_EXCEPT!
+
+if [ $mds1_FSTYPE = "zfs" ]; then
+ # LU-2829 / LU-2887 - make allowances for ZFS slowness
TEST33_NFILES=${TEST33_NFILES:-1000}
fi
+
# 23 (min)"
[ "$SLOW" = "no" ] && EXCEPT_SLOW="33a"
+build_test_filter
+
FAIL_ON_ERROR=false
SETUP=${SETUP:-:}
check_runas_id $RUNAS_ID $RUNAS_GID $RUNAS
-build_test_filter
-
test_1() {
touch $DIR1/$tfile
[ -f $DIR2/$tfile ] || error "Check create"
# The FSXNUM reduction for ZFS is needed until ORI-487 is fixed.
# We don't want to skip it entirely, but ZFS is VERY slow and cannot
# pass a 2500 operation dual-mount run within the time limit.
-if [ "$(facet_fstype ost1)" = "zfs" ]; then
+if [ "$ost1_FSTYPE" = "zfs" ]; then
FSXNUM=$((COUNT / 5))
FSXP=1
elif [ "$SLOW" = "yes" ]; then
local stripe_size=$(do_facet $SINGLEMDS \
"$LCTL get_param -n lod.$(facet_svc $SINGLEMDS)*.stripesize")
- [ $(facet_fstype ost1) != ldiskfs ] && skip "dio on ldiskfs only"
+ [ "$ost1_FSTYPE" != ldiskfs ] && skip "dio on ldiskfs only"
# to allocate grant because it may run out due to test_15.
$LFS setstripe -c -1 $file1
}
run_test 16c "verify data consistency on ldiskfs with cache disabled (b=17397)"
+test_16d() {
+ local file1=$DIR1/$tfile
+ local file2=$DIR2/$tfile
+ local file3=$DIR1/file
+ local stripe_size=$(do_facet $SINGLEMDS \
+ "$LCTL get_param -n lod.$(facet_svc $SINGLEMDS)*.stripesize")
+
+ # to allocate grant because it may run out due to test_15.
+ $LFS setstripe -c -1 $file1
+ dd if=/dev/zero of=$file1 bs=$stripe_size count=$OSTCOUNT oflag=sync
+ dd if=/dev/zero of=$file2 bs=$stripe_size count=$OSTCOUNT oflag=sync
+ rm -f $file1
+
+ local tmpfile=`mktemp`
+ $LFS setstripe -c -1 $file1 # b=10919
+ $LCTL set_param ldlm.namespaces.*.lru_size=clear
+
+ # direct write on one client and direct read from another
+ dd if=/dev/urandom of=$file1 bs=1M count=100 oflag=direct
+ dd if=$file2 of=$tmpfile iflag=direct bs=1M
+ diff $file1 $tmpfile || error "file different(1)"
+ rm -f $file1
+
+ # buffer write on one client, but direct read from another
+ dd if=$tmpfile of=$file1 bs=1M count=100
+ dd if=$file2 of=$file3 bs=1M iflag=direct count=100
+ diff $file3 $tmpfile || error "file different(2)"
+
+ rm -f $file3 $file2 $file1
+ # direct write on one client
+ dd if=$tmpfile of=$file1 bs=1M count=100 oflag=direct
+ # buffer read from another client
+ dd if=$file2 of=$file3 bs=1M count=100
+ diff $file3 $tmpfile || error "file different(3)"
+
+ rm -f $file1 $file2 $file3 $tmpfile
+
+}
+run_test 16d "Verify DIO and buffer IO with two clients"
+
test_17() { # bug 3513, 3667
remote_ost_nodsh && skip "remote OST with nodsh" && return
# commit on sharing tests
test_33a() {
- remote_mds_nodsh && skip "remote MDS with nodsh" && return
+ remote_mds_nodsh && skip "remote MDS with nodsh" && return
- [ -z "$CLIENTS" ] && skip "Need two or more clients, have $CLIENTS" && return 0
- [ $CLIENTCOUNT -lt 2 ] &&
- skip "Need two or more clients, have $CLIENTCOUNT" && return 0
+ [ -z "$CLIENTS" ] && skip "Need two or more clients, have $CLIENTS"
+ [ $CLIENTCOUNT -lt 2 ] &&
+ skip "Need two or more clients, have $CLIENTCOUNT"
- local nfiles=${TEST33_NFILES:-10000}
- local param_file=$TMP/$tfile-params
- local fstype=$(facet_fstype $SINGLEMDS)
+ local nfiles=${TEST33_NFILES:-10000}
+ local param_file=$TMP/$tfile-params
+ local COS
+ local jbdold="N/A"
+ local jbdnew="N/A"
+ local jbd
save_lustre_params $(get_facets MDS) \
"mdt.*.commit_on_sharing" > $param_file
- local COS
- local jbdold="N/A"
- local jbdnew="N/A"
- local jbd
-
- for COS in 0 1; do
- do_facet $SINGLEMDS lctl set_param mdt.*.commit_on_sharing=$COS
- avgjbd=0
- avgtime=0
- for i in 1 2 3; do
- do_nodes $CLIENT1,$CLIENT2 "mkdir -p $DIR1/$tdir-\\\$(hostname)-$i"
-
- [ $fstype = ldiskfs ] && jbdold=$(print_jbd_stat)
- echo "=== START createmany old: $jbdold transaction"
- local elapsed=$(do_and_time "do_nodes $CLIENT1,$CLIENT2 createmany -o $DIR1/$tdir-\\\$(hostname)-$i/f- -r$DIR2/$tdir-\\\$(hostname)-$i/f- $nfiles > /dev/null 2>&1")
- [ $fstype = ldiskfs ] && jbdnew=$(print_jbd_stat)
- [ $fstype = ldiskfs ] && jbd=$(( jbdnew - jbdold ))
- echo "=== END createmany new: $jbdnew transaction : $jbd transactions nfiles $nfiles time $elapsed COS=$COS"
- [ $fstype = ldiskfs ] && avgjbd=$(( avgjbd + jbd ))
- avgtime=$(( avgtime + elapsed ))
- done
- eval cos${COS}_jbd=$((avgjbd / 3))
- eval cos${COS}_time=$((avgtime / 3))
- done
+ for COS in 0 1; do
+ do_facet $SINGLEMDS lctl set_param mdt.*.commit_on_sharing=$COS
+ avgjbd=0
+ avgtime=0
+ for i in 1 2 3; do
+ do_nodes $CLIENT1,$CLIENT2 "mkdir -p $DIR1/$tdir-\\\$(hostname)-$i"
+
+ [ "$mds1_FSTYPE" = ldiskfs ] && jbdold=$(print_jbd_stat)
+ echo "=== START createmany old: $jbdold transaction"
+ local elapsed=$(do_and_time "do_nodes $CLIENT1,$CLIENT2 createmany -o $DIR1/$tdir-\\\$(hostname)-$i/f- -r$DIR2/$tdir-\\\$(hostname)-$i/f- $nfiles > /dev/null 2>&1")
+ [ "$mds1_FSTYPE" = ldiskfs ] && jbdnew=$(print_jbd_stat)
+ [ "$mds1_FSTYPE" = ldiskfs ] && jbd=$(( jbdnew - jbdold ))
+ echo "=== END createmany new: $jbdnew transaction : $jbd transactions nfiles $nfiles time $elapsed COS=$COS"
+ [ "$mds1_FSTYPE" = ldiskfs ] && avgjbd=$(( avgjbd + jbd ))
+ avgtime=$(( avgtime + elapsed ))
+ done
+ eval cos${COS}_jbd=$((avgjbd / 3))
+ eval cos${COS}_time=$((avgtime / 3))
+ done
- echo "COS=0 transactions (avg): $cos0_jbd time (avg): $cos0_time"
- echo "COS=1 transactions (avg): $cos1_jbd time (avg): $cos1_time"
- [ "$cos0_jbd" != 0 ] && echo "COS=1 vs COS=0 jbd: $((((cos1_jbd/cos0_jbd - 1)) * 100 )) %"
- [ "$cos0_time" != 0 ] && echo "COS=1 vs COS=0 time: $((((cos1_time/cos0_time - 1)) * 100 )) %"
+ echo "COS=0 transactions (avg): $cos0_jbd time (avg): $cos0_time"
+ echo "COS=1 transactions (avg): $cos1_jbd time (avg): $cos1_time"
+ [ "$cos0_jbd" != 0 ] &&
+ echo "COS=1 vs COS=0 jbd: $((((cos1_jbd/cos0_jbd - 1)) * 100 )) %"
+ [ "$cos0_time" != 0 ] &&
+ echo "COS=1 vs COS=0 time: $((((cos1_time/cos0_time - 1)) * 100 )) %"
- restore_lustre_params < $param_file
- rm -f $param_file
- return 0
+ restore_lustre_params < $param_file
+ rm -f $param_file
+ return 0
}
run_test 33a "commit on sharing, cross crete/delete, 2 clients, benchmark"
run_test 33b "COS: cross create/delete, 2 clients, benchmark under remote dir"
test_33c() {
- [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.7.63) ] &&
- skip "DNE CoS not supported" && return
+ [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs"
+ [ "$MDS1_VERSION" -lt $(version_code 2.7.63) ] &&
+ skip "DNE CoS not supported"
local sync_count
}
test_33d() {
- [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.7.63) ] &&
- skip "DNE CoS not supported" && return
+ [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs"
+ [ "$MDS1_VERSION" -lt $(version_code 2.7.63) ] &&
+ skip "DNE CoS not supported"
# remote directory create
op_trigger_cos "mkdir $DIR/$tdir" "$LFS mkdir -i 1 $DIR/$tdir/subdir"
run_test 33d "DNE distributed operation should trigger COS"
test_33e() {
- [ -n "$CLIENTS" ] || { skip "Need two or more clients" && return 0; }
+ [ -n "$CLIENTS" ] || skip "Need two or more clients"
[ $CLIENTCOUNT -ge 2 ] ||
- { skip "Need two or more clients, have $CLIENTCOUNT" &&
- return 0; }
- [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.7.63) ] &&
- skip "DNE CoS not supported" && return
+ skip "Need two or more clients, have $CLIENTCOUNT"
+ [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs"
+ [ "$MDS1_VERSION" -lt $(version_code 2.7.63) ] &&
+ skip "DNE CoS not supported"
local client2=${CLIENT2:-$(hostname)}
pdo_sched() {
# how long 40-47 take with specific delay
# sleep 0.1 # 78s
- sleep 0.2 # 103s
+ # sleep 0.2 # 103s
# sleep 0.3 # 124s
- # sleep 0.5 # 164s
+ sleep 0.5 # 164s
}
# for pdo testing, we must cancel MDT-MDT locks as well as client locks to
run_test 51a "layout lock: refresh layout should work"
test_51b() {
- [[ $(lustre_version_code $SINGLEMDS) -ge $(version_code 2.3.59) ]] ||
- { skip "Need MDS version at least 2.3.59"; return 0; }
+ [[ "$MDS1_VERSION" -ge $(version_code 2.3.59) ]] ||
+ skip "Need MDS version at least 2.3.59"
local tmpfile=`mktemp`
run_test 55d "rename file vs link"
test_60() {
- local MDSVER=$(lustre_build_version $SINGLEMDS)
- [ $(version_code $MDSVER) -lt $(version_code 2.3.0) ] &&
- skip "MDS version $MDSVER must be >= 2.3.0" && return 0
+ [ $MDS1_VERSION -lt $(version_code 2.3.0) ] &&
+ skip "MDS version must be >= 2.3.0"
# Create a file
test_mkdir $DIR1/$tdir
run_test 70b "remove files after calling rm_entry"
test_71a() {
- local server_version=$(lustre_version_code $SINGLEMDS)
-
- [[ $server_version -lt $(version_code 2.1.6) ]] &&
- skip "Need MDS version at least 2.1.6" && return
+ [[ "$MDS1_VERSION" -lt $(version_code 2.1.6) ]] &&
+ skip "Need MDS version at least 2.1.6"
# Patch not applied to 2.2 and 2.3 branches
- [[ $server_version -ge $(version_code 2.2.0) ]] &&
- [[ $server_version -lt $(version_code 2.4.0) ]] &&
- skip "Need MDS version earlier than 2.2.0 or at least 2.4.0" &&
- return
+ [[ "$MDS1_VERSION" -ge $(version_code 2.2.0) ]] &&
+ [[ "$MDS1_VERSION" -lt $(version_code 2.4.0) ]] &&
+ skip "Need MDS version earlier than 2.2.0 or at least 2.4.0"
checkfiemap --test ||
- { skip "checkfiemap not runnable: $?" && return; }
+ skip "checkfiemap not runnable: $?"
# write data this way: hole - data - hole - data
dd if=/dev/urandom of=$DIR1/$tfile bs=40K seek=1 count=1
[ "$(facet_fstype ost$(($($LFS getstripe -i $DIR1/$tfile) + 1)))" = \
run_test 71a "correct file map just after write operation is finished"
test_71b() {
- local server_version=$(lustre_version_code $SINGLEMDS)
-
- [[ $server_version -lt $(version_code 2.1.6) ]] &&
- skip "Need MDS version at least 2.1.6" && return
+ [[ "$MDS1_VERSION" -lt $(version_code 2.1.6) ]] &&
+ skip "Need MDS version at least 2.1.6"
# Patch not applied to 2.2 and 2.3 branches
- [[ $server_version -ge $(version_code 2.2.0) ]] &&
- [[ $server_version -lt $(version_code 2.4.0) ]] &&
- skip "Need MDS version earlier than 2.2.0 or at least 2.4.0" &&
- return
- [[ $OSTCOUNT -ge 2 ]] || { skip "needs >= 2 OSTs"; return; }
+ [[ "$MDS1_VERSION" -ge $(version_code 2.2.0) ]] &&
+ [[ "$MDS1_VERSION" -lt $(version_code 2.4.0) ]] &&
+ skip "Need MDS version earlier than 2.2.0 or at least 2.4.0"
+ [[ $OSTCOUNT -ge 2 ]] || skip "needs >= 2 OSTs"
checkfiemap --test ||
- { skip "error $?: checkfiemap failed" && return; }
+ skip "error $?: checkfiemap failed"
mkdir -p $DIR1/$tdir
run_test 73 "getxattr should not cause xattr lock cancellation"
test_74() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.4.93) ] &&
- skip "Need MDS version at least 2.4.93" && return
+ [ "$MDS1_VERSION" -lt $(version_code 2.4.93) ] &&
+ skip "Need MDS version at least 2.4.93"
dd if=/dev/zero of=$DIR1/$tfile-1 bs=1K count=1
dd if=/dev/zero of=$DIR1/$tfile-2 bs=1K count=1
run_test 75 "osc: upcall after unuse lock==================="
test_76() { #LU-946
- [[ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.5.53) ]] &&
- skip "Need MDS version at least 2.5.53" && return
+ [[ "$MDS1_VERSION" -lt $(version_code 2.5.53) ]] &&
+ skip "Need MDS version at least 2.5.53"
- remote_mds_nodsh && skip "remote MDS with nodsh" && return
+ remote_mds_nodsh && skip "remote MDS with nodsh"
local fcount=$((MDSCOUNT * 256))
declare -a fd_list
declare -a fid_list
local idis
local rateis
- if [ $(lustre_version_code ost1) -ge $(version_code 2.8.54) ]; then
+ if [ "$OST1_VERSION" -ge $(version_code 2.8.54) ]; then
idis="nid="
rateis="rate="
fi
local idis
local rateis
- if [ $(lustre_version_code ost1) -ge $(version_code 2.8.54) ]; then
+ if [ "$OST1_VERSION" -ge $(version_code 2.8.54) ]; then
idis="jobid="
rateis="rate="
fi
local idis
local rateis
- if [ $(lustre_version_code ost1) -ge $(version_code 2.8.54) ]; then
+ if [ "$OST1_VERSION" -ge $(version_code 2.8.54) ]; then
idis="jobid="
rateis="rate="
fi
run_test 77g "Change TBF type directly"
test_77h() {
- [ $(lustre_version_code ost1) -ge $(version_code 2.8.55) ] ||
- { skip "Need OST version at least 2.8.55"; return 0; }
+ [ "$OST1_VERSION" -ge $(version_code 2.8.55) ] ||
+ skip "Need OST version at least 2.8.55"
local old_policy=$(do_facet ost1 \
lctl get_param ost.OSS.ost_io.nrs_policies)
}
test_77i() {
- [ $(lustre_version_code ost1) -ge $(version_code 2.8.55) ] ||
- { skip "Need OST version at least 2.8.55"; return 0; }
+ [ "$OST1_VERSION" -ge $(version_code 2.8.55) ] ||
+ skip "Need OST version at least 2.8.55"
for i in $(seq 1 $OSTCOUNT)
do
test_77j() {
local idis
local rateis
- local ost_version=$(lustre_version_code ost1)
- [ $ost_version -ge $(version_code 2.9.53) ] ||
- { skip "Need OST version at least 2.9.53"; return 0; }
- if [ $ost_version -ge $(version_code 2.8.60) ]; then
+ [ "$OST1_VERSION" -ge $(version_code 2.9.53) ] ||
+ skip "Need OST version at least 2.9.53"
+ if [ "$OST1_VERSION" -ge $(version_code 2.8.60) ]; then
idis="opcode="
rateis="rate="
fi
}
test_77ja(){
- if [ $(lustre_version_code ost1) -lt $(version_code 2.11.50) ]; then
+ if [ "$OST1_VERSION" -lt $(version_code 2.11.50) ]; then
skip "Need OST version at least 2.11.50"
- return 0
fi
+
test_id "u" "500" "5" "-u 500"
test_id "g" "500" "5" "-u 500 -g 500"
}
}
test_77k() {
- [[ $(lustre_version_code ost1) -ge $(version_code 2.9.53) ]] ||
- { skip "Need OST version at least 2.9.53"; return 0; }
+ [[ "$OST1_VERSION" -ge $(version_code 2.9.53) ]] ||
+ skip "Need OST version at least 2.9.53"
do_nodes $(comma_list $(osts_nodes)) \
lctl set_param ost.OSS.ost_io.nrs_policies="tbf" \
trap "cleanup_77k \"ext_a ext_b\" \"fifo\"" EXIT
- [[ $(lustre_version_code ost1) -ge $(version_code 2.10.58) ]] ||
- { skip "Need OST version at least 2.10.58"; return 0; }
+ [[ "$OST1_VERSION" -ge $(version_code 2.10.58) ]] ||
+ skip "Need OST version at least 2.10.58"
do_nodes $(comma_list $(osts_nodes)) \
lctl set_param ost.OSS.ost_io.nrs_tbf_rule="stop\ ext_a" \
run_test 77k "check TBF policy with NID/JobID/OPCode expression"
test_77l() {
- [[ $(lustre_version_code ost1) -ge $(version_code 2.10.56) ]] ||
- { skip "Need OST version at least 2.10.56"; return 0; }
+ [[ "$OST1_VERSION" -ge $(version_code 2.10.56) ]] ||
+ skip "Need OST version at least 2.10.56"
do_facet ost1 lctl set_param ost.OSS.ost_io.nrs_policies="tbf\ nid"
do_facet ost1 lctl set_param ost.OSS.ost_io.nrs_policies="tbf"
run_test 77l "check the output of NRS policies for generic TBF"
test_77m() {
- if [ $(lustre_version_code ost1) -lt $(version_code 2.9.54) ]; then
+ if [ "$OST1_VERSION" -lt $(version_code 2.9.54) ]; then
skip "Need OST version at least 2.9.54"
- return 0
fi
local dir=$DIR/$tdir
run_test 77m "check NRS Delay slows write RPC processing"
test_77n() { #LU-10802
- if [ $(lustre_version_code ost1) -lt $(version_code 2.10.58) ]; then
+ if [ "$OST1_VERSION" -lt $(version_code 2.10.58) ]; then
skip "Need OST version at least 2.10.58"
- return 0
fi
# Configure jobid_var
run_test 81b "rename under striped directory doesn't deadlock"
test_82() {
- [[ $(lustre_version_code $SINGLEMDS) -gt $(version_code 2.6.91) ]] ||
- { skip "Need MDS version at least 2.6.92"; return 0; }
+ [[ "$MDS1_VERSION" -gt $(version_code 2.6.91) ]] ||
+ skip "Need MDS version at least 2.6.92"
# Client 1 creates a file.
multiop_bg_pause $DIR1/$tfile O_ac || error "multiop_bg_pause 1"
mkdir -p $DIR1/$tfile-1/
mkdir -p $DIR2/$tfile-2/
- local old_rr=$(do_facet $SINGLEMDS lctl get_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' | sed -e 's/%//')
- do_facet $SINGLEMDS lctl set_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' 100
+ local old_rr=$(do_facet $SINGLEMDS "$LCTL get_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr" | sed -e 's/%//')
+ do_facet $SINGLEMDS "$LCTL set_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr=100"
#define OBD_FAIL_MDS_LOV_CREATE_RACE 0x163
- do_facet $SINGLEMDS "lctl set_param fail_loc=0x00000163"
+ do_facet $SINGLEMDS "$LCTL set_param fail_loc=0x00000163"
$LFS setstripe -c -1 $DIR1/$tfile-1/file1 &
local PID1=$!
local PID2=$!
wait $PID2
wait $PID1
- do_facet $SINGLEMDS "lctl set_param fail_loc=0x0"
- do_facet $SINGLEMDS "lctl set_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' $old_rr"
+ do_facet $SINGLEMDS "$LCTL set_param fail_loc=0x0"
+ do_facet $SINGLEMDS "$LCTL set_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr=$old_rr"
$LFS getstripe $DIR1/$tfile-1/file1
rc1=$($LFS getstripe -q $DIR1/$tfile-1/file1 |
}
run_test 93 "alloc_rr should not allocate on same ost"
+test_94() {
+ $LCTL set_param osc.*.idle_timeout=0
+ dd if=/dev/zero of=$DIR2/$tfile bs=4k count=2 conv=fsync
+
+ local before=$(date +%s)
+ local evict
+
+ $LCTL mark write
+#define OBD_FAIL_LDLM_PAUSE_CANCEL 0x312
+ $LCTL set_param fail_val=5 fail_loc=0x80000312
+ dd if=/dev/zero of=$DIR/$tfile conv=notrunc oflag=append bs=4k count=1 &
+ local pid=$!
+ sleep 2
+
+#define OBD_FAIL_LDLM_PAUSE_CANCEL_LOCAL 0x329
+ $LCTL set_param fail_val=6 fail_loc=0x80000329
+ $LCTL mark kill $pid
+ kill -ALRM $pid
+
+ dd if=/dev/zero of=$DIR2/$tfile conv=notrunc oflag=append bs=4k count=1
+
+ wait $pid
+ dd if=/dev/zero of=$DIR/$tfile bs=4k count=1 conv=fsync
+
+ evict=$(do_facet client $LCTL get_param \
+ osc.$FSNAME-OST*-osc-*/state |
+ awk -F"[ [,]" '/EVICTED ]$/ { if (t<$5) {t=$5;} } END { print t }')
+
+ [ -z "$evict" ] || [[ $evict -le $before ]] ||
+ (do_facet client $LCTL get_param \
+ osc.$FSNAME-OST*-osc-*/state;
+ error "eviction happened: $evict before:$before")
+ $LCTL set_param osc.*.idle_timeout=debug
+}
+run_test 94 "signal vs CP callback race"
+
# Data-on-MDT tests
test_100a() {
skip "Reserved for glimpse-ahead" && return
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
skip "Need MDS version at least 2.10.55"
mkdir -p $DIR/$tdir
run_test 100a "DoM: glimpse RPCs for stat without IO lock (DoM only file)"
test_100b() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
skip "Need MDS version at least 2.10.55"
mkdir -p $DIR/$tdir
run_test 100b "DoM: no glimpse RPC for stat with IO lock (DoM only file)"
test_100c() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
skip "Need MDS version at least 2.10.55"
mkdir -p $DIR/$tdir
run_test 100c "DoM: write vs stat without IO lock (combined file)"
test_100d() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
skip "Need MDS version at least 2.10.55"
mkdir -p $DIR/$tdir
run_test 100d "DoM: write+truncate vs stat without IO lock (combined file)"
test_100e() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.11.50) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.11.50) ] &&
skip "Need MDS version at least 2.11.50"
local dom=$DIR/$tdir/dom
run_test 100e "DoM: read on open and file size"
test_101a() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
- skip "Need MDS version at least 2.10.55" && return
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
+ skip "Need MDS version at least 2.10.55"
$LFS setstripe -E 1024K -L mdt -E EOF $DIR1/$tfile
# to get layout
run_test 101a "Discard DoM data on unlink"
test_101b() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
- skip "Need MDS version at least 2.10.55" && return
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
+ skip "Need MDS version at least 2.10.55"
$LFS setstripe -E 1024K -L mdt -E EOF $DIR1/$tfile
touch $DIR1/${tfile}_2
run_test 101b "Discard DoM data on rename"
test_101c() {
- [ $(lustre_version_code $SINGLEMDS) -lt $(version_code 2.10.55) ] &&
- skip "Need MDS version at least 2.10.55" && return
+ [ "$MDS1_VERSION" -lt $(version_code 2.10.55) ] &&
+ skip "Need MDS version at least 2.10.55"
$LFS setstripe -E 1024K -L mdt -E EOF $DIR1/$tfile
# to get layout
# This test opens the file normally on $DIR1, which is on one mount, and then
# opens it by handle on $DIR2, which is on a different mount.
test_102() {
- [ $MDS1_VERSION -lt $(version_code 2.11.57) ] &&
+ [ "$MDS1_VERSION" -lt $(version_code 2.11.57) ] &&
skip "Needs MDS version 2.11.57 or later"
echo "Test file_handle syscalls" > $DIR/$tfile ||
# Compare file size between first & second mount, ensuring the client correctly
# glimpses even with unused speculative locks - LU-11670
test_103() {
- [ $(lustre_version_code $ost1) -lt $(version_code 2.10.50) ] &&
+ [ $OST1_VERSION -lt $(version_code 2.10.50) ] &&
skip "Lockahead needs OST version at least 2.10.50"
- local testnum=23
+ local locktest=23
test_mkdir -p $DIR/$tdir
do_facet ost1 $LCTL set_param fail_loc=0x415 fail_val=2
echo "Incorrect size expected (no glimpse fix):"
- lockahead_test -d $DIR/$tdir -D $DIR2/$tdir -t $testnum -f $tfile
+ lockahead_test -d $DIR/$tdir -D $DIR2/$tdir -t $locktest -f $tfile
rc=$?
if [ $rc -eq 0 ]; then
echo "This doesn't work 100%, but this is just reproducing the bug, not testing the fix, so OK to not fail test."
do_facet ost1 $LCTL set_param fail_loc=0x214 fail_val=2
# Write commit is still delayed by 2 seconds
- lockahead_test -d $DIR/$tdir -D $DIR2/$tdir -t $testnum -f $tfile
+ lockahead_test -d $DIR/$tdir -D $DIR2/$tdir -t $locktest -f $tfile
rc=$?
- [ $rc -eq 0 ] || error "Lockahead test${testnum} failed, ${rc}"
+ [ $rc -eq 0 ] || error "Lockahead test$locktest failed, $rc"
# guarantee write commit timeout has expired
sleep 2
}
run_test 103 "Test size correctness with lockahead"
+get_stat_xtimes()
+{
+ local xtimes
+
+ xtimes=$(stat -c "%X %Y %Z" $DIR/$tfile)
+
+ echo ${xtimes[*]}
+}
+
+get_mdt_xtimes()
+{
+ local mdtdev=$1
+ local output
+ local xtimes
+
+ output=$(do_facet mds1 "$DEBUGFS -c -R 'stat ROOT/$tfile' $mdtdev")
+ ((xtimes[0]=$(awk -F ':' /atime/'{ print $2 }' <<< "$output")))
+ ((xtimes[1]=$(awk -F ':' /mtime/'{ print $2 }' <<< "$output")))
+ ((xtimes[2]=$(awk -F ':' /ctime/'{ print $2 }' <<< "$output")))
+
+ echo ${xtimes[*]}
+}
+
+check_mdt_xtimes()
+{
+ local mdtdev=$1
+ local xtimes=($(get_stat_xtimes))
+ local mdt_xtimes=($(get_mdt_xtimes $mdtdev))
+
+ echo "STAT a|m|ctime ${xtimes[*]}"
+ echo "MDT a|m|ctime ${xtimes[*]}"
+ [[ ${xtimes[0]} == ${mdt_xtimes[0]} ]] ||
+ error "$DIR/$tfile atime (${xtimes[0]}:${mdt_xtimes[0]}) diff"
+ [[ ${xtimes[1]} == ${mdt_xtimes[1]} ]] ||
+ error "$DIR/$tfile mtime (${xtimes[1]}:${mdt_xtimes[1]}) diff"
+ [[ ${xtimes[2]} == ${mdt_xtimes[2]} ]] ||
+ error "$DIR/$tfile ctime (${xtimes[2]}:${mdt_xtimes[2]}) diff"
+}
+
+test_104() {
+ [ "$mds1_FSTYPE" == "ldiskfs" ] || skip_env "ldiskfs only test"
+ [ $MDS1_VERSION -lt $(version_code 2.12.4) ] &&
+ skip "Need MDS version at least 2.12.4"
+
+ local pid
+ local mdtdev=$(mdsdevname ${SINGLEMDS//mds/})
+ local atime_diff=$(do_facet $SINGLEMDS \
+ lctl get_param -n mdd.*MDT0000*.atime_diff)
+
+ do_facet $SINGLEMDS \
+ lctl set_param -n mdd.*MDT0000*.atime_diff=0
+
+ stack_trap "do_facet $SINGLEMDS \
+ lctl set_param -n mdd.*MDT0000*.atime_diff=$atime_diff" EXIT
+
+ dd if=/dev/zero of=$DIR/$tfile bs=1k count=1 conv=notrunc
+ check_mdt_xtimes $mdtdev
+ sleep 2
+
+ dd if=/dev/zero of=$DIR/$tfile bs=1k count=1 conv=notrunc
+ check_mdt_xtimes $mdtdev
+ sleep 2
+ $MULTIOP $DIR2/$tfile Oz8192w8192_c &
+ pid=$!
+ sleep 2
+ dd if=/dev/zero of=$DIR/$tfile bs=1k count=1 conv=notrunc
+ sleep 2
+ kill -USR1 $pid && wait $pid || error "multiop failure"
+ check_mdt_xtimes $mdtdev
+
+ local xtimes
+ local mdt_xtimes
+
+ # Verify mtime/ctime is NOT upated on MDS when there is no modification
+ # on the client side
+ xtimes=($(get_stat_xtimes))
+ $MULTIOP $DIR/$tfile O_c &
+ pid=$!
+ sleep 2
+ kill -USR1 $pid && wait $pid || error "multiop failure"
+ mdt_xtimes=($(get_mdt_xtimes $mdtdev))
+ [[ ${xtimes[1]} == ${mdt_xtimes[1]} ]] ||
+ error "$DIR/$tfile mtime (${xtimes[1]}:${mdt_xtimes[1]}) diff"
+ [[ ${xtimes[2]} == ${mdt_xtimes[2]} ]] ||
+ error "$DIR/$tfile ctime (${xtimes[2]}:${mdt_xtimes[2]}) diff"
+ check_mdt_xtimes $mdtdev
+
+ sleep 2
+ # Change ctime via chmod
+ $MULTIOP $DIR/$tfile o_tc &
+ pid=$!
+ sleep 2
+ kill -USR1 $pid && wait $pid || error "multiop failure"
+ check_mdt_xtimes $mdtdev
+}
+run_test 104 "Verify that MDS stores atime/mtime/ctime during close"
+
+test_105() {
+ test_mkdir -p $DIR/$tdir
+ echo test > $DIR/$tdir/$tfile
+ $LCTL set_param fail_loc=0x416
+ cancel_lru_locks osc & sleep 1
+ fsize1=$(stat -c %s $DIR2/$tdir/$tfile)
+ wait
+ [[ $fsize1 = 5 ]] || error "Glimpse returned wrong file size $fsize1"
+}
+run_test 105 "Glimpse and lock cancel race"
+
log "cleanup: ======================================================"
# kill and wait in each test only guarentee script finish, but command in script