1*5602294fSDan Kimmel#!/usr/bin/ksh
2*5602294fSDan Kimmel
3*5602294fSDan Kimmel#
4*5602294fSDan Kimmel# This file and its contents are supplied under the terms of the
5*5602294fSDan Kimmel# Common Development and Distribution License ("CDDL"), version 1.0.
6*5602294fSDan Kimmel# You may only use this file in accordance with the terms of version
7*5602294fSDan Kimmel# 1.0 of the CDDL.
8*5602294fSDan Kimmel#
9*5602294fSDan Kimmel# A full copy of the text of the CDDL should have accompanied this
10*5602294fSDan Kimmel# source.  A copy of the CDDL is also available via the Internet at
11*5602294fSDan Kimmel# http://www.illumos.org/license/CDDL.
12*5602294fSDan Kimmel#
13*5602294fSDan Kimmel
14*5602294fSDan Kimmel#
15*5602294fSDan Kimmel# Copyright (c) 2015 by Delphix. All rights reserved.
16*5602294fSDan Kimmel#
17*5602294fSDan Kimmel
18*5602294fSDan Kimmel. $STF_SUITE/tests/functional/rsend/rsend.kshlib
19*5602294fSDan Kimmel
20*5602294fSDan Kimmel#
21*5602294fSDan Kimmel# Description:
22*5602294fSDan Kimmel# Verify that compressed send works correctly with incremental sends.
23*5602294fSDan Kimmel#
24*5602294fSDan Kimmel# Strategy:
25*5602294fSDan Kimmel# 1. Randomly choose either a -i or -I incremental.
26*5602294fSDan Kimmel# 2. Generate compressed incremental replication streams for a pool, a
27*5602294fSDan Kimmel#    descendant dataset, and a volume.
28*5602294fSDan Kimmel# 3. Receive these streams verifying both the contents, and intermediate
29*5602294fSDan Kimmel#    snapshots are present or absent as appropriate to the -i or -I option.
30*5602294fSDan Kimmel#
31*5602294fSDan Kimmel
32*5602294fSDan Kimmelverify_runnable "both"
33*5602294fSDan Kimmel
34*5602294fSDan Kimmellog_assert "Verify compressed send works with incremental send streams."
35*5602294fSDan Kimmellog_onexit cleanup_pool $POOL2
36*5602294fSDan Kimmel
37*5602294fSDan Kimmeltypeset opt=$(random_get "-i" "-I")
38*5602294fSDan Kimmeltypeset final dstlist list vol
39*5602294fSDan Kimmel
40*5602294fSDan Kimmellog_must eval "zfs send -R $POOL@final > $BACKDIR/final"
41*5602294fSDan Kimmellog_must eval "zfs receive -d -F $POOL2 < $BACKDIR/final"
42*5602294fSDan Kimmel
43*5602294fSDan Kimmelfunction do_checks
44*5602294fSDan Kimmel{
45*5602294fSDan Kimmel	log_must cmp_ds_cont $POOL $POOL2
46*5602294fSDan Kimmel	[[ $opt = "-I" ]] && log_must cmp_ds_subs $POOL $POOL2
47*5602294fSDan Kimmel	[[ $opt = "-i" ]] && log_mustnot cmp_ds_subs $POOL $POOL2
48*5602294fSDan Kimmel
49*5602294fSDan Kimmel	[[ $1 != "clean" ]] && return
50*5602294fSDan Kimmel
51*5602294fSDan Kimmel	cleanup_pool $POOL2
52*5602294fSDan Kimmel	log_must eval "zfs send -R $POOL@final > $BACKDIR/final"
53*5602294fSDan Kimmel	log_must eval "zfs receive -d -F $POOL2 < $BACKDIR/final"
54*5602294fSDan Kimmel}
55*5602294fSDan Kimmel
56*5602294fSDan Kimmelif is_global_zone; then
57*5602294fSDan Kimmel	# Send from the pool root
58*5602294fSDan Kimmel	final=$(getds_with_suffix $POOL2 @final)
59*5602294fSDan Kimmel	list="$final $(getds_with_suffix $POOL2 @snapA)"
60*5602294fSDan Kimmel	list="$list $(getds_with_suffix $POOL2 @snapB)"
61*5602294fSDan Kimmel	list="$list $(getds_with_suffix $POOL2 @snapC)"
62*5602294fSDan Kimmel
63*5602294fSDan Kimmel	log_must eval "zfs send -c -R $opt @init $POOL2@final >$BACKDIR/pool"
64*5602294fSDan Kimmel	log_must destroy_tree $list
65*5602294fSDan Kimmel	log_must eval "zfs recv -d -F $POOL2 <$BACKDIR/pool"
66*5602294fSDan Kimmel
67*5602294fSDan Kimmel	dstlist=$(getds_with_suffix $POOL2 @final)
68*5602294fSDan Kimmel	[[ $final != $dstlist ]] && log_fail "$final != $dstlist"
69*5602294fSDan Kimmel
70*5602294fSDan Kimmel	do_checks clean
71*5602294fSDan Kimmel
72*5602294fSDan Kimmel	# Send of a volume
73*5602294fSDan Kimmel	vol=$POOL2/$FS/vol
74*5602294fSDan Kimmel	final=$(getds_with_suffix $vol @final)
75*5602294fSDan Kimmel	log_must eval "zfs send -c -R $opt @init $vol@final >$BACKDIR/vol"
76*5602294fSDan Kimmel	log_must destroy_tree $vol@snapB $vol@snapC $vol@final
77*5602294fSDan Kimmel	log_must eval "zfs recv -d -F $POOL2 <$BACKDIR/vol"
78*5602294fSDan Kimmel
79*5602294fSDan Kimmel	dstlist=$(getds_with_suffix $POOL2/$FS/vol @final)
80*5602294fSDan Kimmel	[[ $final != $dstlist ]] && log_fail "$final != $dstlist"
81*5602294fSDan Kimmel
82*5602294fSDan Kimmel	do_checks clean
83*5602294fSDan Kimmelfi
84*5602294fSDan Kimmel
85*5602294fSDan Kimmel# Send of a descendant fs
86*5602294fSDan Kimmelfinal=$(getds_with_suffix $POOL2/$FS @final)
87*5602294fSDan Kimmellist="$final $(getds_with_suffix $POOL2/$FS @snapA)"
88*5602294fSDan Kimmellist="$list $(getds_with_suffix $POOL2/$FS @snapB)"
89*5602294fSDan Kimmellist="$list $(getds_with_suffix $POOL2/$FS @snapC)"
90*5602294fSDan Kimmel
91*5602294fSDan Kimmellog_must eval "zfs send -c -R $opt @init $POOL2/$FS@final >$BACKDIR/fs"
92*5602294fSDan Kimmellog_must destroy_tree $list
93*5602294fSDan Kimmellog_must eval "zfs recv -d -F $POOL2 <$BACKDIR/fs"
94*5602294fSDan Kimmel
95*5602294fSDan Kimmeldstlist=$(getds_with_suffix $POOL2/$FS @final)
96*5602294fSDan Kimmel[[ $final != $dstlist ]] && log_fail "$final != $dstlist"
97*5602294fSDan Kimmel
98*5602294fSDan Kimmeldo_checks
99*5602294fSDan Kimmel
100*5602294fSDan Kimmellog_pass "Compressed send works with incremental send streams."
101