run_test 20a "|X| open(O_CREAT), unlink, replay, close (test mds_cleanup_orphans)"
test_20b() { # bug 10480
- BEFOREUSED=`df -P $DIR | tail -1 | awk '{ print $3 }'`
+ local wait_timeout=$((TIMEOUT * 4))
+ local BEFOREUSED
+ local AFTERUSED
- dd if=/dev/zero of=$DIR/$tfile bs=4k count=10000 &
- pid=$!
- while [ ! -e $DIR/$tfile ] ; do
- usleep 60 # give dd a chance to start
- done
-
- $GETSTRIPE $DIR/$tfile || return 1
- rm -f $DIR/$tfile || return 2 # make it an orphan
- mds_evict_client
- client_up || client_up || true # reconnect
+ BEFOREUSED=`df -P $DIR | tail -1 | awk '{ print $3 }'`
+ dd if=/dev/zero of=$DIR/$tfile bs=4k count=10000 &
+ pid=$!
+ while [ ! -e $DIR/$tfile ] ; do
+ usleep 60 # give dd a chance to start
+ done
- fail $SINGLEMDS # start orphan recovery
- wait_recovery_complete $SINGLEMDS || error "MDS recovery not done"
- wait_mds_ost_sync || return 3
- AFTERUSED=`df -P $DIR | tail -1 | awk '{ print $3 }'`
- log "before $BEFOREUSED, after $AFTERUSED"
- (( $AFTERUSED > $BEFOREUSED + $(fs_log_size) )) &&
- error "after $AFTERUSED > before $BEFOREUSED"
- return 0
+ $GETSTRIPE $DIR/$tfile || return 1
+ rm -f $DIR/$tfile || return 2 # make it an orphan
+ mds_evict_client
+ client_up || client_up || true # reconnect
+
+ fail $SINGLEMDS # start orphan recovery
+ wait_recovery_complete $SINGLEMDS || error "MDS recovery not done"
+ wait_delete_completed_mds $wait_timeout || return 3
+ AFTERUSED=$(df -P $DIR | tail -1 | awk '{ print $3 }')
+ log "before $BEFOREUSED, after $AFTERUSED"
+ (( $AFTERUSED > $BEFOREUSED + $(fs_log_size) )) &&
+ error "after $AFTERUSED > before $BEFOREUSED"
+ return 0
}
run_test 20b "write, unlink, eviction, replay, (test mds_cleanup_orphans)"
test_44a() { # was test_44
local at_max_saved=0
- local mdcdev=$($LCTL get_param -n devices |
- awk "/ ${FSNAME}-MDT0000-mdc-/ {print \$1}")
+ local mdcdev=$($LCTL dl |
+ awk "/${FSNAME}-MDT0000-mdc-/ {if (\$2 == \"UP\") {print \$1}}")
[ "$mdcdev" ] || return 2
[ $(echo $mdcdev | wc -w) -eq 1 ] ||
{ echo mdcdev=$mdcdev; $LCTL dl; return 3; }
run_test 44a "race in target handle connect"
test_44b() {
- local mdcdev=$($LCTL get_param -n devices |
- awk "/ ${FSNAME}-MDT0000-mdc-/ {print \$1}")
+ local mdcdev=$($LCTL dl |
+ awk "/${FSNAME}-MDT0000-mdc-/ {if (\$2 == \"UP\") {print \$1}}")
[ "$mdcdev" ] || return 2
[ $(echo $mdcdev | wc -w) -eq 1 ] ||
{ echo mdcdev=$mdcdev; $LCTL dl; return 3; }
}
run_test 57 "test recovery from llog for setattr op"
+cleanup_58() {
+ zconf_umount `hostname` $MOUNT2
+ trap - EXIT
+}
+
#recovery many mds-ost setattr from llog
test_58a() {
mkdir -p $DIR/$tdir
local orig
local new
+ trap cleanup_58 EXIT
+
large_xattr_enabled &&
orig="$(generate_string $(max_xattr_size))" || orig="bar"
[[ "$new" = "$orig" ]] || return 1
rm -f $DIR/$tdir/$tfile
rmdir $DIR/$tdir
- zconf_umount `hostname` $MOUNT2
+ cleanup_58
}
run_test 58b "test replay of setxattr op"
local orig1
local new
+ trap cleanup_58 EXIT
+
if large_xattr_enabled; then
local xattr_size=$(max_xattr_size)
orig="$(generate_string $((xattr_size / 2)))"
[[ "$new" = "$orig1" ]] || return 4
rm -f $DIR/$tdir/$tfile
rmdir $DIR/$tdir
- zconf_umount $HOSTNAME $MOUNT2
+ cleanup_58
}
run_test 58c "resend/reconstruct setxattr op"
#LU-1897 wait for all dbench copies to start
while ! check_for_process $clients dbench; do
elapsed=$(($(date +%s) - start_ts))
- if [ $elapsed -gt $duration]; then
+ if [ $elapsed -gt $duration ]; then
killall_process $clients dbench
error "dbench failed to start on $clients!"
fi
local uuid=$(ostuuid_from_index $i)
for file in f$i all; do
if [[ $dir/$file != $($LFS find --obd $uuid --name $file $dir) ]]; then
- $GETSTRIPE $dir/file
- error wrong stripe: $file, uuid: $uuid
+ $GETSTRIPE $dir/$file
+ error wrong stripe: $file, uuid: $uuid
fi
done
done