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