if (handler->zi_record.zi_cmd != ZINJECT_DELAY_IO)
continue;
+ if (handler->zi_record.zi_freq != 0 &&
+ spa_get_random(100) >= handler->zi_record.zi_freq);
+ continue;
+
if (vd->vdev_guid == handler->zi_record.zi_guid) {
seconds = handler->zi_record.zi_timer;
break;
-k Disable cleanup after test failure
-f Use files only, disables block device tests
-d DIR Use DIR for files and loopback devices
- -s SIZE Use vdevs of SIZE (default: 4G)
+ -s SIZE Use vdevs of SIZE (default: 2G)
-r RUNFILE Run tests in RUNFILE (default: linux.run)
EXAMPLES:
[tests/functional/cli_root/zpool_replace]
tests = ['zpool_replace_001_neg']
-# DISABLED:
-# zpool_scrub_004_pos - needs investigation
-# zpool_scrub_005_pos - needs investigation
[tests/functional/cli_root/zpool_scrub]
-tests = ['zpool_scrub_001_neg', 'zpool_scrub_002_pos', 'zpool_scrub_003_pos']
+tests = ['zpool_scrub_001_neg', 'zpool_scrub_002_pos', 'zpool_scrub_003_pos',
+ 'zpool_scrub_004_pos', 'zpool_scrub_005_pos']
[tests/functional/cli_root/zpool_set]
tests = ['zpool_set_001_pos', 'zpool_set_002_neg', 'zpool_set_003_neg']
#
. $STF_SUITE/include/libtest.shlib
+. $STF_SUITE/tests/functional/cli_root/zpool_scrub/zpool_scrub.cfg
#
# DESCRIPTION:
# 2. zpool scrub the pool
# 3. Verify zpool scrub -s succeed when the system is scrubbing.
#
+# NOTES:
+# A 1 second delay is added to 10% of zio's in order to ensure that
+# the scrub does not complete before it has a chance to be cancelled.
+# This can occur when testing with small pools or very fast hardware.
+#
verify_runnable "global"
log_assert "Verify scrub -s works correctly."
+log_must $ZINJECT -d $DISK1 -f10 -D1 $TESTPOOL
log_must $ZPOOL scrub $TESTPOOL
log_must $ZPOOL scrub -s $TESTPOOL
log_must is_pool_scrub_stopped $TESTPOOL
+log_must $ZINJECT -c all
log_pass "Verify scrub -s works correctly."
#
. $STF_SUITE/include/libtest.shlib
+. $STF_SUITE/tests/functional/cli_root/zpool_scrub/zpool_scrub.cfg
#
# DESCRIPTION:
# 3. Check the completed percent and invoke another scrub
# 4. Check the percent again, verify a new scrub started.
#
+# NOTES:
+# A 1 second delay is added to 10% of zio's in order to ensure that
+# the scrub does not complete before it has a chance to be restarted.
+# This can occur when testing with small pools or very fast hardware.
+#
verify_runnable "global"
log_assert "scrub command terminates the existing scrub process and starts" \
"a new scrub."
+log_must $ZINJECT -d $DISK1 -f10 -D1 $TESTPOOL
log_must $ZPOOL scrub $TESTPOOL
typeset -i PERCENT=30 percent=0
while ((percent < PERCENT)) ; do
log_fail "zpool scrub don't stop existing scrubbing process."
fi
+log_must $ZINJECT -c all
log_pass "scrub command terminates the existing scrub process and starts" \
"a new scrub."
# 2. Detach one of devices
# 3. Verify scrub failed until the resilver completed
#
+# NOTES:
+# A 1 second delay is added to 10% of zio's in order to ensure that
+# the resilver does not complete before the scrub can be issue. This
+# can occur when testing with small pools or very fast hardware.
verify_runnable "global"
log_assert "Resilver prevent scrub from starting until the resilver completes"
+log_must $ZINJECT -d $DISK1 -f10 -D1 $TESTPOOL
log_must $ZPOOL detach $TESTPOOL $DISK2
log_must $ZPOOL attach $TESTPOOL $DISK1 $DISK2
log_must is_pool_resilvering $TESTPOOL
$SLEEP 1
done
+log_must $ZINJECT -c all
log_pass "Resilver prevent scrub from starting until the resilver completes"