1f38cb554SJohn Wren Kennedy#!/bin/ksh -p 2f38cb554SJohn Wren Kennedy# 3f38cb554SJohn Wren Kennedy# CDDL HEADER START 4f38cb554SJohn Wren Kennedy# 5f38cb554SJohn Wren Kennedy# The contents of this file are subject to the terms of the 6f38cb554SJohn Wren Kennedy# Common Development and Distribution License (the "License"). 7f38cb554SJohn Wren Kennedy# You may not use this file except in compliance with the License. 8f38cb554SJohn Wren Kennedy# 9f38cb554SJohn Wren Kennedy# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10f38cb554SJohn Wren Kennedy# or http://www.opensolaris.org/os/licensing. 11f38cb554SJohn Wren Kennedy# See the License for the specific language governing permissions 12f38cb554SJohn Wren Kennedy# and limitations under the License. 13f38cb554SJohn Wren Kennedy# 14f38cb554SJohn Wren Kennedy# When distributing Covered Code, include this CDDL HEADER in each 15f38cb554SJohn Wren Kennedy# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16f38cb554SJohn Wren Kennedy# If applicable, add the following below this CDDL HEADER, with the 17f38cb554SJohn Wren Kennedy# fields enclosed by brackets "[]" replaced with your own identifying 18f38cb554SJohn Wren Kennedy# information: Portions Copyright [yyyy] [name of copyright owner] 19f38cb554SJohn Wren Kennedy# 20f38cb554SJohn Wren Kennedy# CDDL HEADER END 21f38cb554SJohn Wren Kennedy# 22f38cb554SJohn Wren Kennedy 23f38cb554SJohn Wren Kennedy# 24f38cb554SJohn Wren Kennedy# Copyright 2007 Sun Microsystems, Inc. All rights reserved. 25f38cb554SJohn Wren Kennedy# Use is subject to license terms. 26f38cb554SJohn Wren Kennedy# 27f38cb554SJohn Wren Kennedy 28f38cb554SJohn Wren Kennedy# 29*1d32ba66SJohn Wren Kennedy# Copyright (c) 2013, 2016 by Delphix. All rights reserved. 30f38cb554SJohn Wren Kennedy# 31f38cb554SJohn Wren Kennedy 32f38cb554SJohn Wren Kennedy. $STF_SUITE/include/libtest.shlib 33f38cb554SJohn Wren Kennedy 34f38cb554SJohn Wren Kennedy# 35f38cb554SJohn Wren Kennedy# DESCRIPTION: 36f38cb554SJohn Wren Kennedy# 'zpool history' can cope with simultaneous commands. 37f38cb554SJohn Wren Kennedy# 38f38cb554SJohn Wren Kennedy# STRATEGY: 39f38cb554SJohn Wren Kennedy# 1. Create test pool and test fs. 40f38cb554SJohn Wren Kennedy# 2. Loop 100 times, set properties to test fs simultaneously. 41f38cb554SJohn Wren Kennedy# 3. Wait for all the command execution complete. 42f38cb554SJohn Wren Kennedy# 4. Make sure all the commands was logged by 'zpool history'. 43f38cb554SJohn Wren Kennedy# 44f38cb554SJohn Wren Kennedy 45f38cb554SJohn Wren Kennedyverify_runnable "global" 46f38cb554SJohn Wren Kennedy 47f38cb554SJohn Wren Kennedylog_assert "'zpool history' can cope with simultaneous commands." 48f38cb554SJohn Wren Kennedy 49*1d32ba66SJohn Wren Kennedytypeset -i orig_count=$(zpool history $spool | wc -l | awk '{print $1}') 50f38cb554SJohn Wren Kennedy 51f38cb554SJohn Wren Kennedytypeset -i i=0 52f38cb554SJohn Wren Kennedywhile ((i < 10)); do 53*1d32ba66SJohn Wren Kennedy zfs set compression=off $TESTPOOL/$TESTFS & 54*1d32ba66SJohn Wren Kennedy zfs set atime=off $TESTPOOL/$TESTFS & 55*1d32ba66SJohn Wren Kennedy zfs create $TESTPOOL/$TESTFS1 & 56*1d32ba66SJohn Wren Kennedy zfs create $TESTPOOL/$TESTFS2 & 57*1d32ba66SJohn Wren Kennedy zfs create $TESTPOOL/$TESTFS3 & 58f38cb554SJohn Wren Kennedy 59f38cb554SJohn Wren Kennedy wait 60f38cb554SJohn Wren Kennedy 61*1d32ba66SJohn Wren Kennedy zfs snapshot $TESTPOOL/$TESTFS1@snap & 62*1d32ba66SJohn Wren Kennedy zfs snapshot $TESTPOOL/$TESTFS2@snap & 63*1d32ba66SJohn Wren Kennedy zfs snapshot $TESTPOOL/$TESTFS3@snap & 64f38cb554SJohn Wren Kennedy 65f38cb554SJohn Wren Kennedy wait 66f38cb554SJohn Wren Kennedy 67*1d32ba66SJohn Wren Kennedy zfs clone $TESTPOOL/$TESTFS1@snap $TESTPOOL/clone1 & 68*1d32ba66SJohn Wren Kennedy zfs clone $TESTPOOL/$TESTFS2@snap $TESTPOOL/clone2 & 69*1d32ba66SJohn Wren Kennedy zfs clone $TESTPOOL/$TESTFS3@snap $TESTPOOL/clone3 & 70f38cb554SJohn Wren Kennedy 71f38cb554SJohn Wren Kennedy wait 72f38cb554SJohn Wren Kennedy 73*1d32ba66SJohn Wren Kennedy zfs promote $TESTPOOL/clone1 & 74*1d32ba66SJohn Wren Kennedy zfs promote $TESTPOOL/clone2 & 75*1d32ba66SJohn Wren Kennedy zfs promote $TESTPOOL/clone3 & 76f38cb554SJohn Wren Kennedy 77f38cb554SJohn Wren Kennedy wait 78f38cb554SJohn Wren Kennedy 79*1d32ba66SJohn Wren Kennedy zfs destroy $TESTPOOL/$TESTFS1 & 80*1d32ba66SJohn Wren Kennedy zfs destroy $TESTPOOL/$TESTFS2 & 81*1d32ba66SJohn Wren Kennedy zfs destroy $TESTPOOL/$TESTFS3 & 82f38cb554SJohn Wren Kennedy 83f38cb554SJohn Wren Kennedy wait 84f38cb554SJohn Wren Kennedy 85*1d32ba66SJohn Wren Kennedy zfs destroy -Rf $TESTPOOL/clone1 & 86*1d32ba66SJohn Wren Kennedy zfs destroy -Rf $TESTPOOL/clone2 & 87*1d32ba66SJohn Wren Kennedy zfs destroy -Rf $TESTPOOL/clone3 & 88f38cb554SJohn Wren Kennedy 89f38cb554SJohn Wren Kennedy wait 90f38cb554SJohn Wren Kennedy ((i += 1)) 91f38cb554SJohn Wren Kennedydone 92f38cb554SJohn Wren Kennedy 93*1d32ba66SJohn Wren Kennedytypeset -i entry_count=$(zpool history $spool | wc -l | awk '{print $1}') 94f38cb554SJohn Wren Kennedy 95f38cb554SJohn Wren Kennedyif ((entry_count - orig_count != 200)); then 96f38cb554SJohn Wren Kennedy log_fail "The entries count error: entry_count=$entry_count " \ 97f38cb554SJohn Wren Kennedy "orig_count = $orig_count" 98f38cb554SJohn Wren Kennedyfi 99f38cb554SJohn Wren Kennedy 100f38cb554SJohn Wren Kennedylog_pass "'zpool history' can cope with simultaneous commands." 101