xref: /illumos-gate/usr/src/test/zfs-tests/tests/functional/cli_root/zpool_import/zpool_import_errata4.ksh (revision f52943a93040563107b95bccb9db87d9971ef47d)
1#!/bin/ksh -p
2#
3# CDDL HEADER START
4#
5# This file and its contents are supplied under the terms of the
6# Common Development and Distribution License ("CDDL"), version 1.0.
7# You may only use this file in accordance with the terms of version
8# 1.0 of the CDDL.
9#
10# A full copy of the text of the CDDL should have accompanied this
11# source.  A copy of the CDDL is also available via the Internet at
12# http://www.illumos.org/license/CDDL.
13#
14# CDDL HEADER END
15#
16
17#
18# Copyright (c) 2019 Datto, Inc. All rights reserved.
19#
20
21. $STF_SUITE/include/libtest.shlib
22
23#
24# DESCRIPTION:
25# 'zpool import' should import a pool with Errata #4. Users should be
26# able to set the zfs_disable_ivset_guid_check to continue normal
27# operation and the errata should disappear when no more effected
28# datasets remain.
29#
30# STRATEGY:
31# 1. Import a pre-packaged pool with Errata #4 and verify its state
32# 2. Prepare pool to fix existing datasets
33# 3. Use raw sends to fix datasets
34# 4. Ensure fixed datasets match their initial counterparts
35# 5. Destroy the initial datasets and verify the errata is gone
36#
37
38verify_runnable "global"
39
40POOL_NAME=missing_ivset
41POOL_FILE=missing_ivset.dat
42
43function uncompress_pool
44{
45	log_note "Creating pool from $POOL_FILE"
46	log_must bzcat \
47	    $STF_SUITE/tests/functional/cli_root/zpool_import/blockfiles/$POOL_FILE.bz2 \
48	    > /$TESTPOOL/$POOL_FILE
49	return 0
50}
51
52function cleanup
53{
54	log_must set_tunable32 zfs_disable_ivset_guid_check 0
55	poolexists $POOL_NAME && log_must zpool destroy $POOL_NAME
56	[[ -e /$TESTPOOL/$POOL_FILE ]] && rm /$TESTPOOL/$POOL_FILE
57	return 0
58}
59log_onexit cleanup
60
61log_assert "Verify that Errata 4 is properly handled"
62
63function has_ivset_guid # dataset
64{
65	ds="$1"
66	ivset_guid=$(get_prop ivsetguid $ds)
67
68	if [ "$ivset_guid" == "-" ]; then
69		return 1
70	else
71		return 0
72	fi
73}
74
75# 1. Import a pre-packaged pool with Errata #4 and verify its state
76uncompress_pool
77log_must zpool import -d /$TESTPOOL/ $POOL_NAME
78log_must eval "zpool status $POOL_NAME | grep -q 'Errata #4'"
79log_must eval "zpool status $POOL_NAME | grep -q ZFS-8000-ER"
80bm2_value=$(zpool get -H -o value feature@bookmark_v2 $POOL_NAME)
81if [ "$bm2_value" != "disabled" ]; then
82	log_fail "initial pool's bookmark_v2 feature is not disabled"
83fi
84
85log_mustnot has_ivset_guid $POOL_NAME/testfs@snap1
86log_mustnot has_ivset_guid $POOL_NAME/testfs@snap2
87log_mustnot has_ivset_guid $POOL_NAME/testfs@snap3
88log_mustnot has_ivset_guid $POOL_NAME/testvol@snap1
89log_mustnot has_ivset_guid $POOL_NAME/testvol@snap2
90log_mustnot has_ivset_guid $POOL_NAME/testvol@snap3
91
92# 2. Prepare pool to fix existing datasets
93log_must zpool set feature@bookmark_v2=enabled $POOL_NAME
94log_must set_tunable32 zfs_disable_ivset_guid_check 1
95log_must zfs create $POOL_NAME/fixed
96
97# 3. Use raw sends to fix datasets
98log_must eval "zfs send -w $POOL_NAME/testfs@snap1 | \
99	zfs recv $POOL_NAME/fixed/testfs"
100log_must eval "zfs send -w -i @snap1 $POOL_NAME/testfs@snap2 | \
101	zfs recv $POOL_NAME/fixed/testfs"
102log_must eval \
103	"zfs send -w -i $POOL_NAME/testfs#snap2 $POOL_NAME/testfs@snap3 | \
104	zfs recv $POOL_NAME/fixed/testfs"
105
106log_must eval "zfs send -w $POOL_NAME/testvol@snap1 | \
107	zfs recv $POOL_NAME/fixed/testvol"
108log_must eval "zfs send -w -i @snap1 $POOL_NAME/testvol@snap2 | \
109	zfs recv $POOL_NAME/fixed/testvol"
110log_must eval \
111	"zfs send -w -i $POOL_NAME/testvol#snap2 $POOL_NAME/testvol@snap3 | \
112	zfs recv $POOL_NAME/fixed/testvol"
113
114# 4. Ensure fixed datasets match their initial counterparts
115log_must eval "echo 'password' | zfs load-key $POOL_NAME/testfs"
116log_must eval "echo 'password' | zfs load-key $POOL_NAME/testvol"
117log_must eval "echo 'password' | zfs load-key $POOL_NAME/fixed/testfs"
118log_must eval "echo 'password' | zfs load-key $POOL_NAME/fixed/testvol"
119log_must zfs mount $POOL_NAME/testfs
120log_must zfs mount $POOL_NAME/fixed/testfs
121block_device_wait
122
123old_mntpnt=$(get_prop mountpoint $POOL_NAME/testfs)
124new_mntpnt=$(get_prop mountpoint $POOL_NAME/fixed/testfs)
125log_must diff -r "$old_mntpnt" "$new_mntpnt"
126log_must diff /dev/zvol/$POOL_NAME/testvol /dev/zvol/$POOL_NAME/fixed/testvol
127
128log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap1
129log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap2
130log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap3
131log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap1
132log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap2
133log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap3
134
135# 5. Destroy the initial datasets and verify the errata is gone
136log_must zfs destroy -r $POOL_NAME/testfs
137log_must zfs destroy -r $POOL_NAME/testvol
138
139log_must zpool export $POOL_NAME
140log_must zpool import -d /$TESTPOOL/ $POOL_NAME
141log_mustnot eval "zpool status $POOL_NAME | grep -q 'Errata #4'"
142log_mustnot eval "zpool status $POOL_NAME | grep -q ZFS-8000-ER"
143log_pass "Errata 4 is properly handled"
144