diff options
author | LOLi <[email protected]> | 2017-10-27 01:49:33 +0200 |
---|---|---|
committer | Brian Behlendorf <[email protected]> | 2017-10-26 16:49:33 -0700 |
commit | 88f9c9396bcce596db56dc880260f95c49a51d67 (patch) | |
tree | 5203ec97b33111ff803c5f7ee916175a791efb58 /tests/zfs-tests | |
parent | a032ac4b3819408b2e17085224290b6a762de79a (diff) |
Allow 'zpool events' filtering by pool name
Additionally add four new tests:
* zpool_events_clear: verify 'zpool events -c' functionality
* zpool_events_cliargs: verify command line options and arguments
* zpool_events_follow: verify 'zpool events -f'
* zpool_events_poolname: verify events filtering by pool name
Reviewed-by: Brian Behlendorf <[email protected]>
Reviewed-by: Giuseppe Di Natale <[email protected]>
Signed-off-by: loli10K <[email protected]>
Closes #3285
Closes #6762
Diffstat (limited to 'tests/zfs-tests')
12 files changed, 395 insertions, 2 deletions
diff --git a/tests/zfs-tests/tests/functional/cli_root/Makefile.am b/tests/zfs-tests/tests/functional/cli_root/Makefile.am index 6c70fa13e..bc64e3bba 100644 --- a/tests/zfs-tests/tests/functional/cli_root/Makefile.am +++ b/tests/zfs-tests/tests/functional/cli_root/Makefile.am @@ -37,6 +37,7 @@ SUBDIRS = \ zpool_create \ zpool_destroy \ zpool_detach \ + zpool_events \ zpool_expand \ zpool_export \ zpool_get \ diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/Makefile.am b/tests/zfs-tests/tests/functional/cli_root/zpool_events/Makefile.am new file mode 100644 index 000000000..44a28e289 --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/Makefile.am @@ -0,0 +1,10 @@ +pkgdatadir = $(datadir)/@PACKAGE@/zfs-tests/tests/functional/cli_root/zpool_events +dist_pkgdata_SCRIPTS = \ + setup.ksh \ + cleanup.ksh \ + zpool_events.cfg \ + zpool_events.kshlib \ + zpool_events_clear.ksh \ + zpool_events_cliargs.ksh \ + zpool_events_follow.ksh \ + zpool_events_poolname.ksh diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/cleanup.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/cleanup.ksh new file mode 100755 index 000000000..1adac153d --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/cleanup.ksh @@ -0,0 +1,19 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib + +default_cleanup diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/setup.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/setup.ksh new file mode 100755 index 000000000..e37841add --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/setup.ksh @@ -0,0 +1,21 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib + +DISK=${DISKS%% *} + +default_volume_setup $DISK diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.cfg b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.cfg new file mode 100644 index 000000000..6f5da0a76 --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.cfg @@ -0,0 +1,17 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +export EVENTS_NUM=42 diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.kshlib b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.kshlib new file mode 100755 index 000000000..a64f14a85 --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events.kshlib @@ -0,0 +1,40 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib +. $STF_SUITE/tests/functional/cli_root/zpool_events/zpool_events.cfg + +# +# Wait to allow the kernel module to process ZFS events until we reach $eventnum +# or a timeout of $timeout seconds expire, whichever comes first +# +function zpool_events_settle # <eventnum> [timeout] +{ + typeset eventnum="${1:-$EVENTS_NUM}" + typeset timeout="${2:-3}" + typeset -i count + typeset -i i=0 + + while [[ $i -lt $timeout ]]; do + count=$(zpool events -H | wc -l) + if [[ $count -ge $eventnum ]]; then + break + fi + i=$((i+1)) + sleep 1 + done + log_note "waited $i seconds" +} diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_clear.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_clear.ksh new file mode 100755 index 000000000..ab862354b --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_clear.ksh @@ -0,0 +1,58 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib +. $STF_SUITE/tests/functional/cli_root/zpool_events/zpool_events.kshlib + +# +# DESCRIPTION: +# 'zpool events -c' should successfully clear events. +# +# STRATEGY: +# 1. Clear all ZFS events +# 2. Generate some new ZFS events +# 3. Verify 'zpool events -c' successfully clears new events +# + +verify_runnable "both" + +log_assert "'zpool events -c' should successfully clear events." + +# 1. Clear all ZFS events +# This is needed because we may already over the max number or events queued +# (zfs_zevent_len_max) generated by previous tests: generating $EVENTS_NUM new +# events and then counting them is racy and leads to failues, so start from 0. +log_must zpool events -c + +# 2. Generate some new ZFS events +for i in `seq 1 $EVENTS_NUM`; do + log_must zpool clear $TESTPOOL +done +# wait a bit to allow the kernel module to process new events +zpool_events_settle +EVENTS_NUM="$(zpool events -H | wc -l)" + +# 3. Verify 'zpool events -c' successfully clear new events +CLEAR_OUTPUT="$(zpool events -c)" +if [[ "$CLEAR_OUTPUT" != "cleared $EVENTS_NUM events" ]]; then + log_fail "Failed to clear $EVENTS_NUM events: $CLEAR_OUTPUT" +fi +EVENTS_NUM="$(zpool events -H | wc -l)" +if [[ $EVENTS_NUM -ne 0 ]]; then + log_fail "Unexpected events number: $EVENTS_NUM != 0" +fi + +log_pass "'zpool events -c' successfully clears events." diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_cliargs.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_cliargs.ksh new file mode 100755 index 000000000..1623a18e4 --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_cliargs.ksh @@ -0,0 +1,89 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib + +# +# DESCRIPTION: +# 'zpool events' should only work with supported options. +# +# STRATEGY: +# 1. Verify every supported option is accepted +# 2. Verify supported options raise an error with unsupported arguments +# 3. Verify other unsupported options raise an error +# + +verify_runnable "both" + +function log_must_follow # <command> +{ + typeset command="$1" + + log_must eval "$command > /dev/null &" + pid=$! + sleep 3 + kill $pid + if [[ $? -ne 0 ]]; then + log_fail "'$command' does not work as expected." + else + log_note "'$command' works successfully." + fi +} + +log_assert "'zpool events' should only work with supported options." + +typeset goodopts=("" "-v" "-H" "-f" "-vH" "-vf" "-Hf" "-vHf") +typeset badopts=("-vV" "-Hh" "-fF" "-cC" "-x" "-o" "-") + +# 1. Verify every supported option is accepted +for opt in ${goodopts[@]} +do + # when in 'follow' mode we can't use log_must() + if [[ $opt =~ 'f' ]]; then + log_must_follow "zpool events $opt" + log_must_follow "zpool events $opt $TESTPOOL" + else + log_must eval "zpool events $opt > /dev/null" + log_must eval "zpool events $opt $TESTPOOL > /dev/null" + fi +done + +# 2.1 Verify supported options raise an error with unsupported arguments +for opt in ${goodopts[@]} +do + log_mustnot zpool events $opt "/tmp/" + log_mustnot zpool events $opt "$TESTPOOL/fs" + log_mustnot zpool events $opt "$TESTPOOL@snap" + log_mustnot zpool events $opt "$TESTPOOL#bm" + log_mustnot zpool events $opt "$TESTPOOL" "$TESTPOOL" +done + +# 2.2 Additionally, 'zpool events -c' does not support any other option|argument +log_must eval "zpool events -c > /dev/null" +log_mustnot zpool events -c "$TESTPOOL" +for opt in ${goodopts[@]} +do + log_mustnot zpool events -c $opt +done + +# 3. Verify other unsupported options raise an error +for opt in ${badopts[@]} +do + log_mustnot zpool events $opt + log_mustnot zpool events $opt "$TESTPOOL" +done + +log_pass "'zpool events' only works with supported options." diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_follow.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_follow.ksh new file mode 100755 index 000000000..a996e57c1 --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_follow.ksh @@ -0,0 +1,64 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib +. $STF_SUITE/tests/functional/cli_root/zpool_events/zpool_events.kshlib + +# +# DESCRIPTION: +# 'zpool events -f' should successfully follow new events. +# +# STRATEGY: +# 1. Clear all ZFS events +# 2. Run 'zpool events -f' in background, saving its output to a temporary file +# 3. Generate some ZFS events +# 4. Verify 'zpool events -f' successfully recorded these new events +# + +verify_runnable "both" + +function cleanup +{ + [[ -n $pid ]] && kill $pid 2>/dev/null + rm -f $EVENTS_FILE +} + +log_assert "'zpool events -f' should follow new events." +log_onexit cleanup + +EVENTS_FILE="$TESTDIR/zpool_events.$$" + +# 1. Clear all ZFS events +log_must zpool events -c + +# 2. Run 'zpool events -f' in background, saving its output to a temporary file +log_must eval "zpool events -H -f > $EVENTS_FILE &" +pid=$! + +# 3. Generate some ZFS events +for i in `seq 1 $EVENTS_NUM`; do + log_must zpool clear $TESTPOOL +done +# wait a bit to allow the kernel module to process new events +zpool_events_settle + +# 4. Verify 'zpool events -f' successfully recorded these new events +EVENTS_LOG="$(cat $EVENTS_FILE | wc -l)" +if [[ "$EVENTS_LOG" != "$EVENTS_NUM" ]]; then + log_fail "Unexpected number of events: $EVENTS_LOG != $EVENTS_NUM" +fi + +log_pass "'zpool events -f' successfully follows new events." diff --git a/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_poolname.ksh b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_poolname.ksh new file mode 100755 index 000000000..42c46712f --- /dev/null +++ b/tests/zfs-tests/tests/functional/cli_root/zpool_events/zpool_events_poolname.ksh @@ -0,0 +1,74 @@ +#!/bin/ksh -p +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2017, loli10K <[email protected]>. All rights reserved. +# + +. $STF_SUITE/include/libtest.shlib +. $STF_SUITE/tests/functional/cli_root/zpool_events/zpool_events.kshlib + +# +# DESCRIPTION: +# 'zpool events poolname' should only display events from the chosen pool. +# +# STRATEGY: +# 1. Create an additional pool +# 2. Clear all ZFS events +# 3. Generate some ZFS events on both pools +# 4. Verify 'zpool events poolname' successfully display events +# + +verify_runnable "both" + +function cleanup +{ + destroy_pool $NEWPOOL + rm -f $DISK +} + +log_assert "'zpool events poolname' should only display events from poolname." +log_onexit cleanup + +NEWPOOL="newpool" +DISK="$TEST_BASE_DIR/$NEWPOOL.dat" + +# 1. Create an additional pool +log_must truncate -s $MINVDEVSIZE $DISK +log_must zpool create $NEWPOOL $DISK + +# 2. Clear all ZFS events +log_must zpool events -c + +# 3. Generate some ZFS events on both pools +for i in `seq 1 $EVENTS_NUM`; do + log_must zpool clear $TESTPOOL +done +for i in `seq 1 $EVENTS_NUM`; do + log_must zpool clear $NEWPOOL +done +# wait a bit to allow the kernel module to process new events +zpool_events_settle + +# 4. Verify 'zpool events poolname' successfully display events +zpool events -v $TESTPOOL | + awk -v POOL=$TESTPOOL '/pool = / {if ($3 != "\""POOL"\"") exit 1}' +if [[ $? -ne 0 ]]; then + log_fail "Unexpected events for pools other than $TESTPOOL" +fi +zpool events -v $NEWPOOL | + awk -v POOL=$NEWPOOL '/pool = / {if ($3 != "\""POOL"\"") exit 1}' +if [[ $? -ne 0 ]]; then + log_fail "Unexpected events for pools other than $NEWPOOL" +fi + +log_pass "'zpool events poolname' display events only from the chosen pool." diff --git a/tests/zfs-tests/tests/functional/fault/auto_online_001_pos.ksh b/tests/zfs-tests/tests/functional/fault/auto_online_001_pos.ksh index 50f721c27..0f6e38ac2 100755 --- a/tests/zfs-tests/tests/functional/fault/auto_online_001_pos.ksh +++ b/tests/zfs-tests/tests/functional/fault/auto_online_001_pos.ksh @@ -111,7 +111,7 @@ do fi # Clear zpool events - zpool events -c $TESTPOOL + log_must zpool events -c # Online disk insert_disk $offline_disk $host diff --git a/tests/zfs-tests/tests/functional/fault/auto_replace_001_pos.ksh b/tests/zfs-tests/tests/functional/fault/auto_replace_001_pos.ksh index 0f71a575e..40a680a9b 100755 --- a/tests/zfs-tests/tests/functional/fault/auto_replace_001_pos.ksh +++ b/tests/zfs-tests/tests/functional/fault/auto_replace_001_pos.ksh @@ -122,7 +122,7 @@ if (($? != 0)); then fi # Clear zpool events -zpool events -c $TESTPOOL +log_must zpool events -c # Create another scsi_debug device setup |