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 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 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