3 # add uml1 uml2 uml3 in your /etc/hosts
8 PATH=$PWD/$SRCDIR:$SRCDIR:$SRCDIR/../utils:$PATH
10 LUSTRE=${LUSTRE:-`dirname $0`/..}
11 RLUSTRE=${RLUSTRE:-$LUSTRE}
13 . $LUSTRE/tests/test-framework.sh
17 . ${CONFIG:=$LUSTRE/tests/cfg/local.sh}
19 FORCE=${FORCE:-" --force"}
21 if [ "$VERBOSE" == "true" ]; then
24 CMDVERBOSE=" > /dev/null"
30 add_mds mds --dev $MDSDEV --size $MDSSIZE
31 add_lov lov1 mds --stripe_sz $STRIPE_BYTES\
32 --stripe_cnt $STRIPES_PER_OBJ --stripe_pattern 0
33 add_ost ost --lov lov1 --dev $OSTDEV --size $OSTSIZE
34 add_client client mds --lov lov1 --path $MOUNT
40 add_mds mds2 --dev $MDSDEV --size $MDSSIZE
41 add_lov lov2 mds2 --stripe_sz $STRIPE_BYTES\
42 --stripe_cnt $STRIPES_PER_OBJ --stripe_pattern 0
43 add_ost ost2 --lov lov2 --dev $OSTDEV --size $OSTSIZE
44 add_client client mds2 --lov lov2 --path $MOUNT2
48 echo "start mds service on `facet_active_host mds`"
49 start mds --reformat $MDSLCONFARGS $CMDVERBOSE || return 94
52 echo "stop mds service on `facet_active_host mds`"
53 stop mds $@ $CMDVERBOSE || return 97
57 echo "start ost service on `facet_active_host ost`"
58 start ost --reformat $OSTLCONFARGS $CMDVERBOSE || return 95
62 echo "stop ost service on `facet_active_host ost`"
63 stop ost $@ $CMDVERBOSE || return 98
68 echo "mount lustre on ${MOUNTPATH}....."
69 zconf_mount $MOUNTPATH $CMDVERBOSE || return 96
74 echo "umount lustre on ${MOUNTPATH}....."
75 zconf_umount $MOUNTPATH $CMDVERBOSE || return 97
78 manual_umount_client(){
79 echo "manual umount lustre on ${MOUNTPATH}...."
80 do_facet client "umount $MOUNT"
90 umount_client $MOUNT || return 200
91 stop_mds || return 201
92 stop_ost || return 202
93 # catch case where these return just fine, but modules are still not unloaded
94 /sbin/lsmod | grep -q portals
96 echo "modules still loaded..."
102 do_facet client "touch $DIR/a" || return 71
103 do_facet client "rm $DIR/a" || return 72
104 echo "setup single mount lustre success"
108 do_facet client "touch $DIR/a" || return 71
109 do_facet client "rm $DIR/a" || return 72
110 do_facet client "touch $DIR2/a" || return 73
111 do_facet client "rm $DIR2/a" || return 74
112 echo "setup double mount lustre success"
117 #create single point mountpoint
126 check_mount || return 41
129 run_test 0 "single mount setup"
133 echo "start ost second time..."
134 start ost --reformat $OSTLCONFARGS $CMDVERBOSE
137 check_mount || return 42
140 run_test 1 "start up ost twice"
145 echo "start mds second time.."
146 start mds --reformat $MDSLCONFARGS $CMDVERBOSE
149 check_mount || return 43
152 run_test 2 "start up mds twice"
158 check_mount || return 44
163 run_test 3 "mount client twice"
167 touch $DIR/$tfile || return 85
171 # ok for ost to fail shutdown
172 if [ 202 -ne $eno ]; then
177 run_test 4 "force cleanup ost, then cleanup"
181 touch $DIR/$tfile || return 86
182 stop_mds ${FORCE} || return 98
185 # ok for mds to fail shutdown
186 if [ 201 -ne $eno ]; then
191 run_test 5 "force cleanup mds, then cleanup"
196 mount_client ${MOUNT} || return 87
197 touch $DIR/a || return 86
200 run_test 6 "manual umount, then mount again"
207 run_test 7 "manual umount, then cleanup"
216 check_mount2 || return 45
218 umount_client $MOUNT2
223 run_test 8 "double mount setup"
226 # backup the old values of PTLDEBUG and SUBSYSTEM
227 OLDPTLDEBUG=$PTLDEBUG
228 OLDSUBSYSTEM=$SUBSYSTEM
230 # generate new configuration file with lmc --ptldebug and --subsystem
235 # check the result of lmc --ptldebug/subsystem
239 CHECK_PTLDEBUG="`cat /proc/sys/portals/debug`"
240 if [ $CHECK_PTLDEBUG = "1" ]; then
241 echo "lmc --debug success"
243 echo "lmc --debug: want 1, have $CHECK_PTLDEBUG"
246 CHECK_SUBSYSTEM="`cat /proc/sys/portals/subsystem_debug`"
247 if [ $CHECK_SUBSYSTEM = "2" ]; then
248 echo "lmc --subsystem success"
250 echo "lmc --subsystem: want 2, have $CHECK_SUBSYSTEM"
253 check_mount || return 41
256 # the new PTLDEBUG/SUBSYSTEM used for lconf --ptldebug/subsystem
257 PTLDEBUG="inode+trace"
260 # check lconf --ptldebug/subsystem overriding lmc --ptldebug/subsystem
263 CHECK_PTLDEBUG="`do_facet mds cat /proc/sys/portals/debug`"
264 if [ $CHECK_PTLDEBUG = "3" ]; then
265 echo "lconf --debug success"
267 echo "lconf --debug: want 3, have $CHECK_PTLDEBUG"
270 CHECK_SUBSYSTEM="`do_facet mds cat /proc/sys/portals/subsystem_debug`"
271 if [ $CHECK_SUBSYSTEM = "20" ]; then
272 echo "lconf --subsystem success"
274 echo "lconf --subsystem: want 20, have $CHECK_SUBSYSTEM"
278 check_mount || return 41
281 # resume the old configuration
282 PTLDEBUG=$OLDPTLDEBUG
283 SUBSYSTEM=$OLDSUBSYSTEM
287 run_test 9 "test --ptldebug and --subsystem for lmc and lconf"
290 OLDXMLCONFIG=$XMLCONFIG
291 XMLCONFIG="broken.xml"
292 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
294 do_lmc --add node --node $SAMENAME
295 do_lmc --add net --node $SAMENAME --nid $SAMENAME --nettype tcp
296 do_lmc --add mds --node $SAMENAME --mds $SAMENAME --nid $SAMENAME \
297 --fstype ext3 --dev /dev/mds1 || return $?
298 do_lmc --add lov --lov lov1 --mds $SAMENAME --stripe_sz 65536 \
299 --stripe_cnt 1 --stripe_pattern 0 || return $?
301 XMLCONFIG=$OLDXMLCONFIG
303 run_test 10 "use lmc with the same name for node and mds"
306 OLDXMLCONFIG=$XMLCONFIG
307 XMLCONFIG="conf11.xml"
309 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
310 add_mds mds --dev $MDSDEV --size $MDSSIZE
311 add_ost ost --dev $OSTDEV --size $OSTSIZE
312 add_client client mds --path $MOUNT --ost ost_svc || return $?
313 echo "Default lov config success!"
315 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
316 add_mds mds --dev $MDSDEV --size $MDSSIZE
317 add_ost ost --dev $OSTDEV --size $OSTSIZE
318 add_client client mds --path $MOUNT && return $?
319 echo "--add mtpt with neither --lov nor --ost will return error"
323 XMLCONFIG=$OLDXMLCONFIG
325 run_test 11 "use default lov configuration (should return error)"
328 OLDXMLCONFIG=$XMLCONFIG
329 XMLCONFIG="batch.xml"
330 BATCHFILE="batchfile"
333 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
334 [ -f "$BATCHFILE" ] && rm -f $BATCHFILE
335 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
336 echo "--add mds --node localhost --mds mds1 --mkfsoptions \"-I 128\"" >> $BATCHFILE
337 # --mkfsoptions "-I 128"
338 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
339 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
340 echo "matched double quote success"
342 echo "matched double quote fail"
347 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
348 echo "--add mds --node localhost --mds mds1 --mkfsoptions \"-I 128" >> $BATCHFILE
349 # --mkfsoptions "-I 128
350 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
351 echo "unmatched double quote should return error"
355 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
356 echo "--add mds --node localhost --mds mds1 --mkfsoptions '-I 128'" >> $BATCHFILE
357 # --mkfsoptions '-I 128'
358 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
359 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
360 echo "matched single quote success"
362 echo "matched single quote fail"
367 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
368 echo "--add mds --node localhost --mds mds1 --mkfsoptions '-I 128" >> $BATCHFILE
369 # --mkfsoptions '-I 128
370 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
371 echo "unmatched single quote should return error"
375 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
376 echo "--add mds --node localhost --mds mds1 --mkfsoptions \-\I\ \128" >> $BATCHFILE
377 # --mkfsoptions \-\I\ \128
378 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
379 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
380 echo "backslash followed by a whitespace/letter success"
382 echo "backslash followed by a whitespace/letter fail"
387 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
388 echo "--add mds --node localhost --mds mds1 --mkfsoptions -I\ 128\\" >> $BATCHFILE
389 # --mkfsoptions -I\ 128\
390 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
391 echo "backslash followed by nothing should return error"
394 XMLCONFIG=$OLDXMLCONFIG
396 run_test 12 "lmc --batch, with single/double quote, backslash in batchfile"
399 OLDXMLCONFIG=$XMLCONFIG
400 XMLCONFIG="conf13-1.xml"
401 SECONDXMLCONFIG="conf13-2.xml"
403 # check long uuid will be truncated properly and uniquely
404 echo "To generate XML configuration file(with long ost name): $XMLCONFIG"
405 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
406 do_lmc --add net --node localhost --nid localhost.localdomain --nettype tcp
407 do_lmc --add mds --node localhost --mds mds1_name_longer_than_31characters
408 do_lmc --add mds --node localhost --mds mds2_name_longer_than_31characters
409 if [ ! -f "$XMLCONFIG" ]; then
410 echo "Error:no file $XMLCONFIG created!"
413 EXPECTEDMDS1UUID="e_longer_than_31characters_UUID"
414 EXPECTEDMDS2UUID="longer_than_31characters_UUID_2"
415 FOUNDMDS1UUID=`awk -F"'" '/<mds uuid=/{print $2}' $XMLCONFIG | sed -n '1p'`
416 FOUNDMDS2UUID=`awk -F"'" '/<mds uuid=/{print $2}' $XMLCONFIG | sed -n '2p'`
417 if [ $EXPECTEDMDS1UUID != $FOUNDMDS1UUID ]; then
418 echo "Error:expected uuid for mds1: $EXPECTEDMDS1UUID; found: $FOUNDMDS1UUID"
421 if [ $EXPECTEDMDS2UUID != $FOUNDMDS2UUID ]; then
422 echo "Error:expected uuid for mds2: $EXPECTEDMDS2UUID; found: $FOUNDMDS2UUID"
425 echo "Success:long uuid truncated successfully and being unique."
427 # check multiple invocations for lmc generate same XML configuration file
429 echo "Generate the first XML configuration file"
431 echo "mv $XMLCONFIG to $SECONDXMLCONFIG"
432 mv $XMLCONFIG $SECONDXMLCONFIG || return $?
433 echo "Generate the second XML configuration file"
435 if [ `diff $XMLCONFIG $SECONDXMLCONFIG | wc -l` -eq 0 ]; then
436 echo "Success:multiple invocations for lmc generate same XML file"
438 echo "Error: multiple invocations for lmc generate different XML file"
443 rm -f $SECONDXMLCONFIG
444 XMLCONFIG=$OLDXMLCONFIG
446 run_test 13 "check new_uuid of lmc operating correctly"
451 # create xml file with --mkfsoptions for ost
452 echo "create xml file with --mkfsoptions for ost"
453 add_mds mds --dev $MDSDEV --size $MDSSIZE
454 add_lov lov1 mds --stripe_sz $STRIPE_BYTES\
455 --stripe_cnt $STRIPES_PER_OBJ --stripe_pattern 0
456 add_ost ost --lov lov1 --dev $OSTDEV --size $OSTSIZE \
458 add_client client mds --lov lov1 --path $MOUNT
460 FOUNDSTRING=`awk -F"<" '/<mkfsoptions>/{print $2}' $XMLCONFIG`
461 EXPECTEDSTRING="mkfsoptions>-V"
462 if [ $EXPECTEDSTRING != $FOUNDSTRING ]; then
463 echo "Error:expected string: $EXPECTEDSTRING; found: $FOUNDSTRING"
466 echo "Success:mkfsoptions for ost written to xml file correctly."
468 # mount lustre to test lconf mkfsoptions-parsing
472 mount_client $MOUNT || return $?
474 echo "lconf mkfsoptions-parsing for ost success"
478 run_test 14 "test mkfsoptions of ost for lmc and lconf"