#!/bin/ksh -p # # CDDL HEADER START # # This file and its contents are supplied under the terms of the # Common Development and Distribution License ("CDDL"), version 1.0. # You may only use this file in accordance with the terms of version # 1.0 of the CDDL. # # A full copy of the text of the CDDL should have accompanied this # source. A copy of the CDDL is also available via the Internet at # http://www.illumos.org/license/CDDL. # # CDDL HEADER END # # # Copyright (c) 2019 Datto, Inc. All rights reserved. # . $STF_SUITE/include/libtest.shlib # # DESCRIPTION: # 'zpool import' should import a pool with Errata #4. Users should be # able to set the zfs_disable_ivset_guid_check to continue normal # operation and the errata should disappear when no more effected # datasets remain. # # STRATEGY: # 1. Import a pre-packaged pool with Errata #4 and verify its state # 2. Prepare pool to fix existing datasets # 3. Use raw sends to fix datasets # 4. Ensure fixed datasets match their initial counterparts # 5. Destroy the initial datasets and verify the errata is gone # verify_runnable "global" POOL_NAME=missing_ivset POOL_FILE=missing_ivset.dat function uncompress_pool { log_note "Creating pool from $POOL_FILE" log_must bzcat \ $STF_SUITE/tests/functional/cli_root/zpool_import/blockfiles/$POOL_FILE.bz2 \ > /$TESTPOOL/$POOL_FILE return 0 } function cleanup { log_must set_tunable32 zfs_disable_ivset_guid_check 0 poolexists $POOL_NAME && log_must zpool destroy $POOL_NAME [[ -e /$TESTPOOL/$POOL_FILE ]] && rm /$TESTPOOL/$POOL_FILE return 0 } log_onexit cleanup log_assert "Verify that Errata 4 is properly handled" function has_ivset_guid # dataset { ds="$1" ivset_guid=$(get_prop ivsetguid $ds) if [ "$ivset_guid" == "-" ]; then return 1 else return 0 fi } # 1. Import a pre-packaged pool with Errata #4 and verify its state uncompress_pool log_must zpool import -d /$TESTPOOL/ $POOL_NAME log_must eval "zpool status $POOL_NAME | grep -q 'Errata #4'" log_must eval "zpool status $POOL_NAME | grep -q ZFS-8000-ER" bm2_value=$(zpool get -H -o value feature@bookmark_v2 $POOL_NAME) if [ "$bm2_value" != "disabled" ]; then log_fail "initial pool's bookmark_v2 feature is not disabled" fi log_mustnot has_ivset_guid $POOL_NAME/testfs@snap1 log_mustnot has_ivset_guid $POOL_NAME/testfs@snap2 log_mustnot has_ivset_guid $POOL_NAME/testfs@snap3 log_mustnot has_ivset_guid $POOL_NAME/testvol@snap1 log_mustnot has_ivset_guid $POOL_NAME/testvol@snap2 log_mustnot has_ivset_guid $POOL_NAME/testvol@snap3 # 2. Prepare pool to fix existing datasets log_must zpool set feature@bookmark_v2=enabled $POOL_NAME log_must set_tunable32 zfs_disable_ivset_guid_check 1 log_must zfs create $POOL_NAME/fixed # 3. Use raw sends to fix datasets log_must eval "zfs send -w $POOL_NAME/testfs@snap1 | \ zfs recv $POOL_NAME/fixed/testfs" log_must eval "zfs send -w -i @snap1 $POOL_NAME/testfs@snap2 | \ zfs recv $POOL_NAME/fixed/testfs" log_must eval \ "zfs send -w -i $POOL_NAME/testfs#snap2 $POOL_NAME/testfs@snap3 | \ zfs recv $POOL_NAME/fixed/testfs" log_must eval "zfs send -w $POOL_NAME/testvol@snap1 | \ zfs recv $POOL_NAME/fixed/testvol" log_must eval "zfs send -w -i @snap1 $POOL_NAME/testvol@snap2 | \ zfs recv $POOL_NAME/fixed/testvol" log_must eval \ "zfs send -w -i $POOL_NAME/testvol#snap2 $POOL_NAME/testvol@snap3 | \ zfs recv $POOL_NAME/fixed/testvol" # 4. Ensure fixed datasets match their initial counterparts log_must eval "echo 'password' | zfs load-key $POOL_NAME/testfs" log_must eval "echo 'password' | zfs load-key $POOL_NAME/testvol" log_must eval "echo 'password' | zfs load-key $POOL_NAME/fixed/testfs" log_must eval "echo 'password' | zfs load-key $POOL_NAME/fixed/testvol" log_must zfs mount $POOL_NAME/testfs log_must zfs mount $POOL_NAME/fixed/testfs block_device_wait old_mntpnt=$(get_prop mountpoint $POOL_NAME/testfs) new_mntpnt=$(get_prop mountpoint $POOL_NAME/fixed/testfs) log_must diff -r "$old_mntpnt" "$new_mntpnt" log_must diff /dev/zvol/$POOL_NAME/testvol /dev/zvol/$POOL_NAME/fixed/testvol log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap1 log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap2 log_must has_ivset_guid $POOL_NAME/fixed/testfs@snap3 log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap1 log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap2 log_must has_ivset_guid $POOL_NAME/fixed/testvol@snap3 # 5. Destroy the initial datasets and verify the errata is gone log_must zfs destroy -r $POOL_NAME/testfs log_must zfs destroy -r $POOL_NAME/testvol log_must zpool export $POOL_NAME log_must zpool import -d /$TESTPOOL/ $POOL_NAME log_mustnot eval "zpool status $POOL_NAME | grep -q 'Errata #4'" log_mustnot eval "zpool status $POOL_NAME | grep -q ZFS-8000-ER" log_pass "Errata 4 is properly handled"