Add more sanity testing for zdb input args
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: John Kennedy <john.kennedy@delphix.com> Signed-off-by: sara hartse <sara.hartse@delphix.com> Closes #10243
This commit is contained in:
parent
fa25460538
commit
89a6610ed0
|
@ -103,8 +103,8 @@ tests = [ 'clean_mirror_001_pos', 'clean_mirror_002_pos',
|
|||
tags = ['functional', 'clean_mirror']
|
||||
|
||||
[tests/functional/cli_root/zdb]
|
||||
tests = ['zdb_001_neg', 'zdb_002_pos', 'zdb_003_pos', 'zdb_004_pos',
|
||||
'zdb_005_pos', 'zdb_006_pos', 'zdb_checksum', 'zdb_decompress',
|
||||
tests = ['zdb_002_pos', 'zdb_003_pos', 'zdb_004_pos', 'zdb_005_pos',
|
||||
'zdb_006_pos', 'zdb_args_neg', 'zdb_args_pos', 'zdb_checksum', 'zdb_decompress',
|
||||
'zdb_object_range_neg', 'zdb_object_range_pos', 'zdb_display_block',
|
||||
'zdb_objset_id']
|
||||
pre =
|
||||
|
|
|
@ -1,11 +1,12 @@
|
|||
pkgdatadir = $(datadir)/@PACKAGE@/zfs-tests/tests/functional/cli_root/zdb
|
||||
dist_pkgdata_SCRIPTS = \
|
||||
zdb_001_neg.ksh \
|
||||
zdb_002_pos.ksh \
|
||||
zdb_003_pos.ksh \
|
||||
zdb_004_pos.ksh \
|
||||
zdb_005_pos.ksh \
|
||||
zdb_006_pos.ksh \
|
||||
zdb_args_neg.ksh \
|
||||
zdb_args_pos.ksh \
|
||||
zdb_checksum.ksh \
|
||||
zdb_decompress.ksh \
|
||||
zdb_object_range_neg.ksh \
|
||||
|
|
|
@ -56,18 +56,28 @@ set -A args "create" "add" "destroy" "import fakepool" \
|
|||
"add mirror fakepool" "add raidz fakepool" \
|
||||
"add raidz1 fakepool" "add raidz2 fakepool" \
|
||||
"setvprop" "blah blah" "-%" "--?" "-*" "-=" \
|
||||
"-a" "-f" "-g" "-h" "-j" "-m" "-n" "-o" "-p" \
|
||||
"-p /tmp" "-r" "-t" "-w" "-x" "-y" "-z" \
|
||||
"-D" "-E" "-G" "-H" "-I" "-J" "-K" "-M" \
|
||||
"-N" "-Q" "-R" "-S" "-T" "-W" "-Z"
|
||||
"-a" "-f" "-g" "-j" "-n" "-o" "-p" "-p /tmp" "-r" \
|
||||
"-t" "-w" "-y" "-z" "-E" "-H" "-I" "-J" "-K" \
|
||||
"-N" "-Q" "-R" "-T" "-W" "-Z"
|
||||
|
||||
log_assert "Execute zdb using invalid parameters."
|
||||
|
||||
typeset -i i=0
|
||||
while [[ $i -lt ${#args[*]} ]]; do
|
||||
log_mustnot zdb ${args[i]}
|
||||
log_onexit cleanup
|
||||
|
||||
((i = i + 1))
|
||||
done
|
||||
function cleanup
|
||||
{
|
||||
default_cleanup_noexit
|
||||
}
|
||||
|
||||
function test_imported_pool
|
||||
{
|
||||
for i in ${args[@]}; do
|
||||
log_mustnot zdb $i $TESTPOOL
|
||||
done
|
||||
}
|
||||
|
||||
default_mirror_setup_noexit $DISKS
|
||||
|
||||
test_imported_pool
|
||||
|
||||
log_pass "Badly formed zdb parameters fail as expected."
|
|
@ -0,0 +1,104 @@
|
|||
#!/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) 2012, 2020 by Delphix. All rights reserved.
|
||||
#
|
||||
|
||||
. $STF_SUITE/include/libtest.shlib
|
||||
|
||||
#
|
||||
# DESCRIPTION:
|
||||
# ZDB allows a large number of possible inputs
|
||||
# and combinations of those inputs. Test for non-zero
|
||||
# exit values. These input options are based on the zdb
|
||||
# man page
|
||||
#
|
||||
# STRATEGY:
|
||||
# 1. Create an array containing value zdb parameters.
|
||||
# 2. For each element, execute the sub-command.
|
||||
# 3. Verify it does not return a error.
|
||||
#
|
||||
|
||||
verify_runnable "global"
|
||||
|
||||
log_assert "Execute zdb using valid parameters."
|
||||
|
||||
log_onexit cleanup
|
||||
|
||||
function cleanup
|
||||
{
|
||||
default_cleanup_noexit
|
||||
}
|
||||
|
||||
function test_imported_pool
|
||||
{
|
||||
typeset -a args=("-A" "-b" "-C" "-c" "-d" "-D" "-G" "-h" "-i" "-L" \
|
||||
"-M" "-P" "-s" "-v" "-Y")
|
||||
for i in ${args[@]}; do
|
||||
log_must eval "zdb $i $TESTPOOL >/dev/null"
|
||||
done
|
||||
}
|
||||
|
||||
function test_exported_pool
|
||||
{
|
||||
log_must zpool export $TESTPOOL
|
||||
typeset -a args=("-A" "-b" "-C" "-c" "-d" "-D" "-F" "-G" "-h" "-i" "-L" "-M" \
|
||||
"-P" "-s" "-v" "-X" "-Y")
|
||||
for i in ${args[@]}; do
|
||||
log_must eval "zdb -e $i $TESTPOOL >/dev/null"
|
||||
done
|
||||
log_must zpool import $TESTPOOL
|
||||
}
|
||||
|
||||
function test_vdev
|
||||
{
|
||||
typeset -a args=("-A" "-q" "-u" "-Aqu")
|
||||
VDEVS=$(get_pool_devices ${TESTPOOL} ${DEV_RDSKDIR})
|
||||
log_note $VDEVS
|
||||
set -A VDEV_ARRAY $VDEVS
|
||||
for i in ${args[@]}; do
|
||||
log_must eval "zdb -l $i ${VDEV_ARRAY[0]} >/dev/null"
|
||||
done
|
||||
}
|
||||
|
||||
function test_metaslab
|
||||
{
|
||||
typeset -a args=("-A" "-L" "-P" "-Y")
|
||||
for i in ${args[@]}; do
|
||||
log_must eval "zdb -m $i $TESTPOOL >/dev/null"
|
||||
done
|
||||
}
|
||||
|
||||
default_mirror_setup_noexit $DISKS
|
||||
|
||||
test_imported_pool
|
||||
test_exported_pool
|
||||
test_vdev
|
||||
test_metaslab
|
||||
|
||||
log_pass "Valid zdb parameters pass as expected."
|
Loading…
Reference in New Issue