From: Elena Gryaznova Date: Wed, 9 Jun 2010 18:36:17 +0000 (+0400) Subject: b=22977 add echoclient async journal regression test to acc-sm obdfilter-survey X-Git-Tag: v1_8_3_54~28 X-Git-Url: https://git.whamcloud.com/?a=commitdiff_plain;h=c37114f174d154f16c3d2d9e9fc46a33ea12a3e9;p=fs%2Flustre-release.git b=22977 add echoclient async journal regression test to acc-sm obdfilter-survey i=Oleg.Drokin --- diff --git a/lustre/tests/obdfilter-survey.sh b/lustre/tests/obdfilter-survey.sh index e260d4e..9ced8ee 100644 --- a/lustre/tests/obdfilter-survey.sh +++ b/lustre/tests/obdfilter-survey.sh @@ -14,6 +14,7 @@ size=${size:-1024} . ${CONFIG:=$LUSTRE/tests/cfg/$NAME.sh} [ "$SLOW" = no ] && { nobjhi=1; thrhi=4; } +thrlo=${thrlo:-$(( thrhi / 2))} # Skip these tests ALWAYS_EXCEPT="$OBDFILTER_SURVEY_EXCEPT" @@ -71,7 +72,7 @@ obdflter_survey_run () { rm -f ${TMP}/obdfilter_survey* local targets=$(obdflter_survey_targets $case) - local cmd="nobjhi=$nobjhi thrhi=$thrhi size=$size case=$case rslt_loc=${TMP} targets=\"$targets\" sh $OBDSURVEY" + local cmd="thrlo=$thrlo nobjhi=$nobjhi thrhi=$thrhi size=$size case=$case rslt_loc=${TMP} targets=\"$targets\" sh $OBDSURVEY" echo + $cmd eval $cmd @@ -82,10 +83,94 @@ test_1a () { } run_test 1a "Object Storage Targets survey" -test_2 () { +print_jbd () { + local file=$1 + local facet=$2 + local varsvc=${facet}_svc + local dev=$(basename $(do_facet $facet lctl get_param -n *.${!varsvc}.mntdev)) + + # ext4: /proc/fs/jbd2/sda1:8/history + # ext3: /proc/fs/jbd/sdb1/history + + do_facet $facet cat /proc/fs/jbd*/${dev}*/$file +} + +check_jbd_values () { + local facet=$1 + local thrhi=$2 + + # last two lines from history + # $4: run >= 5000 + # $8: hndls >= thrhi * 2 + local hist=("$(print_jbd history $facet | tail -3 | head -2)") + echo "$hist" + local run=($(echo "${hist[*]}" | awk '{print $4}')) + local hndls=($(echo "${hist[*]}" | awk '{print $8}')) + + local rc=0 + for (( i=0; i<1; i++)); do + [[ ${run[i]} -lt 5000 ]] && \ + error "$facet: run expected 5000, have ${run[i]}" && rc=1 + [[ ${hndls[i]} -lt $((thrhi * 2)) ]] && \ + error "$facet: hndls expected > $((thrhi * 2)), have ${hndls[i]}" && rc=2 + done + return $rc +} + +check_jbd_values_facets () { + local facets=$1 + local thrhi=$2 + local facet + local rc=0 + for facet in ${facets//,/ }; do + check_jbd_values $facet $thrhi || rc=$((rc+$?)) + done + return $rc +} + +test_1b () { + local param_file=$TMP/$tfile-params + + do_nodesv $(comma_list $(osts_nodes)) lctl get_param obdfilter.${FSNAME}-*.sync_journal + + save_lustre_params $(comma_list $(osts_nodes)) "obdfilter.${FSNAME}-*.sync_journal" >$param_file + do_nodesv $(comma_list $(osts_nodes)) lctl set_param obdfilter.${FSNAME}-*.sync_journal=0 + + thrlo=4 nobjhi=1 thrhi=4 obdflter_survey_run disk + + check_jbd_values_facets $(get_facets OST) 4 || rc=$((rc+$?)) + + restore_lustre_params < $param_file + + rm -f $param_file + return $rc +} +run_test 1b "Object Storage Targets survey, async journal" + +test_2a () { obdflter_survey_run netdisk } -run_test 2 "Stripe F/S over the Network" +run_test 2a "Stripe F/S over the Network" + +test_2b () { + local param_file=$TMP/$tfile-params + + do_nodesv $(comma_list $(osts_nodes)) lctl get_param obdfilter.${FSNAME}-*.sync_journal + + save_lustre_params $(comma_list $(osts_nodes)) "obdfilter.${FSNAME}-*.sync_journal" >$param_file + do_nodesv $(comma_list $(osts_nodes)) lctl set_param obdfilter.${FSNAME}-*.sync_journal=0 + + thrlo=4 nobjhi=1 thrhi=4 obdflter_survey_run netdisk + + check_jbd_values_facets $(get_facets OST) 4 || rc=$((rc+$?)) + + restore_lustre_params < $param_file + + rm -f $param_file + return $rc +} +run_test 2b "Stripe F/S over the Network, async journal" + # README.obdfilter-survey: In network test only automated run is supported. test_3a () {