xref: /illumos-gate/usr/src/test/zfs-tests/tests/functional/rsend/rsend_013_pos.ksh (revision 440a8a36792bdf9ef51639066aab0b7771ffcab8)
1#!/bin/ksh -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
28#
29# Copyright (c) 2013, 2016 by Delphix. All rights reserved.
30#
31
32. $STF_SUITE/tests/functional/rsend/rsend.kshlib
33
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
48verify_runnable "both"
49
50function cleanup
51{
52	cleanup_pool $POOL2
53	cleanup_pool $POOL
54	log_must setup_test_model $POOL
55}
56
57log_assert "zfs receive -dF will destroy all the dataset that not exist" \
58	"on the sender side"
59log_onexit cleanup
60
61cleanup
62
63#
64# Duplicate POOL2 for testing
65#
66log_must eval "zfs send -R $POOL@final > $BACKDIR/pool-final-R"
67log_must eval "zfs receive -dF $POOL2 < $BACKDIR/pool-final-R"
68
69log_must zfs destroy -Rf $POOL/$FS
70log_must zfs destroy -Rf $POOL/pclone
71
72if is_global_zone ; then
73	log_must zfs destroy -Rf $POOL/vol
74fi
75log_must zfs snapshot -r $POOL@destroy
76
77log_must eval "zfs send -R -I @final $POOL@destroy > " \
78	"$BACKDIR/pool-final-destroy-IR"
79log_must eval "zfs receive -dF $POOL2 < $BACKDIR/pool-final-destroy-IR"
80
81dstds=$(get_dst_ds $POOL $POOL2)
82log_must cmp_ds_subs $POOL $dstds
83log_must cmp_ds_cont $POOL $dstds
84
85log_pass "zfs receive -dF will destroy all the dataset that not exist" \
86	"on the sender side"
87