1#!/usr/local/bin/ksh93 -p 2# 3# CDDL HEADER START 4# 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. 8# 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. 13# 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] 19# 20# CDDL HEADER END 21# 22 23# 24# Copyright 2009 Sun Microsystems, Inc. All rights reserved. 25# Use is subject to license terms. 26 27. $STF_SUITE/tests/rsend/rsend.kshlib 28 29################################################################################# 30# 31# __stc_assertion_start 32# 33# ID: rsend_013_pos 34# 35# DESCRIPTION: 36# zfs receive -dF with incremental stream will destroy all the 37# dataset that not exist on the sender side. 38# 39# STRATEGY: 40# 1. Setup test model 41# 2. Send -R @final on pool 42# 3. Destroy some dataset within the @final, and create @destroy 43# 4. Send -R -I @final @destroy on pool 44# 5. Verify receive -dF will destroy all the dataset that not exist 45# on the sender side. 46# 47# TESTABILITY: explicit 48# 49# TEST_AUTOMATION_LEVEL: automated 50# 51# CODING_STATUS: COMPLETED (2008-12-15) 52# 53# __stc_assertion_end 54# 55################################################################################ 56 57verify_runnable "both" 58 59function cleanup 60{ 61 cleanup_pool $POOL2 62 cleanup_pool $POOL 63 log_must setup_test_model $POOL 64} 65 66log_assert "zfs receive -dF will destroy all the dataset that not exist" \ 67 "on the sender side" 68log_onexit cleanup 69 70cleanup 71 72# 73# Duplicate POOL2 for testing 74# 75log_must eval "$ZFS send -R $POOL@final > $BACKDIR/pool-final-R" 76log_must eval "$ZFS receive -dF $POOL2 < $BACKDIR/pool-final-R" 77 78log_must $ZFS destroy -Rf $POOL/$FS 79log_must $ZFS destroy -Rf $POOL/pclone 80 81if is_global_zone ; then 82 log_must $ZFS destroy -Rf $POOL/vol 83fi 84log_must $ZFS snapshot -r $POOL@destroy 85 86log_must eval "$ZFS send -R -I @final $POOL@destroy > " \ 87 "$BACKDIR/pool-final-destroy-IR" 88log_must eval "$ZFS receive -dF $POOL2 < $BACKDIR/pool-final-destroy-IR" 89 90dstds=$(get_dst_ds $POOL $POOL2) 91log_must cmp_ds_subs $POOL $dstds 92log_must cmp_ds_cont $POOL $dstds 93 94log_pass "zfs receive -dF will destroy all the dataset that not exist" \ 95 "on the sender side" 96