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"}
24 add_mds mds --dev $MDSDEV --size $MDSSIZE
25 add_lov lov1 mds --stripe_sz $STRIPE_BYTES\
26 --stripe_cnt $STRIPES_PER_OBJ --stripe_pattern 0
27 add_ost ost --lov lov1 --dev $OSTDEV --size $OSTSIZE
28 add_client client mds --lov lov1 --path $MOUNT
34 add_mds mds2 --dev $MDSDEV --size $MDSSIZE
35 add_lov lov2 mds2 --stripe_sz $STRIPE_BYTES\
36 --stripe_cnt $STRIPES_PER_OBJ --stripe_pattern 0
37 add_ost ost2 --lov lov2 --dev $OSTDEV --size $OSTSIZE
38 add_client client mds2 --lov lov2 --path $MOUNT2
42 echo "start mds service on `facet_active_host mds`"
43 start mds --reformat $MDSLCONFARGS > /dev/null || return 94
46 echo "stop mds service on `facet_active_host mds`"
47 stop mds $@ > /dev/null || return 97
51 echo "start ost service on `facet_active_host ost`"
52 start ost --reformat $OSTLCONFARGS > /dev/null || return 95
56 echo "stop ost service on `facet_active_host ost`"
57 stop ost $@ > /dev/null || return 98
62 echo "mount lustre on ${MOUNTPATH}....."
63 zconf_mount $MOUNTPATH > /dev/null || return 96
68 echo "umount lustre on ${MOUNTPATH}....."
69 zconf_umount $MOUNTPATH > /dev/null || return 97
72 manual_umount_client(){
73 echo "manual umount lustre on ${MOUNTPATH}...."
74 do_facet client "umount $MOUNT"
84 umount_client $MOUNT || return -200
85 stop_mds || return -201
86 stop_ost || return -202
90 do_facet client "touch $DIR/a" || return 71
91 do_facet client "rm $DIR/a" || return 72
92 echo "setup single mount lustre success"
96 do_facet client "touch $DIR/a" || return 71
97 do_facet client "rm $DIR/a" || return 72
98 do_facet client "touch $DIR2/a" || return 73
99 do_facet client "rm $DIR2/a" || return 74
100 echo "setup double mount lustre success"
105 #create single point mountpoint
114 check_mount || return 41
117 run_test 0 "single mount setup"
121 echo "start ost second time..."
122 start ost --reformat $OSTLCONFARGS > /dev/null
125 check_mount || return 42
128 run_test 1 "start up ost twice"
133 echo "start mds second time.."
134 start mds --reformat $MDSLCONFARGS > /dev/null
137 check_mount || return 43
140 run_test 2 "start up mds twice"
146 check_mount || return 44
151 run_test 3 "mount client twice"
155 touch $DIR/$tfile || return 85
158 # cleanup may return an error from the failed
159 # disconnects; for now I'll consider this successful
160 # if all the modules have unloaded.
162 lsmod | grep -q portals && return 1
166 run_test 4 "force cleanup ost, then cleanup"
170 touch $DIR/$tfile || return 86
171 stop_mds ${FORCE} || return 98
173 # cleanup may return an error from the failed
174 # disconnects; for now I'll consider this successful
175 # if all the modules have unloaded.
177 lsmod | grep -q portals && return 1
181 run_test 5 "force cleanup mds, then cleanup"
186 mount_client ${MOUNT} || return 87
187 touch $DIR/a || return 86
190 run_test 6 "manual umount, then mount again"
197 run_test 7 "manual umount, then cleanup"
206 check_mount2 || return 45
208 umount_client $MOUNT2
213 run_test 8 "double mount setup"
216 # backup the old values of PTLDEBUG and SUBSYSTEM
217 OLDPTLDEBUG=$PTLDEBUG
218 OLDSUBSYSTEM=$SUBSYSTEM
220 # generate new configuration file with lmc --ptldebug and --subsystem
225 # check the result of lmc --ptldebug/subsystem
229 CHECK_PTLDEBUG="`cat /proc/sys/portals/debug`"
230 if [ $CHECK_PTLDEBUG = "1" ]; then
231 echo "lmc --debug success"
233 echo "lmc --debug: want 1, have $CHECK_PTLDEBUG"
236 CHECK_SUBSYSTEM="`cat /proc/sys/portals/subsystem_debug`"
237 if [ $CHECK_SUBSYSTEM = "2" ]; then
238 echo "lmc --subsystem success"
240 echo "lmc --subsystem: want 2, have $CHECK_SUBSYSTEM"
243 check_mount || return 41
246 # the new PTLDEBUG/SUBSYSTEM used for lconf --ptldebug/subsystem
247 PTLDEBUG="inode+trace"
250 # check lconf --ptldebug/subsystem overriding lmc --ptldebug/subsystem
253 CHECK_PTLDEBUG="`do_facet mds cat /proc/sys/portals/debug`"
254 if [ $CHECK_PTLDEBUG = "3" ]; then
255 echo "lconf --debug success"
257 echo "lconf --debug: want 3, have $CHECK_PTLDEBUG"
260 CHECK_SUBSYSTEM="`do_facet mds cat /proc/sys/portals/subsystem_debug`"
261 if [ $CHECK_SUBSYSTEM = "20" ]; then
262 echo "lconf --subsystem success"
264 echo "lconf --subsystem: want 20, have $CHECK_SUBSYSTEM"
268 check_mount || return 41
271 # resume the old configuration
272 PTLDEBUG=$OLDPTLDEBUG
273 SUBSYSTEM=$OLDSUBSYSTEM
277 run_test 9 "test --ptldebug and --subsystem for lmc and lconf"
280 OLDXMLCONFIG=$XMLCONFIG
281 XMLCONFIG="broken.xml"
282 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
284 do_lmc --add node --node $SAMENAME
285 do_lmc --add net --node $SAMENAME --nid $SAMENAME --nettype tcp
286 do_lmc --add mds --node $SAMENAME --mds $SAMENAME --nid $SAMENAME \
287 --fstype ext3 --dev /dev/mds1 || return $?
288 do_lmc --add lov --lov lov1 --mds $SAMENAME --stripe_sz 65536 \
289 --stripe_cnt 1 --stripe_pattern 0 || return $?
291 XMLCONFIG=$OLDXMLCONFIG
293 run_test 10 "use lmc with the same name for node and mds"
296 OLDXMLCONFIG=$XMLCONFIG
297 XMLCONFIG="conf11.xml"
299 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
300 add_mds mds --dev $MDSDEV --size $MDSSIZE
301 add_ost ost --dev $OSTDEV --size $OSTSIZE
302 add_client client mds --path $MOUNT --ost ost_svc || return $?
303 echo "Default lov config success!"
305 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
306 add_mds mds --dev $MDSDEV --size $MDSSIZE
307 add_ost ost --dev $OSTDEV --size $OSTSIZE
308 add_client client mds --path $MOUNT && return $?
309 echo "--add mtpt with neither --lov nor --ost will return error"
313 XMLCONFIG=$OLDXMLCONFIG
315 run_test 11 "use default lov configuration (should return error)"
318 OLDXMLCONFIG=$XMLCONFIG
319 XMLCONFIG="batch.xml"
320 BATCHFILE="batchfile"
323 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
324 [ -f "$BATCHFILE" ] && rm -f $BATCHFILE
325 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
326 echo "--add mds --node localhost --mds mds1 --mkfsoptions \"-I 128\"" >> $BATCHFILE
327 # --mkfsoptions "-I 128"
328 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
329 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
330 echo "matched double quote success"
332 echo "matched double quote fail"
337 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
338 echo "--add mds --node localhost --mds mds1 --mkfsoptions \"-I 128" >> $BATCHFILE
339 # --mkfsoptions "-I 128
340 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
341 echo "unmatched double quote should return error"
345 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
346 echo "--add mds --node localhost --mds mds1 --mkfsoptions '-I 128'" >> $BATCHFILE
347 # --mkfsoptions '-I 128'
348 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
349 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
350 echo "matched single quote success"
352 echo "matched single quote fail"
357 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
358 echo "--add mds --node localhost --mds mds1 --mkfsoptions '-I 128" >> $BATCHFILE
359 # --mkfsoptions '-I 128
360 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
361 echo "unmatched single quote should return error"
365 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
366 echo "--add mds --node localhost --mds mds1 --mkfsoptions \-\I\ \128" >> $BATCHFILE
367 # --mkfsoptions \-\I\ \128
368 do_lmc -m $XMLCONFIG --batch $BATCHFILE || return $?
369 if [ `sed -n '/>-I 128</p' $XMLCONFIG | wc -l` -eq 1 ]; then
370 echo "backslash followed by a whitespace/letter success"
372 echo "backslash followed by a whitespace/letter fail"
377 echo "--add net --node localhost --nid localhost.localdomain --nettype tcp" > $BATCHFILE
378 echo "--add mds --node localhost --mds mds1 --mkfsoptions -I\ 128\\" >> $BATCHFILE
379 # --mkfsoptions -I\ 128\
380 do_lmc -m $XMLCONFIG --batch $BATCHFILE && return $?
381 echo "backslash followed by nothing should return error"
384 XMLCONFIG=$OLDXMLCONFIG
386 run_test 12 "lmc --batch, with single/double quote, backslash in batchfile"
389 OLDXMLCONFIG=$XMLCONFIG
390 XMLCONFIG="conf13-1.xml"
391 SECONDXMLCONFIG="conf13-2.xml"
393 # check long uuid will be truncated properly and uniquely
394 echo "To generate XML configuration file(with long ost name): $XMLCONFIG"
395 [ -f "$XMLCONFIG" ] && rm -f $XMLCONFIG
396 do_lmc --add net --node localhost --nid localhost.localdomain --nettype tcp
397 do_lmc --add mds --node localhost --mds mds1_name_longer_than_31characters
398 do_lmc --add mds --node localhost --mds mds2_name_longer_than_31characters
399 if [ ! -f "$XMLCONFIG" ]; then
400 echo "Error:no file $XMLCONFIG created!"
403 EXPECTEDMDS1UUID="e_longer_than_31characters_UUID"
404 EXPECTEDMDS2UUID="longer_than_31characters_UUID_2"
405 FOUNDMDS1UUID=`awk -F"'" '/<mds uuid=/{print $2}' $XMLCONFIG | sed -n '1p'`
406 FOUNDMDS2UUID=`awk -F"'" '/<mds uuid=/{print $2}' $XMLCONFIG | sed -n '2p'`
407 if [ $EXPECTEDMDS1UUID != $FOUNDMDS1UUID ]; then
408 echo "Error:expected uuid for mds1: $EXPECTEDMDS1UUID; found: $FOUNDMDS1UUID"
411 if [ $EXPECTEDMDS2UUID != $FOUNDMDS2UUID ]; then
412 echo "Error:expected uuid for mds2: $EXPECTEDMDS2UUID; found: $FOUNDMDS2UUID"
415 echo "Success:long uuid truncated successfully and being unique."
417 # check multiple invocations for lmc generate same XML configuration file
419 echo "Generate the first XML configuration file"
421 echo "mv $XMLCONFIG to $SECONDXMLCONFIG"
422 mv $XMLCONFIG $SECONDXMLCONFIG || return $?
423 echo "Generate the second XML configuration file"
425 if [ `diff $XMLCONFIG $SECONDXMLCONFIG | wc -l` -eq 0 ]; then
426 echo "Success:multiple invocations for lmc generate same XML file"
428 echo "Error: multiple invocations for lmc generate different XML file"
433 rm -f $SECONDXMLCONFIG
434 XMLCONFIG=$OLDXMLCONFIG
436 run_test 13 "check new_uuid of lmc operating correctly"