Print this page
NEX-3974 Remove timing issues so the robot can run consistently
Reviewed by: Steve Peng <steve.peng@nexenta.com>
Reviewed by: Josef Sipek <josef.sipek@nexenta.com>
Reviewed by: Alek Pinchuk <alek.pinchuk@nexenta.com>
4206 history_003_pos relies on exact size of history log and entries
4207 history_008_pos depends on obsolete internal history log message
4208 Typo in zfs_main.c: "posxiuser"
4209 Populate zfstest with the remainder of the STF tests
Reviewed by: Sonu Pillai <sonu.pillai@delphix.com>
Reviewed by: Will Guyette <will.guyette@delphix.com>
Reviewed by: Eric Diven <eric.diven@delphix.com>
Reviewed by: Christopher Siden <christopher.siden@delphix.com>
Approved by: Richard Lowe <richlowe@richlowe.net>


  10 # or http://www.opensolaris.org/os/licensing.
  11 # See the License for the specific language governing permissions
  12 # and limitations under the License.
  13 #
  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]
  19 #
  20 # CDDL HEADER END
  21 #
  22 
  23 #
  24 # Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  25 # Use is subject to license terms.
  26 #
  27 
  28 #
  29 # Copyright (c) 2013, 2016 by Delphix. All rights reserved.

  30 #
  31 
  32 . $STF_SUITE/tests/functional/slog/slog.kshlib
  33 
  34 #
  35 # DESCRIPTION:
  36 #       log device can survive when one of pool device get corrupted
  37 #
  38 # STRATEGY:
  39 #       1. Create pool with slog devices
  40 #       2. Corrupt the data on one disk.
  41 #       3. Verify the log is fine
  42 #
  43 
  44 verify_runnable "global"
  45 
  46 log_assert "log device can survive when one of the pool device get corrupted."
  47 
  48 for type in "mirror" "raidz" "raidz2"
  49 do


  56                 dd if=/dev/urandom of=/$TESTPOOL/filler bs=1024k count=50
  57                 # The oseek value below is to skip past the vdev label.
  58                 log_must dd if=/dev/urandom of=$VDIR/a bs=1024k oseek=4 \
  59                     conv=notrunc count=50
  60                 log_must zpool scrub $TESTPOOL
  61                 log_must display_status $TESTPOOL
  62                 log_must zpool status $TESTPOOL 2>&1 >/dev/null
  63 
  64                 zpool status -v $TESTPOOL | \
  65                         grep "state: DEGRADED" 2>&1 >/dev/null
  66                 if (( $? != 0 )); then
  67                         log_fail "pool $TESTPOOL status should be DEGRADED"
  68                 fi
  69 
  70                 zpool status -v $TESTPOOL | grep logs | \
  71                         grep "DEGRADED" 2>&1 >/dev/null
  72                 if (( $? == 0 )); then
  73                         log_fail "log device should display correct status"
  74                 fi
  75 
  76                 log_must zpool destroy -f $TESTPOOL
  77         done
  78 done
  79 
  80 log_pass "log device can survive when one of the pool device get corrupted."


  10 # or http://www.opensolaris.org/os/licensing.
  11 # See the License for the specific language governing permissions
  12 # and limitations under the License.
  13 #
  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]
  19 #
  20 # CDDL HEADER END
  21 #
  22 
  23 #
  24 # Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  25 # Use is subject to license terms.
  26 #
  27 
  28 #
  29 # Copyright (c) 2013, 2016 by Delphix. All rights reserved.
  30 # Copyright 2015 Nexenta Systems, Inc.  All rights reserved.
  31 #
  32 
  33 . $STF_SUITE/tests/functional/slog/slog.kshlib
  34 
  35 #
  36 # DESCRIPTION:
  37 #       log device can survive when one of pool device get corrupted
  38 #
  39 # STRATEGY:
  40 #       1. Create pool with slog devices
  41 #       2. Corrupt the data on one disk.
  42 #       3. Verify the log is fine
  43 #
  44 
  45 verify_runnable "global"
  46 
  47 log_assert "log device can survive when one of the pool device get corrupted."
  48 
  49 for type in "mirror" "raidz" "raidz2"
  50 do


  57                 dd if=/dev/urandom of=/$TESTPOOL/filler bs=1024k count=50
  58                 # The oseek value below is to skip past the vdev label.
  59                 log_must dd if=/dev/urandom of=$VDIR/a bs=1024k oseek=4 \
  60                     conv=notrunc count=50
  61                 log_must zpool scrub $TESTPOOL
  62                 log_must display_status $TESTPOOL
  63                 log_must zpool status $TESTPOOL 2>&1 >/dev/null
  64 
  65                 zpool status -v $TESTPOOL | \
  66                         grep "state: DEGRADED" 2>&1 >/dev/null
  67                 if (( $? != 0 )); then
  68                         log_fail "pool $TESTPOOL status should be DEGRADED"
  69                 fi
  70 
  71                 zpool status -v $TESTPOOL | grep logs | \
  72                         grep "DEGRADED" 2>&1 >/dev/null
  73                 if (( $? == 0 )); then
  74                         log_fail "log device should display correct status"
  75                 fi
  76 
  77                 log_must destroy_pool $TESTPOOL
  78         done
  79 done
  80 
  81 log_pass "log device can survive when one of the pool device get corrupted."