]> git.proxmox.com Git - mirror_zfs.git/blob - tests/zfs-tests/tests/functional/history/history_007_pos.ksh
Add the ZFS Test Suite
[mirror_zfs.git] / tests / zfs-tests / tests / functional / history / history_007_pos.ksh
1 #!/bin/ksh -p
2 #
3 # CDDL HEADER START
4 #
5 # The contents of this file are subject to the terms of the
6 # Common Development and Distribution License (the "License").
7 # You may not use this file except in compliance with the License.
8 #
9 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 # or http://www.opensolaris.org/os/licensing.
11 # See the License for the specific language governing permissions
12 # and limitations under the License.
13 #
14 # When distributing Covered Code, include this CDDL HEADER in each
15 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 # If applicable, add the following below this CDDL HEADER, with the
17 # fields enclosed by brackets "[]" replaced with your own identifying
18 # information: Portions Copyright [yyyy] [name of copyright owner]
19 #
20 # CDDL HEADER END
21 #
22
23 #
24 # Copyright 2007 Sun Microsystems, Inc. All rights reserved.
25 # Use is subject to license terms.
26 #
27
28 #
29 # Copyright (c) 2013 by Delphix. All rights reserved.
30 #
31
32 . $STF_SUITE/include/libtest.shlib
33 . $STF_SUITE/tests/functional/history/history_common.kshlib
34
35 #
36 # DESCRIPTION:
37 # Verify command history moves with pool while pool being migrated
38 #
39 # STRATEGY:
40 # 1. Import uniform platform and cross platform pools
41 # 2. Contract the command history of the imported pool
42 # 3. Compare imported history log with the previous log.
43 #
44
45 verify_runnable "global"
46
47 function cleanup
48 {
49 poolexists $migratedpoolname && \
50 log_must $ZPOOL destroy -f $migratedpoolname
51
52 [[ -d $import_dir ]] && $RM -rf $import_dir
53 }
54
55 log_assert "Verify command history moves with migrated pool."
56 log_onexit cleanup
57
58 tst_dir=$STF_SUITE/tests/functional/history
59 import_dir=$TESTDIR/importdir.$$
60 migrated_cmds_f=$import_dir/migrated_history.$$
61 migratedpoolname=$MIGRATEDPOOLNAME
62 typeset -i RET=1
63 typeset -i linenum=0
64
65 [[ ! -d $import_dir ]] && log_must $MKDIR $import_dir
66
67 # We test the migrations on both uniform platform and cross platform
68 for arch in "i386" "sparc"; do
69 log_must $CP $tst_dir/${arch}.orig_history.txt $import_dir
70 orig_cmds_f=$import_dir/${arch}.orig_history.txt
71 # remove blank line
72 orig_cmds_f1=$import_dir/${arch}.orig_history_1.txt
73 $CAT $orig_cmds_f | $GREP -v "^$" > $orig_cmds_f1
74
75 log_must $CP $tst_dir/${arch}.migratedpool.DAT.Z $import_dir
76 log_must $UNCOMPRESS $import_dir/${arch}.migratedpool.DAT.Z
77
78 # destroy the pool with same name, so that import operation succeeds.
79 poolexists $migratedpoolname && \
80 log_must $ZPOOL destroy -f $migratedpoolname
81
82 log_must $ZPOOL import -d $import_dir $migratedpoolname
83 TZ=$TIMEZONE $ZPOOL history $migratedpoolname | $GREP -v "^$" \
84 >$migrated_cmds_f
85 RET=$?
86 (( $RET != 0 )) && log_fail "$ZPOOL histroy $migratedpoolname fails."
87
88 # The migrated history file should differ with original history file on
89 # two commands -- 'export' and 'import', which are included in migrated
90 # history file but not in original history file. so, check the two
91 # commands firstly in migrated history file and then delete them, and
92 # then compare this filtered file with the original history file. They
93 # should be identical at this time.
94 for subcmd in "export" "import"; do
95 $GREP "$subcmd" $migrated_cmds_f >/dev/null 2>&1
96 RET=$?
97 (( $RET != 0 )) && log_fail "zpool $subcmd is not logged for" \
98 "the imported pool $migratedpoolname."
99 done
100
101 tmpfile=$import_dir/cmds_tmp.$$
102 linenum=`$CAT $migrated_cmds_f | $WC -l`
103 (( linenum = linenum - 2 ))
104 $HEAD -n $linenum $migrated_cmds_f > $tmpfile
105 log_must $DIFF $tmpfile $orig_cmds_f1
106
107 # cleanup for next loop testing
108 log_must $ZPOOL destroy -f $migratedpoolname
109 log_must $RM -f `$LS $import_dir`
110 done
111
112 log_pass "Verify command history moves with migrated pool."