fix up exit status handling
[xfstests-dev.git] / 064
1 #! /bin/sh
2 # XFS QA Test No. 064
3 #
4 # test multilevel dump and restores with hardlinks
5 #
6 #-----------------------------------------------------------------------
7 # Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
8
9 # This program is free software; you can redistribute it and/or modify it
10 # under the terms of version 2 of the GNU General Public License as
11 # published by the Free Software Foundation.
12
13 # This program is distributed in the hope that it would be useful, but
14 # WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
17 # Further, this software is distributed without any warranty that it is
18 # free of the rightful claim of any third person regarding infringement
19 # or the like.  Any license provided herein, whether implied or
20 # otherwise, applies only to this software file.  Patent licenses, if
21 # any, provided herein do not apply to combinations of this program with
22 # other software, or any other product whatsoever.
23
24 # You should have received a copy of the GNU General Public License along
25 # with this program; if not, write the Free Software Foundation, Inc., 59
26 # Temple Place - Suite 330, Boston MA 02111-1307, USA.
27
28 # Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
29 # Mountain View, CA  94043, or:
30
31 # http://www.sgi.com 
32
33 # For further information regarding this notice, see: 
34
35 # http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
36 #-----------------------------------------------------------------------
37 #
38 # creator
39 owner=tes@sgi.com
40
41 seq=`basename $0`
42 echo "QA output created by $seq"
43
44 here=`pwd`
45 tmp=/tmp/$$
46 status=1        # failure is the default!
47 trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
48
49 # get standard environment, filters and checks
50 . ./common.rc
51 . ./common.filter
52 . ./common.dump
53
54
55 _ls_size_filter()
56 {
57     #
58     # Print size ($5) and fname ($9).
59     # The size is significant since we add to the file as part
60     # of a file change for the incremental.
61     #
62     # Filter out the housekeeping files of xfsrestore
63     #
64     $AWK_PROG 'NF == 9 { print $5, $9 }' |\
65     egrep -v 'dumpdir|housekeeping|dirattr|dirextattr|namreg|state|tree' 
66 }
67
68 # real QA test starts here
69
70 _create_dumpdir_hardlinks 9
71
72 echo "Do the incremental dumps"
73 i=0
74 while [ $i -le 9 ]; do
75     if [ $i -gt 0 ]; then
76         _modify_level $i
77         sleep 2
78         _stable_fs
79     fi 
80     echo "********* level $i ***********" >>$seq.full
81     date >>$seq.full
82     find $SCRATCH_MNT -exec $here/src/lstat64 {} \; >$tmp.dates.$i
83     if [ $i -gt 0 ]; then
84        level_1=`expr $i - 1`
85        diff -c $tmp.dates.$level_1 $tmp.dates.$i >>$seq.full
86     else
87        cat $tmp.dates.$i >>$seq.full
88     fi
89
90     dump_file=$tmp.df.level$i
91     _do_dump_file -l $i
92     i=`expr $i + 1`     
93 done
94
95 echo "Listing of what files we start with:"
96 ls -l $dump_dir | _ls_size_filter
97
98 echo "Look at what files are contained in the inc. dump"
99 i=0
100 while [ $i -le 9 ]; do
101     echo ""
102     echo "restoring from df.level$i"
103     dump_file=$tmp.df.level$i
104     _do_restore_toc
105     i=`expr $i + 1`     
106 done
107
108 echo "Do the cumulative restores"
109 i=0
110 while [ $i -le 9 ]; do
111     dump_file=$tmp.df.level$i
112     echo ""
113     echo "restoring from df.level$i"
114     _do_restore_file_cum -l $i
115     echo "ls -l restore_dir"
116     ls -lR $restore_dir | _ls_size_filter | _check_quota_file
117     i=`expr $i + 1`     
118 done
119
120 # success, all done
121 status=0
122 exit