4 # The contents of this file are subject to the terms of the
5 # Common Development and Distribution License (the "License").
6 # You may not use this file except in compliance with the License.
8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 # or http://www.opensolaris.org/os/licensing.
10 # See the License for the specific language governing permissions
11 # and limitations under the License.
13 # When distributing Covered Code, include this CDDL HEADER in each
14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 # If applicable, add the following below this CDDL HEADER, with the
16 # fields enclosed by brackets "[]" replaced with your own identifying
17 # information: Portions Copyright [yyyy] [name of copyright owner]
23 # Copyright 2007 Sun Microsystems, Inc. All rights reserved.
24 # Use is subject to license terms.
28 # Copyright (c) 2012, 2016 by Delphix. All rights reserved.
31 . $STF_SUITE/tests/functional/cli_root/zfs_rename/zfs_rename.cfg
33 function additional_setup
36 log_must cp $DATA $TESTDIR/$TESTFILE0
37 log_must cp $DATA $TESTDIR1/$TESTFILE0
40 if ! snapexists $TESTPOOL/$TESTFS@snapshot; then
41 log_must zfs snapshot $TESTPOOL/$TESTFS@snapshot
42 log_must zfs clone $TESTPOOL/$TESTFS@snapshot \
43 $TESTPOOL/$TESTFS-clone
47 datasetexists $TESTPOOL/$TESTFS1 || \
48 log_must zfs create $TESTPOOL/$TESTFS1
51 log_must cp $DATA $(get_prop mountpoint $TESTPOOL/$TESTFS1)/$TESTFILE0
54 datasetexists $TESTPOOL/$TESTCTR1 || \
55 log_must zfs create $TESTPOOL/$TESTCTR1
56 log_must cp $DATA $(get_prop mountpoint $TESTPOOL/$TESTCTR1)/$TESTFILE0
59 if is_global_zone; then
60 log_must eval "dd if=$DATA of=$VOL_R_PATH bs=$BS count=$CNT \
63 log_must cp $DATA $(get_prop mountpoint $TESTPOOL/$TESTVOL)/$TESTFILE0
66 # Create temporary %recv clone
67 create_recv_clone $TESTPOOL/$RECVFS
70 function rename_dataset # src dest
75 log_must zfs rename $src $dest
79 # Verify src name no longer in use
81 log_mustnot datasetexists $src
82 log_must datasetexists $dest
88 while ((i < ${#dataset[*]} )); do
89 if ! datasetexists ${dataset[i]}-new ; then
94 if [[ ${dataset[i]}-new != *@* ]] ; then
95 zfs rename ${dataset[i]}-new ${dataset[i]}
96 if [[ $? -ne 0 ]]; then
97 typeset newfs=${dataset[i]}-new
98 typeset oldfs=${dataset[i]}
99 typeset mntp=$(get_prop mountpoint $newfs)
100 log_must zfs destroy -f $newfs
101 log_must zfs create -p $oldfs
102 log_must zfs set mountpoint=$mntp $oldfs
105 log_must zfs destroy -fR ${dataset[i]}-new
111 if snapexists $TESTPOOL/$TESTFS@snapshot; then
112 log_must zfs destroy -fR $TESTPOOL/$TESTFS@snapshot
115 if datasetexists $TESTPOOL/$RECVFS; then
116 log_must zfs destroy -r $TESTPOOL/$RECVFS
120 function cmp_data #<$1 src data, $2 tgt data>
125 cmp $src $tgt >/dev/null 2>&1