5 # The contents of this file are subject to the terms of the
6 # Common Development and Distribution License (the "License").
7 # You may not use this file except in compliance with the License.
9 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 # or http://www.opensolaris.org/os/licensing.
11 # See the License for the specific language governing permissions
12 # and limitations under the License.
14 # When distributing Covered Code, include this CDDL HEADER in each
15 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 # If applicable, add the following below this CDDL HEADER, with the
17 # fields enclosed by brackets "[]" replaced with your own identifying
18 # information: Portions Copyright [yyyy] [name of copyright owner]
24 # Copyright (c) 2016 by Delphix. All rights reserved.
26 .
$STF_SUITE/include
/libtest.shlib
27 .
$STF_SUITE/tests
/functional
/cli_root
/zpool_initialize
/zpool_initialize.kshlib
31 # Initializing automatically resumes across import/export.
34 # 1. Create a one-disk pool.
35 # 2. Start initializing and verify that initializing is active.
38 # 5. Verify that initializing resumes and progress does not regress.
39 # 6. Suspend initializing.
40 # 7. Repeat steps 3-4.
41 # 8. Verify that progress does not regress but initializing is still suspended.
46 log_must zpool create
-f $TESTPOOL $DISK1
47 log_must zpool initialize
$TESTPOOL
51 progress
="$(initialize_progress $TESTPOOL $DISK1)"
52 [[ -z "$progress" ]] && log_fail
"Initializing did not start"
54 log_must zpool
export $TESTPOOL
55 log_must zpool import
$TESTPOOL
57 new_progress
="$(initialize_progress $TESTPOOL $DISK1)"
58 [[ -z "$new_progress" ]] && log_fail
"Initializing did not restart after import"
59 [[ "$progress" -le "$new_progress" ]] || \
60 log_fail
"Initializing lost progress after import"
61 log_mustnot
eval "initialize_prog_line $TESTPOOL $DISK1 | grep suspended"
63 log_must zpool initialize
-s $TESTPOOL $DISK1
64 action_date
="$(initialize_prog_line $TESTPOOL $DISK1 | \
65 sed 's/.*ed at \(.*\)).*/\1/g')"
66 log_must zpool
export $TESTPOOL
67 log_must zpool import
$TESTPOOL
68 new_action_date
=$
(initialize_prog_line
$TESTPOOL $DISK1 | \
69 sed 's/.*ed at \(.*\)).*/\1/g')
70 [[ "$action_date" != "$new_action_date" ]] && \
71 log_fail
"Initializing action date did not persist across export/import"
73 [[ "$new_progress" -le "$(initialize_progress $TESTPOOL $DISK1)" ]] || \
74 log_fail
"Initializing lost progress after import"
76 log_must
eval "initialize_prog_line $TESTPOOL $DISK1 | grep suspended"
78 log_pass
"Initializing retains state as expected across export/import"