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