68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#!/bin/ksh -p
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# CDDL HEADER START
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# The contents of this file are subject to the terms of the
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Common Development and Distribution License (the "License").
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# You may not use this file except in compliance with the License.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# or http://www.opensolaris.org/os/licensing.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# See the License for the specific language governing permissions
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# and limitations under the License.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# When distributing Covered Code, include this CDDL HEADER in each
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# If applicable, add the following below this CDDL HEADER, with the
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# fields enclosed by brackets "[]" replaced with your own identifying
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# information: Portions Copyright [yyyy] [name of copyright owner]
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# CDDL HEADER END
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
b868f5d28c02403ad3cd322ee1635887f494ebe9Paul Dagnelie# Copyright (c) 2015, 2016 by Delphix. All rights reserved.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie. $STF_SUITE/include/libtest.shlib
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# DESCRIPTION:
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Test that receiving a full send as a clone works correctly.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# STRATEGY:
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 1. Create pool and filesystems.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 2. Send filesystem, receive as clone of itself.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 3. Verify that nop-write saves space.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 4. Send filesystem, receive as clone of other filesystem.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 5. Verify that contents are correct.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# 6. Repeat steps 4 and 5 with filesystems swapped.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelieverify_runnable "both"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefs=$TESTPOOL/$TESTFS/base/fs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefs2=$TESTPOOL/$TESTFS/base/fs2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelierfs=$TESTPOOL/$TESTFS/base/rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefunction make_object
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie{
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local objnum=$1
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local mntpnt=$2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local type=$3
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie if [[ $type == "file" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy dd if=/dev/urandom of=${mntpnt}/f$objnum bs=512 count=16
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie elif [[ $type == "hole1" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy dd if=/dev/urandom of=${mntpnt}/fh$objnum bs=512 count=5 stride=4
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie elif [[ $type == "hole2" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy dd if=/dev/urandom of=${mntpnt}/fh$objnum bs=512 count=4 stride=5
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie elif [[ $type == "directory" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy mkdir ${mntpnt}/d$objnum
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie elif [[ $type == "missing" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy touch ${mntpnt}/h$objnum
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie fi
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie}
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefunction create_pair
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie{
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local objnum=$1
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local mntpnt1=$2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local mntpnt2=$3
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local type1=$4
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie local type2=$5
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie make_object $objnum $mntpnt1 $type1
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie make_object $objnum $mntpnt2 $type2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie}
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefunction cleanup
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie{
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy zfs destroy -Rf $TESTPOOL/$TESTFS/base
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie rm /tmp/zr010p*
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie}
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelielog_assert "zfs receive of full send as clone should work"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelielog_onexit cleanup
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs create -o checksum=sha256 -o compression=gzip -o recordsize=512 \
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie $TESTPOOL/$TESTFS/base
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs create $fs
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs create $fs2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt=$(get_prop mountpoint $fs)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt2=$(get_prop mountpoint $fs2)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Now, we create the two filesystems. By creating objects with
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# different types and the same object number in each filesystem, we
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# create a situation where, when you receive the full send of each as
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# a clone of the other, we will test to ensure that the code correctly
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# handles receiving all object types onto all other object types.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file onto a file (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 8 $mntpnt $mntpnt2 "file" "file"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file onto a file with holes (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 9 $mntpnt $mntpnt2 "file" "hole1"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file onto a directory (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 10 $mntpnt $mntpnt2 "file" "directory"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file onto a missing object (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 11 $mntpnt $mntpnt2 "file" "missing"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file with holes onto a file with holes (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 12 $mntpnt $mntpnt2 "hole1" "hole2"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file with holes onto a directory (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 13 $mntpnt $mntpnt2 "hole1" "directory"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file with holes onto a missing object (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 14 $mntpnt $mntpnt2 "hole1" "missing"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a directory onto a directory (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 15 $mntpnt $mntpnt2 "directory" "directory"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a directory onto a missing object (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 16 $mntpnt $mntpnt2 "directory" "missing"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a missing object onto a missing object (and vice versa).
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliecreate_pair 17 $mntpnt $mntpnt2 "missing" "missing"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Receive a file with a different record size onto a file (and vice versa).
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs set recordsize=128k $fs
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedydd if=/dev/urandom of=$mntpnt/f18 bs=128k count=64
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedytouch $mntpnt2/f18
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Remove objects that are intended to be missing.
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedyrm $mntpnt/h17
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedyrm $mntpnt2/h*
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
286ef71398fb54b1d5007d6f45aa4320a9e0ede2Paul Dagnelie# Add empty objects to $fs to exercise dmu_traverse code
b868f5d28c02403ad3cd322ee1635887f494ebe9Paul Dagneliefor i in {1..100}; do
286ef71398fb54b1d5007d6f45aa4320a9e0ede2Paul Dagnelie log_must touch $mntpnt/uf$i
286ef71398fb54b1d5007d6f45aa4320a9e0ede2Paul Dagneliedone
286ef71398fb54b1d5007d6f45aa4320a9e0ede2Paul Dagnelie
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs snapshot $fs@s1
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs snapshot $fs2@s1
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs send $fs@s1 > /tmp/zr010p
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs send $fs2@s1 > /tmp/zr010p2
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Test that, when we receive a full send as a clone of itself,
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# nop-write saves us all the space used by data blocks.
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie#
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedycat /tmp/zr010p | log_must zfs receive -o origin=$fs@s1 $rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliesize=$(get_prop used $rfs)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliesize2=$(get_prop used $fs)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelieif [[ $size -ge $(($size2 / 10)) ]] then
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie log_fail "nop-write failure; expected usage less than "\
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie "$(($size2 / 10)), but is using $size"
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliefi
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs destroy -fr $rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie# Correctness testing: receive each full send as a clone of the other fiesystem.
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedycat /tmp/zr010p | log_must zfs receive -o origin=$fs2@s1 $rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt_old=$(get_prop mountpoint $fs)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt_new=$(get_prop mountpoint $rfs)
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must diff -r $mntpnt_old $mntpnt_new
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must zfs destroy -r $rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedycat /tmp/zr010p2 | log_must zfs receive -o origin=$fs@s1 $rfs
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt_old=$(get_prop mountpoint $fs2)
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagneliemntpnt_new=$(get_prop mountpoint $rfs)
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedylog_must diff -r $mntpnt_old $mntpnt_new
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelie
68ecb2ec930c4b0f00acaf8e0abb2b19c4b8b76fPaul Dagnelielog_pass "zfs receive of full send as clone works"