]>
git.proxmox.com Git - mirror_zfs.git/blob - tests/zfs-tests/tests/functional/snapshot/clone_001_pos.ksh
5 # The contents of this file are subject to the terms of the
6 # Common Development and Distribution License (the "License").
7 # You may not use this file except in compliance with the License.
9 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 # or http://www.opensolaris.org/os/licensing.
11 # See the License for the specific language governing permissions
12 # and limitations under the License.
14 # When distributing Covered Code, include this CDDL HEADER in each
15 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 # If applicable, add the following below this CDDL HEADER, with the
17 # fields enclosed by brackets "[]" replaced with your own identifying
18 # information: Portions Copyright [yyyy] [name of copyright owner]
24 # Copyright 2009 Sun Microsystems, Inc. All rights reserved.
25 # Use is subject to license terms.
29 # Copyright (c) 2013 by Delphix. All rights reserved.
32 .
$STF_SUITE/include
/libtest.shlib
33 .
$STF_SUITE/tests
/functional
/snapshot
/snapshot.cfg
37 # Create a snapshot from regular filesystem, volume,
38 # or filesystem upon volume, Build a clone file system
39 # from the snapshot and verify new files can be written.
42 # 1. Create snapshot use 3 combination:
43 # - Regular filesystem
45 # - Filesystem upon volume
46 # 2. Clone a new file system from the snapshot
47 # 3. Verify the cloned file system is writable
50 verify_runnable
"both"
52 # Setup array, 4 elements as a group, refer to:
53 # i+0: name of a snapshot
54 # i+1: mountpoint of the snapshot
55 # i+2: clone created from the snapshot
56 # i+3: mountpoint of the clone
58 set -A args
"$SNAPFS" "$SNAPDIR" "$TESTPOOL/$TESTCLONE" "$TESTDIR.0" \
59 "$SNAPFS1" "$SNAPDIR3" "$TESTPOOL/$TESTCLONE1" "" \
60 "$SNAPFS2" "$SNAPDIR2" "$TESTPOOL1/$TESTCLONE2" "$TESTDIR.2"
64 create_pool
$TESTPOOL1 ${ZVOL_DEVDIR}/$TESTPOOL/$TESTVOL
65 log_must
$ZFS create
$TESTPOOL1/$TESTFS
66 log_must
$ZFS set mountpoint
=$TESTDIR2 $TESTPOOL1/$TESTFS
76 while (( i
< ${#args[*]} )); do
77 snapexists
${args[i]} && \
78 log_must
$ZFS destroy
-Rf ${args[i]}
80 [[ -d ${args[i+3]} ]] && \
81 log_must
$RM -rf ${args[i+3]}
83 [[ -d ${args[i+1]} ]] && \
84 log_must
$RM -rf ${args[i+1]}
89 datasetexists
$TESTPOOL1/$TESTFS && \
90 log_must
$ZFS destroy
-f $TESTPOOL1/$TESTFS
92 destroy_pool
$TESTPOOL1
94 [[ -d $TESTDIR2 ]] && \
95 log_must
$RM -rf $TESTDIR2
100 log_assert
"Verify a cloned file system is writable."
102 log_onexit cleanup_all
106 [[ -n $TESTDIR ]] && \
107 log_must
$RM -rf $TESTDIR/* > /dev
/null
2>&1
112 for mtpt
in $TESTDIR $TESTDIR2 ; do
113 log_note
"Populate the $mtpt directory (prior to snapshot)"
115 while [[ $j -le $COUNT ]]; do
116 log_must
$FILE_WRITE -o create
-f $mtpt/before_file
$j \
117 -b $BLOCKSZ -c $NUM_WRITES -d $j
123 while (( i
< ${#args[*]} )); do
125 # Take a snapshot of the test file system.
127 log_must
$ZFS snapshot
${args[i]}
130 # Clone a new file system from the snapshot
132 log_must
$ZFS clone
${args[i]} ${args[i+2]}
133 if [[ -n ${args[i+3]} ]] ; then
134 log_must
$ZFS set mountpoint
=${args[i+3]} ${args[i+2]}
136 FILE_COUNT
=`$LS -Al ${args[i+3]} | $GREP -v "total" \
137 | $GREP -v "\.zfs" | wc -l`
138 if [[ $FILE_COUNT -ne $COUNT ]]; then
140 log_fail
"AFTER: ${args[i+3]} contains $FILE_COUNT files(s)."
143 log_note
"Verify the ${args[i+3]} directory is writable"
145 while [[ $j -le $COUNT ]]; do
146 log_must
$FILE_WRITE -o create
-f ${args[i+3]}/after_file
$j \
147 -b $BLOCKSZ -c $NUM_WRITES -d $j
151 FILE_COUNT
=`$LS -Al ${args[i+3]}/after* | $GREP -v "total" | wc -l`
152 if [[ $FILE_COUNT -ne $COUNT ]]; then
154 log_fail
"${args[i+3]} contains $FILE_COUNT after* files(s)."
161 log_pass
"The clone file system is writable."