#!/usr/bin/ksh -p # # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License (the "License"). # You may not use this file except in compliance with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # # Copyright 2008 Sun Microsystems, Inc. All rights reserved. # Use is subject to license terms. # # # Copyright (c) 2013, 2016 by Delphix. All rights reserved. # . $STF_SUITE/include/libtest.shlib . $STF_SUITE/tests/functional/cachefile/cachefile.cfg . $STF_SUITE/tests/functional/cachefile/cachefile.kshlib # # DESCRIPTION: # # Creating a pool with "cachefile" set doesn't update zpool.cache # # STRATEGY: # 1. Create a pool with the cachefile property set # 2. Verify that the pool doesn't have an entry in zpool.cache # 3. Verify the cachefile property is set # 4. Create a pool without the cachefile property # 5. Verify the cachefile property isn't set # 6. Verify that zpool.cache contains an entry for the pool # function cleanup { typeset file if poolexists $TESTPOOL ; then destroy_pool $TESTPOOL fi for file in $CPATH1 $CPATH2 ; do if [[ -f $file ]] ; then log_must rm $file fi done } verify_runnable "global" log_assert "Creating a pool with \"cachefile\" set doesn't update zpool.cache" log_onexit cleanup set -A opts "none" "false" "none" \ "$CPATH" "true" "-" \ "$CPATH1" "true" "$CPATH1" \ "$CPATH2" "true" "$CPATH2" typeset -i i=0 while (( i < ${#opts[*]} )); do log_must zpool create -o cachefile=${opts[i]} $TESTPOOL $DISKS case ${opts[((i+1))]} in false) log_mustnot pool_in_cache $TESTPOOL ;; true) log_must pool_in_cache $TESTPOOL ${opts[i]} ;; esac PROP=$(get_pool_prop cachefile $TESTPOOL) if [[ $PROP != ${opts[((i+2))]} ]]; then log_fail "cachefile property not set as expected. " \ "Expect: ${opts[((i+2))]}, Current: $PROP" fi log_must zpool destroy $TESTPOOL (( i = i + 3 )) done log_pass "Creating a pool with \"cachefile\" set doesn't update zpool.cache"