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, 2016 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 0 1 3 4 ; do
69 log_must set_partition
$slice "$cyl" $SIZE $DISK
70 cyl
=$
(get_endslice
$DISK $slice)
72 create_pool
$TESTPOOL $pooltype ${DISK}s0
${DISK}s1
74 log_must set_partition
0 "" $SIZE $DISK0
75 log_must set_partition
0 "" $SIZE $DISK1
76 create_pool
$TESTPOOL $pooltype ${DISK0}s0
${DISK1}s0
79 [[ -d $TESTDIR ]] && log_must
rm -rf $TESTDIR
80 log_must zfs create
$TESTPOOL/$TESTFS
81 log_must zfs
set mountpoint
=$TESTDIR $TESTPOOL/$TESTFS
83 log_must zfs
set compression
=off
$TESTPOOL/$TESTFS
84 file_write
-o create
-f $TESTDIR/$TESTFILE1 \
85 -b $BLOCK_SIZE -c $WRITE_COUNT -d 0
87 [[ $?
-ne $ENOSPC ]] && \
88 log_fail
"file_write completed w/o ENOSPC"
90 [[ ! -s $TESTDIR/$TESTFILE1 ]] && \
91 log_fail
"$TESTDIR/$TESTFILE1 was not created"
93 # $DISK will be set if we're using slices on one disk
94 if [[ -n $DISK ]]; then
95 log_must zpool add
$TESTPOOL $pooltype ${DISK}s3
${DISK}s4
97 [[ -z $DISK2 ||
-z $DISK3 ]] &&
98 log_unsupported
"No spare disks available"
99 log_must zpool add
$TESTPOOL $pooltype ${DISK2}s0
${DISK3}s0
102 log_must file_write
-o append
-f $TESTDIR/$TESTFILE1 \
103 -b $BLOCK_SIZE -c $SMALL_WRITE_COUNT -d 0
105 log_must destroy_pool
$TESTPOOL
108 log_pass
"mirror/raidz pool successfully grown"