]>
git.proxmox.com Git - mirror_zfs.git/blob - tests/zfs-tests/tests/functional/grow_replicas/grow_replicas_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 2008 Sun Microsystems, Inc. All rights reserved.
25 # Use is subject to license terms.
29 # Copyright (c) 2013 by Delphix. All rights reserved.
30 # Copyright 2016 Nexenta Systems, Inc.
33 .
$STF_SUITE/tests
/functional
/grow_replicas
/grow_replicas.cfg
36 # A ZFS filesystem is limited by the amount of disk space
37 # available to the pool. Growing the pool by adding a disk
38 # increases the amount of space.
41 # 1. Fill the filesystem on mirror/raidz pool by writing a file until ENOSPC.
42 # 2. Grow the mirror/raidz pool by adding another mirror/raidz vdev.
43 # 3. Verify that more data can now be written to the filesystem.
45 verify_runnable
"global"
47 if ! is_physical_device
$DISKS; then
48 log_unsupported
"This test case cannot be run on raw files"
53 datasetexists
$TESTPOOL && log_must destroy_pool
$TESTPOOL
54 [[ -d $TESTDIR ]] && log_must
$RM -rf $TESTDIR
57 log_assert
"mirror/raidz pool may be increased in capacity by adding a disk"
63 for pooltype
in "mirror" "raidz"; do
64 log_note
"Creating pool type: $pooltype"
66 if [[ -n $DISK ]]; then
67 log_note
"No spare disks available. Using slices on $DISK"
68 for slice
in $SLICES; do
69 log_must set_partition
$slice "$cyl" $SIZE $DISK
70 cyl
=$
(get_endslice
$DISK $slice)
72 create_pool
$TESTPOOL $pooltype \
73 ${DISK}${SLICE_PREFIX}${SLICE0} \
74 ${DISK}${SLICE_PREFIX}${SLICE1}
76 log_must set_partition
0 "" $SIZE $DISK0
77 log_must set_partition
0 "" $SIZE $DISK1
78 create_pool
$TESTPOOL $pooltype \
79 ${DISK0}${SLICE_PREFIX}${SLICE0} \
80 ${DISK1}${SLICE_PREFIX}${SLICE0}
83 [[ -d $TESTDIR ]] && log_must
$RM -rf $TESTDIR
84 log_must
$ZFS create
$TESTPOOL/$TESTFS
85 log_must
$ZFS set mountpoint
=$TESTDIR $TESTPOOL/$TESTFS
87 log_must
$ZFS set compression
=off
$TESTPOOL/$TESTFS
88 $FILE_WRITE -o create
-f $TESTDIR/$TESTFILE1 \
89 -b $BLOCK_SIZE -c $WRITE_COUNT -d 0
91 [[ $?
-ne $ENOSPC ]] && \
92 log_fail
"file_write completed w/o ENOSPC"
94 [[ ! -s $TESTDIR/$TESTFILE1 ]] && \
95 log_fail
"$TESTDIR/$TESTFILE1 was not created"
97 # $DISK will be set if we're using slices on one disk
98 if [[ -n $DISK ]]; then
99 log_must
$ZPOOL add
$TESTPOOL $pooltype ${DISK}s3
${DISK}s4
101 [[ -z $DISK2 ||
-z $DISK3 ]] &&
102 log_unsupported
"No spare disks available"
103 log_must
$ZPOOL add
$TESTPOOL $pooltype \
104 ${DISK2}${SLICE_PREFIX}${SLICE0} \
105 ${DISK3}${SLICE_PREFIX}${SLICE0}
108 log_must
$FILE_WRITE -o append
-f $TESTDIR/$TESTFILE1 \
109 -b $BLOCK_SIZE -c $SMALL_WRITE_COUNT -d 0
111 log_must destroy_pool
$TESTPOOL
114 log_pass
"mirror/raidz pool successfully grown"