Removal of the message "No I/O performed" when fio does not execute any I/O broke zbd tests 2 and 3 as this message is looked after to test for success. Fix this by looking for a "Run status" line starting with "WRITE:" for test 2 and "READ:" for test 3. The run status lines are not printed when no I/O is performed. Testing for the absence of these strings thus allows to easily test if I/Os where executed or not. Fixes: ff3aa922570c ("Kill "No I/O performed by ..." message") Signed-off-by: Damien Le Moal <damien.lemoal@xxxxxxx> --- t/zbd/test-zbd-support | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/t/zbd/test-zbd-support b/t/zbd/test-zbd-support index d316d880..03d61b70 100755 --- a/t/zbd/test-zbd-support +++ b/t/zbd/test-zbd-support @@ -141,9 +141,8 @@ test2() { if [ -z "$is_zbd" ]; then opts+=("--zonesize=${zone_size}") fi - run_fio "${opts[@]}" 2>&1 | - tee -a "${logfile}.${test_number}" | - grep -q 'No I/O performed' + run_fio "${opts[@]}" >> "${logfile}.${test_number}" 2>&1 || return $? + ! grep -q 'WRITE:' "${logfile}.${test_number}" } # Run fio against an empty zone. This causes fio to report "No I/O performed". @@ -160,12 +159,12 @@ test3() { opts+=("--zonesize=${zone_size}") fi run_fio "${opts[@]}" >> "${logfile}.${test_number}" 2>&1 || return $? - grep -q "No I/O performed" "${logfile}.${test_number}" + grep -q 'READ:' "${logfile}.${test_number}" rc=$? if [ -n "$is_zbd" ]; then - [ $rc = 0 ] - else [ $rc != 0 ] + else + [ $rc = 0 ] fi } -- 2.20.1