test_generic_06.sh 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. . "$(cd "$(dirname "$0")" && pwd)"/test_common.sh
  4. ERR_CODE=0
  5. _prep_test "fault_inject" "fast cleanup when all I/Os of one hctx are in server"
  6. # configure ublk server to sleep 2s before completing each I/O
  7. dev_id=$(_add_ublk_dev -t fault_inject -q 2 -d 1 --delay_us 2000000)
  8. _check_add_dev $TID $?
  9. STARTTIME=${SECONDS}
  10. dd if=/dev/urandom of=/dev/ublkb${dev_id} oflag=direct bs=4k count=1 status=none > /dev/null 2>&1 &
  11. dd_pid=$!
  12. __ublk_kill_daemon ${dev_id} "DEAD" >/dev/null
  13. wait $dd_pid
  14. dd_exitcode=$?
  15. ENDTIME=${SECONDS}
  16. ELAPSED=$(($ENDTIME - $STARTTIME))
  17. # assert that dd sees an error and exits quickly after ublk server is
  18. # killed. previously this relied on seeing an I/O timeout and so would
  19. # take ~30s
  20. if [ $dd_exitcode -eq 0 ]; then
  21. echo "dd unexpectedly exited successfully!"
  22. ERR_CODE=255
  23. fi
  24. if [ $ELAPSED -ge 5 ]; then
  25. echo "dd took $ELAPSED seconds to exit (>= 5s tolerance)!"
  26. ERR_CODE=255
  27. fi
  28. _cleanup_test "fault_inject"
  29. _show_result $TID $ERR_CODE