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