zfs/tests/zfs-tests/tests/functional/removal/removal_with_faulted.ksh

105 lines
3.2 KiB
Bash
Executable File

#! /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) 2014, 2017 by Delphix. All rights reserved.
# Copyright (c) 2018 by Lawrence Livermore National Security, LLC.
#
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/removal/removal.kshlib
#
# DESCRIPTION:
#
# This test ensures that even when child vdevs are unavailable the
# device removal process copies from readable source children to
# writable destination children. This may be different than the
# default mapping which preferentially pairs up source and destination
# child vdevs based on their child ids.
#
# Default Mapping:
# mirror-0 mirror-1
# DISK0 (child 0) ------> DISK2 (child 0)
# DISK1 (child 1) ------> DISK3 (child 1)
#
# We want to setup a scenario where the default mapping would make
# it impossible to copy any data during the removal process. This
# is done by faulting both the mirror-0 (child 0) source vdev and
# mirror-1 (child 1) destination vdev. As shown below the default
# mapping cannot be used due to the FAULTED vdevs. Verify that an
# alternate mapping is selected and all the readable data is copied.
#
# Default Mapping (BAD):
# mirror-0 mirror-1
# DISK0 (FAULTED) ------> DISK2
# DISK1 ----------------> DISK3 (FAULTED)
#
# Required Mapping (GOOD):
# mirror-0 mirror-1
# DISK0 (FAULTED) +---> DISK2
# DISK1 ------------+ DISK3 (FAULTED)
#
# STRATEGY:
#
# 1. We create a pool with two top-level mirror vdevs.
# 2. We write some test data to the pool.
# 3. We fault two children to force the scenario described above.
# 4. We remove the mirror-0 device.
# 5. We verify that the device has been removed and that all of the
# data is still intact.
#
TMPDIR=${TMPDIR:-$TEST_BASE_DIR}
DISK0=$TMPDIR/dsk0
DISK1=$TMPDIR/dsk1
DISK2=$TMPDIR/dsk2
DISK3=$TMPDIR/dsk3
log_must truncate -s $MINVDEVSIZE $DISK0 $DISK1
log_must truncate -s $((MINVDEVSIZE * 4)) $DISK2 $DISK3
function cleanup
{
default_cleanup_noexit
log_must rm -f $DISK0 $DISK1 $DISK2 $DISK3
}
default_setup_noexit "mirror $DISK0 $DISK1 mirror $DISK2 $DISK3"
log_onexit cleanup
log_must zpool offline -f $TESTPOOL $DISK0
log_must zpool offline -f $TESTPOOL $DISK3
FILE_CONTENTS="Leeloo Dallas mul-ti-pass."
echo $FILE_CONTENTS >$TESTDIR/$TESTFILE0
log_must [ "x$(<$TESTDIR/$TESTFILE0)" = "x$FILE_CONTENTS" ]
log_must file_write -o create -f $TESTDIR/$TESTFILE1 -b $((2**20)) -c $((2**7))
sync_pool $TESTPOOL
log_must zpool remove $TESTPOOL mirror-0
log_must wait_for_removal $TESTPOOL
log_mustnot vdevs_in_pool $TESTPOOL mirror-0
verify_pool $TESTPOOL
log_must dd if=$TESTDIR/$TESTFILE0 of=/dev/null
log_must [ "x$(<$TESTDIR/$TESTFILE0)" = "x$FILE_CONTENTS" ]
log_must dd if=$TESTDIR/$TESTFILE1 of=/dev/null
log_pass "Can remove with faulted vdevs"