Files
apfstests/064
T

100 lines
2.1 KiB
Bash
Raw Normal View History

2001-11-30 03:24:22 +00:00
#! /bin/sh
2004-06-15 07:32:36 +00:00
# FS QA Test No. 064
2001-11-30 03:24:22 +00:00
#
# test multilevel dump and restores with hardlinks
#
#-----------------------------------------------------------------------
2002-06-04 23:07:56 +00:00
# Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
2001-11-30 03:24:22 +00:00
#-----------------------------------------------------------------------
#
# creator
owner=tes@sgi.com
2001-11-30 03:24:22 +00:00
seq=`basename $0`
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
# get standard environment, filters and checks
. ./common.rc
. ./common.filter
. ./common.dump
_ls_size_filter()
{
#
# Print size ($5) and fname ($9).
# The size is significant since we add to the file as part
# of a file change for the incremental.
#
# Filter out the housekeeping files of xfsrestore
#
$AWK_PROG 'NF == 9 { print $5, $9 }' |\
egrep -v 'dumpdir|housekeeping|dirattr|dirextattr|namreg|state|tree'
}
# real QA test starts here
2004-06-15 07:32:36 +00:00
_supported_fs xfs
_supported_os IRIX Linux
2001-11-30 03:24:22 +00:00
_create_dumpdir_hardlinks 9
echo "Do the incremental dumps"
i=0
while [ $i -le 9 ]; do
if [ $i -gt 0 ]; then
sleep 2
_modify_level $i
2001-11-30 03:24:22 +00:00
fi
_stable_fs
sleep 2
echo "********* level $i ***********" >>$seq.full
date >>$seq.full
find $SCRATCH_MNT -exec $here/src/lstat64 {} \; | sed 's/(00.*)//' >$tmp.dates.$i
if [ $i -gt 0 ]; then
2009-03-25 20:53:36 +01:00
let level_1=$i-1
diff -c $tmp.dates.$level_1 $tmp.dates.$i >>$seq.full
else
cat $tmp.dates.$i >>$seq.full
fi
2001-11-30 03:24:22 +00:00
dump_file=$tmp.df.level$i
_do_dump_file -l $i
2009-03-25 20:53:36 +01:00
let i=$i+1
2001-11-30 03:24:22 +00:00
done
echo "Listing of what files we start with:"
ls -l $dump_dir | _ls_size_filter
echo "Look at what files are contained in the inc. dump"
i=0
while [ $i -le 9 ]; do
echo ""
echo "restoring from df.level$i"
dump_file=$tmp.df.level$i
_do_restore_toc
2009-03-25 20:53:36 +01:00
let i=$i+1
2001-11-30 03:24:22 +00:00
done
echo "Do the cumulative restores"
i=0
while [ $i -le 9 ]; do
dump_file=$tmp.df.level$i
echo ""
echo "restoring from df.level$i"
_do_restore_file_cum -l $i
echo "ls -l restore_dir"
2001-12-03 06:08:15 +00:00
ls -lR $restore_dir | _ls_size_filter | _check_quota_file
2009-03-25 20:53:36 +01:00
let i=$i+1
2001-11-30 03:24:22 +00:00
done
# success, all done
status=0
exit