mirror of
https://github.com/torvalds/linux.git
synced 2026-05-31 10:33:41 +02:00
selftests: ublk: refactor test_loop_08 into separate functions
Encapsulate each test case in its own function for better organization
and maintainability:
- _setup_device(): device and backfile initialization
- _test_fill_and_verify(): initial data population
- _test_corrupted_reftag(): reftag corruption detection test
- _test_corrupted_data(): data corruption detection test
- _test_bad_apptag(): apptag mismatch detection test
Also fix temp file creation to use ${UBLK_TEST_DIR}/fio_err_XXXXX instead of
creating in current directory.
Signed-off-by: Ming Lei <ming.lei@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
5af302a15a
commit
842b6520e5
|
|
@ -13,98 +13,129 @@ if [[ "$fio_version" =~ fio-[0-9]+\.[0-9]+$ ]]; then
|
|||
exit $UBLK_SKIP_CODE
|
||||
fi
|
||||
|
||||
ERR_CODE=0
|
||||
|
||||
# Global variables set during device setup
|
||||
dev_id=""
|
||||
fio_args=""
|
||||
fio_err=""
|
||||
|
||||
_setup_device() {
|
||||
_create_backfile 0 256M
|
||||
_create_backfile 1 32M # 256M * (64 integrity bytes / 512 data bytes)
|
||||
|
||||
local integrity_params="--integrity_capable --integrity_reftag
|
||||
--metadata_size 64 --pi_offset 56 --csum_type t10dif"
|
||||
dev_id=$(_add_ublk_dev -t loop -u $integrity_params "${UBLK_BACKFILES[@]}")
|
||||
_check_add_dev "$TID" $?
|
||||
|
||||
# 1M * (64 integrity bytes / 512 data bytes) = 128K
|
||||
fio_args="--ioengine io_uring --direct 1 --bsrange 512-1M --iodepth 32
|
||||
--md_per_io_size 128K --pi_act 0 --pi_chk GUARD,REFTAG,APPTAG
|
||||
--filename /dev/ublkb$dev_id"
|
||||
|
||||
fio_err=$(mktemp "${UBLK_TEST_DIR}"/fio_err_XXXXX)
|
||||
}
|
||||
|
||||
_test_fill_and_verify() {
|
||||
fio --name fill --rw randwrite $fio_args > /dev/null
|
||||
if [ $? != 0 ]; then
|
||||
echo "fio fill failed"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
fio --name verify --rw randread $fio_args > /dev/null
|
||||
if [ $? != 0 ]; then
|
||||
echo "fio verify failed"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
_test_corrupted_reftag() {
|
||||
local dd_reftag_args="bs=1 seek=60 count=4 oflag=dsync conv=notrunc status=none"
|
||||
local expected_err="REFTAG compare error: LBA: 0 Expected=0, Actual="
|
||||
|
||||
# Overwrite 4-byte reftag at offset 56 + 4 = 60
|
||||
dd if=/dev/urandom "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
|
||||
if [ $? != 0 ]; then
|
||||
echo "dd corrupted_reftag failed"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
if fio --name corrupted_reftag --rw randread $fio_args > /dev/null 2> "$fio_err"; then
|
||||
echo "fio corrupted_reftag unexpectedly succeeded"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio corrupted_reftag message not found: $expected_err"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Reset to 0
|
||||
dd if=/dev/zero "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
|
||||
if [ $? != 0 ]; then
|
||||
echo "dd restore corrupted_reftag failed"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
_test_corrupted_data() {
|
||||
local dd_data_args="bs=512 count=1 oflag=direct,dsync conv=notrunc status=none"
|
||||
local expected_err="Guard compare error: LBA: 0 Expected=0, Actual="
|
||||
|
||||
dd if=/dev/zero "of=${UBLK_BACKFILES[0]}" $dd_data_args
|
||||
if [ $? != 0 ]; then
|
||||
echo "dd corrupted_data failed"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
if fio --name corrupted_data --rw randread $fio_args > /dev/null 2> "$fio_err"; then
|
||||
echo "fio corrupted_data unexpectedly succeeded"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio corrupted_data message not found: $expected_err"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
_test_bad_apptag() {
|
||||
local expected_err="APPTAG compare error: LBA: [0-9]* Expected=4321, Actual=1234"
|
||||
|
||||
if fio --name bad_apptag --rw randread $fio_args --apptag 0x4321 > /dev/null 2> "$fio_err"; then
|
||||
echo "fio bad_apptag unexpectedly succeeded"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio bad_apptag message not found: $expected_err"
|
||||
ERR_CODE=255
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
_prep_test "loop" "end-to-end integrity"
|
||||
|
||||
_create_backfile 0 256M
|
||||
_create_backfile 1 32M # 256M * (64 integrity bytes / 512 data bytes)
|
||||
integrity_params="--integrity_capable --integrity_reftag
|
||||
--metadata_size 64 --pi_offset 56 --csum_type t10dif"
|
||||
dev_id=$(_add_ublk_dev -t loop -u $integrity_params "${UBLK_BACKFILES[@]}")
|
||||
_check_add_dev $TID $?
|
||||
_setup_device
|
||||
|
||||
# 1M * (64 integrity bytes / 512 data bytes) = 128K
|
||||
fio_args="--ioengine io_uring --direct 1 --bsrange 512-1M --iodepth 32
|
||||
--md_per_io_size 128K --pi_act 0 --pi_chk GUARD,REFTAG,APPTAG
|
||||
--filename /dev/ublkb$dev_id"
|
||||
fio --name fill --rw randwrite $fio_args > /dev/null
|
||||
err=$?
|
||||
if [ $err != 0 ]; then
|
||||
echo "fio fill failed"
|
||||
_show_result $TID $err
|
||||
fi
|
||||
|
||||
fio --name verify --rw randread $fio_args > /dev/null
|
||||
err=$?
|
||||
if [ $err != 0 ]; then
|
||||
echo "fio verify failed"
|
||||
_show_result $TID $err
|
||||
fi
|
||||
|
||||
fio_err=$(mktemp fio_err_XXXXX)
|
||||
|
||||
# Overwrite 4-byte reftag at offset 56 + 4 = 60
|
||||
dd_reftag_args="bs=1 seek=60 count=4 oflag=dsync conv=notrunc status=none"
|
||||
dd if=/dev/urandom "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
|
||||
err=$?
|
||||
if [ $err != 0 ]; then
|
||||
echo "dd corrupted_reftag failed"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID $err
|
||||
fi
|
||||
if fio --name corrupted_reftag --rw randread $fio_args > /dev/null 2> "$fio_err"; then
|
||||
echo "fio corrupted_reftag unexpectedly succeeded"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
expected_err="REFTAG compare error: LBA: 0 Expected=0, Actual="
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio corrupted_reftag message not found: $expected_err"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
# Reset to 0
|
||||
dd if=/dev/zero "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
|
||||
err=$?
|
||||
if [ $err != 0 ]; then
|
||||
echo "dd restore corrupted_reftag failed"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID $err
|
||||
fi
|
||||
|
||||
dd_data_args="bs=512 count=1 oflag=direct,dsync conv=notrunc status=none"
|
||||
dd if=/dev/zero "of=${UBLK_BACKFILES[0]}" $dd_data_args
|
||||
err=$?
|
||||
if [ $err != 0 ]; then
|
||||
echo "dd corrupted_data failed"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID $err
|
||||
fi
|
||||
if fio --name corrupted_data --rw randread $fio_args > /dev/null 2> "$fio_err"; then
|
||||
echo "fio corrupted_data unexpectedly succeeded"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
expected_err="Guard compare error: LBA: 0 Expected=0, Actual="
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio corrupted_data message not found: $expected_err"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
|
||||
if fio --name bad_apptag --rw randread $fio_args --apptag 0x4321 > /dev/null 2> "$fio_err"; then
|
||||
echo "fio bad_apptag unexpectedly succeeded"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
expected_err="APPTAG compare error: LBA: [0-9]* Expected=4321, Actual=1234"
|
||||
if ! grep -q "$expected_err" "$fio_err"; then
|
||||
echo "fio bad_apptag message not found: $expected_err"
|
||||
rm -f "$fio_err"
|
||||
_show_result $TID 255
|
||||
fi
|
||||
_test_fill_and_verify && \
|
||||
_test_corrupted_reftag && \
|
||||
_test_corrupted_data && \
|
||||
_test_bad_apptag
|
||||
|
||||
rm -f "$fio_err"
|
||||
|
||||
_cleanup_test
|
||||
_show_result $TID 0
|
||||
_show_result "$TID" $ERR_CODE
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user