| #!/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 (c) 2017 by Lawrence Livermore National Security, LLC. |
| # Use is subject to license terms. |
| # |
| |
| # DESCRIPTION: |
| # Verify zpool events command logs events. |
| # |
| # STRATEGY: |
| # 1. Execute zpool sub-commands on a pool. |
| # 2. Verify the expected events are logged in 'zpool events'. |
| # 3. Verify the expected events are logged by the ZED. |
| |
| . $STF_SUITE/include/libtest.shlib |
| . $STF_SUITE/tests/functional/events/events_common.kshlib |
| |
| verify_runnable "both" |
| |
| function cleanup |
| { |
| if poolexists $MPOOL; then |
| destroy_pool $MPOOL |
| fi |
| |
| for file in $VDEV1 $VDEV2 $VDEV3 $VDEV4; do |
| [[ -f $file ]] && rm -f $file |
| done |
| |
| log_must zed_stop |
| } |
| |
| log_assert "Verify zpool sub-commands generate expected events" |
| log_onexit cleanup |
| |
| log_must truncate -s $MINVDEVSIZE $VDEV1 $VDEV2 $VDEV3 $VDEV4 |
| |
| log_must zpool events -c |
| log_must zed_start |
| |
| # Create a mirrored pool with two devices. |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.pool_create" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool create $MPOOL mirror $VDEV1 $VDEV2" |
| |
| # Set a pool property. |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| "zpool set comment=string $MPOOL" |
| |
| # Add a cache device then remove it. |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| -e "sysevent.fs.zfs.vdev_add" \ |
| "zpool add -f $MPOOL spare $VDEV3" |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.vdev_remove_aux" \ |
| "zpool remove $MPOOL $VDEV3" |
| |
| # Add a log device then remove it. |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| -e "sysevent.fs.zfs.vdev_add" \ |
| "zpool add -f $MPOOL log $VDEV3" |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.vdev_remove_dev" \ |
| "zpool remove $MPOOL $VDEV3" |
| |
| # Offline then online a device. |
| run_and_verify -p "$MPOOL"\ |
| -e "resource.fs.zfs.statechange" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool offline $MPOOL $VDEV1" |
| run_and_verify -p "$MPOOL" -d 10 \ |
| -e "resource.fs.zfs.statechange" \ |
| -e "sysevent.fs.zfs.vdev_online" \ |
| -e "sysevent.fs.zfs.resilver_start" \ |
| -e "sysevent.fs.zfs.resilver_finish" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool online $MPOOL $VDEV1" |
| |
| # Attach then detach a device from the mirror. |
| run_and_verify -p "$MPOOL" -d 10 \ |
| -e "sysevent.fs.zfs.vdev_attach" \ |
| -e "sysevent.fs.zfs.resilver_start" \ |
| -e "sysevent.fs.zfs.resilver_finish" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool attach $MPOOL $VDEV1 $VDEV4" |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.vdev_remove" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool detach $MPOOL $VDEV4" |
| |
| # Replace a device |
| run_and_verify -p "$MPOOL" -d 10 \ |
| -e "sysevent.fs.zfs.vdev_attach" \ |
| -e "sysevent.fs.zfs.resilver_start" \ |
| -e "sysevent.fs.zfs.resilver_finish" \ |
| -e "sysevent.fs.zfs.vdev_remove" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool replace -f $MPOOL $VDEV1 $VDEV4" |
| |
| # Scrub a pool. |
| run_and_verify -p "$MPOOL" -d 10 \ |
| -e "sysevent.fs.zfs.scrub_start" \ |
| -e "sysevent.fs.zfs.scrub_finish" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| "zpool scrub $MPOOL" |
| |
| # Export then import a pool |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.pool_export" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool export $MPOOL" |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.pool_import" \ |
| -e "sysevent.fs.zfs.history_event" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool import -d $TEST_BASE_DIR $MPOOL" |
| |
| # Destroy the pool |
| run_and_verify -p "$MPOOL" \ |
| -e "sysevent.fs.zfs.pool_destroy" \ |
| -e "sysevent.fs.zfs.config_sync" \ |
| "zpool destroy $MPOOL" |
| |
| log_pass "Verify zpool sub-commands generate expected events" |