1#!/bin/ksh -p 2# 3# This file and its contents are supplied under the terms of the 4# Common Development and Distribution License ("CDDL"), version 1.0. 5# You may only use this file in accordance with the terms of version 6# 1.0 of the CDDL. 7# 8# A full copy of the text of the CDDL should have accompanied this 9# source. A copy of the CDDL is also available via the Internet at 10# http://www.illumos.org/license/CDDL. 11# 12 13# 14# Copyright (c) 2016, 2017 by Delphix. All rights reserved. 15# 16 17. $STF_SUITE/tests/functional/channel_program/channel_common.kshlib 18 19# 20# DESCRIPTION: Construct a set of nested filesystems, then recursively snapshot 21# all of them. 22# 23 24verify_runnable "global" 25 26rootfs=$TESTPOOL/$TESTFS/root 27snapname=snap 28 29function cleanup 30{ 31 destroy_dataset $rootfs "-R" 32} 33 34log_onexit cleanup 35 36filesystems="$rootfs \ 37$rootfs/child1 \ 38$rootfs/child1/subchild1 \ 39$rootfs/child1/subchild2 \ 40$rootfs/child1/subchild3 \ 41$rootfs/child2 \ 42$rootfs/child2/subchild4 \ 43$rootfs/child2/subchild5" 44 45for fs in $filesystems; do 46 log_must zfs create $fs 47done 48 49log_must_program_sync $TESTPOOL \ 50 $ZCP_ROOT/synctask_core/tst.snapshot_recursive.zcp $rootfs $snapname 51 52# 53# Make sure all of the snapshots we expect were created. 54# 55for fs in $filesystems; do 56 log_must snapexists $fs@$snapname 57done 58 59log_pass "Recursively snapshotting multiple filesystems works." 60 61 62