5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#!/usr/bin/ksh
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# This file and its contents are supplied under the terms of the
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Common Development and Distribution License ("CDDL"), version 1.0.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# You may only use this file in accordance with the terms of version
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# 1.0 of the CDDL.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# A full copy of the text of the CDDL should have accompanied this
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# source. A copy of the CDDL is also available via the Internet at
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# http://www.illumos.org/license/CDDL.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Copyright (c) 2015 by Delphix. All rights reserved.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel. $STF_SUITE/tests/functional/rsend/rsend.kshlib
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Description:
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Verify that compressed send works correctly with incremental sends.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Strategy:
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# 1. Randomly choose either a -i or -I incremental.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# 2. Generate compressed incremental replication streams for a pool, a
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# descendant dataset, and a volume.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# 3. Receive these streams verifying both the contents, and intermediate
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# snapshots are present or absent as appropriate to the -i or -I option.
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel#
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmelverify_runnable "both"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_assert "Verify compressed send works with incremental send streams."
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_onexit cleanup_pool $POOL2
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmeltypeset opt=$(random_get "-i" "-I")
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmeltypeset final dstlist list vol
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_must eval "zfs send -R $POOL@final > $BACKDIR/final"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_must eval "zfs receive -d -F $POOL2 < $BACKDIR/final"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmelfunction do_checks
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel{
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must cmp_ds_cont $POOL $POOL2
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel [[ $opt = "-I" ]] && log_must cmp_ds_subs $POOL $POOL2
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel [[ $opt = "-i" ]] && log_mustnot cmp_ds_subs $POOL $POOL2
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel [[ $1 != "clean" ]] && return
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel cleanup_pool $POOL2
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs send -R $POOL@final > $BACKDIR/final"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs receive -d -F $POOL2 < $BACKDIR/final"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel}
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmelif is_global_zone; then
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel # Send from the pool root
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel final=$(getds_with_suffix $POOL2 @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel list="$final $(getds_with_suffix $POOL2 @snapA)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel list="$list $(getds_with_suffix $POOL2 @snapB)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel list="$list $(getds_with_suffix $POOL2 @snapC)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs send -c -R $opt @init $POOL2@final >$BACKDIR/pool"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must destroy_tree $list
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs recv -d -F $POOL2 <$BACKDIR/pool"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel dstlist=$(getds_with_suffix $POOL2 @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel [[ $final != $dstlist ]] && log_fail "$final != $dstlist"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel do_checks clean
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel # Send of a volume
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel vol=$POOL2/$FS/vol
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel final=$(getds_with_suffix $vol @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs send -c -R $opt @init $vol@final >$BACKDIR/vol"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must destroy_tree $vol@snapB $vol@snapC $vol@final
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel log_must eval "zfs recv -d -F $POOL2 <$BACKDIR/vol"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel dstlist=$(getds_with_suffix $POOL2/$FS/vol @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel [[ $final != $dstlist ]] && log_fail "$final != $dstlist"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel do_checks clean
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmelfi
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel# Send of a descendant fs
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmelfinal=$(getds_with_suffix $POOL2/$FS @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellist="$final $(getds_with_suffix $POOL2/$FS @snapA)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellist="$list $(getds_with_suffix $POOL2/$FS @snapB)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellist="$list $(getds_with_suffix $POOL2/$FS @snapC)"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_must eval "zfs send -c -R $opt @init $POOL2/$FS@final >$BACKDIR/fs"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_must destroy_tree $list
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_must eval "zfs recv -d -F $POOL2 <$BACKDIR/fs"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmeldstlist=$(getds_with_suffix $POOL2/$FS @final)
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel[[ $final != $dstlist ]] && log_fail "$final != $dstlist"
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmeldo_checks
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmel
5602294fda888d923d57a78bafdaf48ae6223deaDan Kimmellog_pass "Compressed send works with incremental send streams."