local wait_timeout=200
local wait_start=$SECONDS
local wait_end=$((wait_start + wait_timeout))
+ local sleep_time=100000 # 0.1 second
while ((SECONDS < wait_end)); do
- sleep 2
if ! search_copytools $hosts; then
echo "copytools stopped in $((SECONDS - wait_start))s"
return 0
fi
echo "copytools still running on $hosts"
+ usleep $sleep_time
+ [ $sleep_time -lt 32000000 ] && # 3.2 seconds
+ sleep_time=$(bc <<< "$sleep_time * 2")
done
# try to dump Copytool's stack
local agent=$(facet_active_host $facet)
- if [[ -z "$arc_id" ]] &&
- do_facet $facet "pkill -CONT -x $HSMTOOL_BASE"; then
- echo "Only wakeup running copytool $facet on $agent"
- return 0
- fi
-
if $HSM_ARCHIVE_PURGE; then
echo "Purging archive on $agent"
do_facet $facet "rm -rf $hsm_root/$HSMTMP/*"
echo "Copytool is suspended on $agents"
}
+copytool_continue() {
+ local agents=${1:-$(facet_active_host $SINGLEAGT)}
+
+ do_nodesv $agents "pkill -CONT -x $HSMTOOL_BASE" || return 0
+ echo "Copytool is continued on $agents"
+}
+
copytool_remove_backend() {
local fid=$1
local be=$(do_facet $SINGLEAGT find $HSM_ARCHIVE -name $fid)
[[ $blksz -gt 0 ]] || error "Invalid stripe size"
cleanup_large_files
- check_enough_free_space $fsize $blksz
- [ $? != 0 ] && return $?
+ check_enough_free_space $fsize $blksz || return $?
dd if=/dev/zero of=$file2 count=$fsize bs=$blksz conv=fsync ||
file_creation_failure dd $file2 $?
path2fid $1 || error "cannot get fid on $1"
"awk -vn=0 '/'$fid'.*action='$request'/ {n++}; END {print n}'"
}
+# Ensure the number of HSM request for a given FID is correct
+# assert_request_count FID REQUEST_TYPE COUNT [ERROR_MSG]
+assert_request_count() {
+ local request_count=$(get_request_count $1 $2)
+ local default_error_msg=("expected $3 '$2' request(s) for '$1', found "
+ "'$request_count'")
+ [ $request_count -eq $3 ] || error "${4:-"${default_error_msg[@]}"}"
+}
+
wait_all_done() {
local timeout=$1
local fid=$2
cdt_set_mount_state enabled
cdt_check_state enabled
-echo "Start copytool"
-copytool_setup
-
echo "Set sanity-hsm HSM policy"
cdt_set_sanity_policy
local f=$DIR/$tdir/$tfile
local fid=$(make_small $f)
+ copytool_setup
+
$LFS hsm_archive $f || error "could not archive file"
wait_request_state $fid ARCHIVE SUCCEED
check_hsm_flags $f "0x0000000d"
$MMAP_CAT $f > /dev/null || error "failed mmap & cat release file"
+
+ copytool_cleanup
}
run_test 1a "mmap & cat a HSM released file"
+test_1b() {
+ mkdir -p $DIR/$tdir
+ $LFS setstripe -E 1M -E 64M -c 2 -E -1 -c 4 $DIR/$tdir ||
+ error "failed to set default stripe"
+ local f=$DIR/$tdir/$tfile
+ rm -f $f
+
+ dd if=/dev/random of=$f bs=1M count=1 conv=sync ||
+ error "failed to create file"
+ local fid=$(path2fid $f)
+
+ copytool_setup
+
+ echo "archive $f"
+ $LFS hsm_archive $f || error "could not archive file"
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ echo "release $f"
+ $LFS hsm_release $f || error "could not release file"
+ echo "verify released state: "
+ check_hsm_flags $f "0x0000000d" && echo "pass"
+
+ echo "restore $f"
+ $LFS hsm_restore $f || error "could not restore file"
+ wait_request_state $fid RESTORE SUCCEED
+ echo "verify restored state: "
+ check_hsm_flags $f "0x00000009" && echo "pass"
+
+ copytool_cleanup
+}
+run_test 1b "Archive, Release & Restore composite file"
+
test_2() {
mkdir -p $DIR/$tdir
local f=$DIR/$tdir/$tfile
cleanup_test_24d() {
trap 0
mount -o remount,rw $MOUNT2
+ zconf_umount $(facet_host $SINGLEAGT) "$MOUNT3"
}
test_24d() {
local fid1
local fid2
- copytool_setup
-
mkdir -p $DIR/$tdir
rm -f $file1
fid1=$(make_small $file1)
+ echo $fid1
+ $LFS getstripe $file1
+
trap cleanup_test_24d EXIT
+ zconf_mount $(facet_host $SINGLEAGT) "$MOUNT3" ||
+ error "cannot mount '$MOUNT3' on '$SINGLEAGT'"
+ copytool_setup $SINGLEAGT "$MOUNT3" ||
+ error "unable to setup a copytool for the test"
mount -o remount,ro $MOUNT2
+ do_nodes $(comma_list $(nodes_list)) $LCTL clear
+ start_full_debug_logging
+
fid2=$(path2fid $file2)
[ "$fid1" == "$fid2" ] ||
error "FID mismatch '$fid1' != '$fid2'"
error "archive should fail on read-only mount"
check_hsm_flags $file1 "0x00000000"
- $LFS hsm_archive $file1
+ $LFS hsm_archive $file1 || error "Fail to archive $file1"
wait_request_state $fid1 ARCHIVE SUCCEED
+ stop_full_debug_logging
+
$LFS hsm_release $file1
$LFS hsm_restore $file2
wait_request_state $fid1 RESTORE SUCCEED
}
run_test 26 "Remove the archive of a valid file"
+cleanup_test_26a() {
+ trap 0
+ set_hsm_param remove_archive_on_last_unlink 0
+ set_hsm_param loop_period $orig_loop_period
+ set_hsm_param grace_delay $orig_grace_delay
+ copytool_cleanup
+}
+
+test_26a() {
+ local raolu=$(get_hsm_param remove_archive_on_last_unlink)
+ [[ $raolu -eq 0 ]] || error "RAoLU policy should be off"
+
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ local f2=$DIR/$tdir/${tfile}_2
+ local fid2=$(copy_file /etc/passwd $f2)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f2
+ wait_request_state $fid2 ARCHIVE SUCCEED
+
+ local f3=$DIR/$tdir/${tfile}_3
+ local fid3=$(copy_file /etc/passwd $f3)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f3
+ wait_request_state $fid3 ARCHIVE SUCCEED
+
+ trap cleanup_test_26a EXIT
+
+ # set a long grace_delay vs short loop_period
+ local orig_loop_period=$(get_hsm_param loop_period)
+ local orig_grace_delay=$(get_hsm_param grace_delay)
+ set_hsm_param loop_period 10
+ set_hsm_param grace_delay 100
+
+ rm -f $f
+
+ set_hsm_param remove_archive_on_last_unlink 1
+
+ ln "$f3" "$f3"_bis || error "Unable to create hard-link"
+ rm -f $f3
+
+ rm -f $f2
+
+ set_hsm_param remove_archive_on_last_unlink 0
+
+ wait_request_state $fid2 REMOVE SUCCEED
+
+ assert_request_count $fid REMOVE 0 \
+ "Unexpected archived data remove request for $f"
+ assert_request_count $fid3 REMOVE 0 \
+ "Unexpected archived data remove request for $f3"
+
+ cleanup_test_26a
+}
+run_test 26a "Remove Archive On Last Unlink (RAoLU) policy"
+
+cleanup_test_26b() {
+ trap 0
+ set_hsm_param remove_archive_on_last_unlink 0
+ copytool_cleanup
+}
+
+test_26b() {
+
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ trap cleanup_test_26b EXIT
+
+ set_hsm_param remove_archive_on_last_unlink 1
+
+ cdt_shutdown
+ cdt_check_state stopped
+
+ rm -f $f
+
+ set_hsm_param remove_archive_on_last_unlink 0
+
+ wait_request_state $fid REMOVE WAITING
+
+ cdt_enable
+ # copytool must re-register
+ kill_copytools
+ wait_copytools || error "copytool failed to stop"
+ HSM_ARCHIVE_PURGE=false copytool_setup
+
+ wait_request_state $fid REMOVE SUCCEED
+
+ cleanup_test_26b
+}
+run_test 26b "RAoLU policy when CDT off"
+
+cleanup_test_26c() {
+ trap 0
+ set_hsm_param remove_archive_on_last_unlink 0
+ set_hsm_param loop_period $orig_loop_period
+ set_hsm_param grace_delay $orig_grace_delay
+ copytool_cleanup
+}
+
+test_26c() {
+
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ local f2=$DIR/$tdir/${tfile}_2
+ local fid2=$(copy_file /etc/passwd $f2)
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f2
+ wait_request_state $fid2 ARCHIVE SUCCEED
+
+ trap cleanup_test_26c EXIT
+
+ # set a long grace_delay vs short loop_period
+ local orig_loop_period=$(get_hsm_param loop_period)
+ local orig_grace_delay=$(get_hsm_param grace_delay)
+ set_hsm_param loop_period 10
+ set_hsm_param grace_delay 100
+
+ set_hsm_param remove_archive_on_last_unlink 1
+
+ multiop_bg_pause $f O_c || error "open $f failed"
+ local pid=$!
+
+ rm -f $f
+ rm -f $f2
+
+ wait_request_state $fid2 REMOVE SUCCEED
+ assert_request_count $fid REMOVE 0 \
+ "Unexpected archived data remove request for $f"
+
+ kill -USR1 $pid || error "multiop early exit"
+ # should reach autotest timeout if multiop fails to trap
+ # signal, close file, and exit ...
+ wait $pid || error
+
+ set_hsm_param remove_archive_on_last_unlink 0
+
+ wait_request_state $fid REMOVE SUCCEED
+
+ cleanup_test_26c
+}
+run_test 26c "RAoLU effective when file closed"
+
+cleanup_test_26d() {
+ trap 0
+ set_hsm_param remove_archive_on_last_unlink 0
+ set_hsm_param loop_period $orig_loop_period
+ set_hsm_param grace_delay $orig_grace_delay
+ copytool_cleanup
+}
+
+test_26d() {
+
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/motd $f 1)
+
+ $LFS hsm_archive $f || error "could not archive file"
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ trap cleanup_test_26d EXIT
+
+ # set a long grace_delay vs short loop_period
+ local orig_loop_period=$(get_hsm_param loop_period)
+ local orig_grace_delay=$(get_hsm_param grace_delay)
+ set_hsm_param loop_period 10
+ set_hsm_param grace_delay 100
+
+ set_hsm_param remove_archive_on_last_unlink 1
+
+ multiop_bg_pause $f O_c || error "multiop failed"
+ local MULTIPID=$!
+
+ rm -f $f
+
+ mds_evict_client
+
+ set_hsm_param remove_archive_on_last_unlink 0
+
+ wait_request_state $fid REMOVE SUCCEED
+
+ client_up || client_up || true
+
+ kill -USR1 $MULTIPID
+ wait $MULTIPID || error "multiop close failed"
+
+ cleanup_test_26d
+}
+run_test 26d "RAoLU when Client eviction"
+
test_27a() {
# test needs a running copytool
copytool_setup
rm -f $file
- $LFS hsm_remove -a 0 $fid
+ $LFS hsm_remove --mntpath "$MOUNT" -a 0 $fid ||
+ error "cannot hsm_remove '$fid'"
# give time for CDT to handle remove request and create broadcasted
sleep 2
}
run_test 60 "Changing progress update interval from default"
+test_61() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+ cdt_disable
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ rm -f $f
+ cdt_enable
+ wait_request_state $fid ARCHIVE FAILED
+
+ copytool_cleanup
+}
+run_test 61 "Waiting archive of a removed file should fail"
+
test_70() {
# test needs a new running copytool
copytool_cleanup
}
run_test 220 "Changelog for archive"
+test_220a() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ changelog_setup
+
+ # block copytool operations to allow for HSM request to be
+ # submitted and file be unlinked (CDT will find object removed)
+ copytool_suspend
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+
+ rm -f $f
+
+ copytool_continue
+
+ wait_request_state $fid ARCHIVE FAILED
+
+ local flags=$(changelog_get_flags ${MDT[0]} HSM $fid | tail -1)
+ changelog_cleanup
+
+ # HE_ARCHIVE|ENOENT
+ local target=0x2
+ [[ $flags == $target ]] || error "Changelog flag is $flags not $target"
+
+ copytool_cleanup
+}
+run_test 220a "Changelog for failed archive"
+
test_221() {
# test needs a running copytool
copytool_setup
}
run_test 222b "Changelog for implicit restore"
+test_222c() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ copy2archive /etc/passwd $tdir/$tfile
+
+ local f=$DIR/$tdir/$tfile
+ import_file $tdir/$tfile $f
+ local fid=$(path2fid $f)
+
+ changelog_setup
+
+ # block copytool operations to allow for HSM request to be
+ # submitted and file be unlinked (CDT will find object removed)
+ copytool_suspend
+
+ $LFS hsm_restore $f
+ rm -f $f
+
+ copytool_continue
+
+ wait_request_state $fid RESTORE FAILED
+
+ local flags=$(changelog_get_flags ${MDT[0]} HSM $fid | tail -1)
+
+ # HE_RESTORE|ENOENT
+ local target=0x82
+ [[ $flags == $target ]] || error "Changelog flag is $flags not $target"
+
+ cleanup
+}
+run_test 222c "Changelog for failed explicit restore"
+
+test_222d() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ changelog_setup
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE SUCCEED
+ $LFS hsm_release $f
+
+ copytool_remove_backend $fid
+ md5sum $f
+
+ wait_request_state $fid RESTORE FAILED
+
+ local flags=$(changelog_get_flags ${MDT[0]} HSM $fid | tail -1)
+
+ # HE_RESTORE|ENOENT
+ local target=0x82
+ [[ $flags == $target ]] || error "Changelog flag is $flags not $target"
+
+ cleanup
+}
+run_test 222d "Changelog for failed implicit restore"
+
test_223a() {
# test needs a running copytool
copytool_setup
}
run_test 224 "Changelog for remove"
+test_224a() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+
+ local f=$DIR/$tdir/$tfile
+ local fid=$(copy_file /etc/passwd $f)
+
+ changelog_setup
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ copytool_remove_backend $fid
+
+ # block copytool operations to allow for HSM request to be
+ # submitted and file be unlinked (CDT will find object removed)
+ copytool_suspend
+
+ $LFS hsm_remove $f
+ rm -f $f
+
+ copytool_continue
+
+ wait_request_state $fid REMOVE FAILED
+
+ local flags=$(changelog_get_flags ${MDT[0]} HSM $fid | tail -n 1)
+
+ # HE_REMOVE|ENOENT
+ local target=0x202
+ [[ $flags == $target ]] ||
+ error "Changelog flag is $flags not $target"
+
+ cleanup
+}
+run_test 224a "Changelog for failed remove"
+
test_225() {
# test needs a running copytool
copytool_setup
}
run_test 251 "Coordinator request timeout"
+test_252() {
+ # test needs a running copytool
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+ local f=$DIR/$tdir/$tfile
+ local fid=$(make_custom_file_for_progress $f 103 1048576)
+
+ cdt_disable
+ # to have a short test
+ local old_to=$(get_hsm_param active_request_timeout)
+ set_hsm_param active_request_timeout 20
+ # to be sure the cdt will wake up frequently so
+ # it will be able to cancel the "old" request
+ local old_loop=$(get_hsm_param loop_period)
+ set_hsm_param loop_period 2
+ cdt_enable
+
+ # clear locks to avoid extra delay caused by flush/cancel
+ # and thus prevent early copytool death to timeout.
+ cancel_lru_locks osc
+
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+ wait_request_state $fid ARCHIVE STARTED
+ rm -f $f
+
+ # wait but less than active_request_timeout+grace_delay
+ sleep 25
+ wait_request_state $fid ARCHIVE CANCELED
+
+ set_hsm_param active_request_timeout $old_to
+ set_hsm_param loop_period $old_loop
+
+ copytool_cleanup
+}
+run_test 252 "Timeout'ed running archive of a removed file should be canceled"
+
test_300() {
# the only way to test ondisk conf is to restart MDS ...
echo "Stop coordinator and remove coordinator state at mount"
done
}
-test_402() {
+test_402a() {
# make sure there is no running copytool
copytool_cleanup
# reactivate MDCs
mdc_change_state $SINGLEAGT "$FSNAME-MDT000." "activate"
}
-run_test 402 "Copytool start fails if all MDTs are inactive"
+run_test 402a "Copytool start fails if all MDTs are inactive"
+
+test_402b() {
+ copytool_setup
+
+ mkdir -p $DIR/$tdir
+
+ local f=$DIR/$tdir/$tfile
+ touch $f || error "touch $f failed"
+ local fid=$(path2fid $f)
+
+#define OBD_FAIL_MDS_HSM_CT_REGISTER_NET 0x14d
+ do_facet $SINGLEAGT lctl set_param fail_loc=0x14d
+ $LFS hsm_archive --archive $HSM_ARCHIVE_NUMBER $f
+
+ # give time for CDT to send request and to keep it for retry
+ wait_for_loop_period
+
+ wait_request_state $fid ARCHIVE WAITING
+
+ do_facet $SINGLEAGT lctl set_param fail_loc=0
+
+ # request should succeed now
+ wait_request_state $fid ARCHIVE SUCCEED
+
+ copytool_cleanup
+}
+run_test 402b "CDT must retry request upon slow start of CT"
test_403() {
[ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return