]> git.sur5r.net Git - bacula/bacula/blob - regress/tests/estimate-test
ebl cleanup test files
[bacula/bacula] / regress / tests / estimate-test
1 #!/bin/sh
2 #
3 # Run a simple backup of the Bacula build directory
4 #   then restore it.
5 #
6 TestName="estimate-test"
7 . scripts/functions
8 JobName=BackupClient1
9
10 scripts/cleanup
11 scripts/copy-confs
12
13 #
14 # Zap out any schedule in default conf file so that
15 #  it doesn't start during our test
16 #
17 outf="$tmp/sed_tmp"
18 echo "s%  Schedule =%# Schedule =%g" >${outf}
19 cp $scripts/bacula-dir.conf $tmp/1
20 sed -f ${outf} $tmp/1 >$scripts/bacula-dir.conf
21
22 start_test
23
24 rm -rf ${cwd}/build/src/test ${cwd}/build/po/test
25 mkdir ${cwd}/build/src/test
26 touch ${cwd}/build/src/test/test1 ${cwd}/build/src/test/test2
27
28 cat <<END_OF_DATA >$tmp/bconcmds
29 @output /dev/null
30 messages
31 @$out $tmp/log1.out
32 label volume=TestVolume001 storage=File pool=Default
33 run job=$JobName yes
34 wait
35 messages
36 @#
37 @# now do a restore
38 @#
39 @$out $tmp/log2.out
40 restore where=$tmp/bacula-restores select all done
41 yes
42 wait
43 messages
44 @$out
45 quit
46 END_OF_DATA
47
48 run_bacula
49
50 check_two_logs
51 check_restore_diff
52
53 mv ${cwd}/build/src/test ${cwd}/build/po/test
54
55 cat <<END_OF_DATA >$tmp/bconcmds
56 @output /dev/null
57 messages
58 @$out $tmp/log3.out
59 estimate listing job=$JobName level=incremental
60 messages
61 quit
62 END_OF_DATA
63
64 run_bconsole
65
66 cat <<END_OF_DATA >$tmp/bconcmds
67 @output /dev/null
68 messages
69 @$out $tmp/log4.out
70 estimate listing job=$JobName level=incremental accurate=yes
71 messages
72 quit
73 END_OF_DATA
74
75 run_bconsole
76
77 cp $scripts/bacula-dir.conf $tmp/1
78 sed 's/JobDefs {/JobDefs { Accurate=yes/' $tmp/1>$scripts/bacula-dir.conf
79
80 cat <<END_OF_DATA >$tmp/bconcmds
81 @output /dev/null
82 messages
83 @$out $tmp/log5.out
84 reload
85 estimate listing job=$JobName level=incremental
86 messages
87 quit
88 END_OF_DATA
89
90 run_bconsole
91
92 cat <<END_OF_DATA >$tmp/bconcmds
93 @output /dev/null
94 messages
95 @$out $tmp/log6.out
96 estimate listing job=$JobName level=incremental accurate=no
97 messages
98 quit
99 END_OF_DATA
100
101 run_bconsole
102
103 rm -rf ${cwd}/build/po/test
104
105 grep test1 $tmp/log3.out > /dev/null
106 if [ $? = 0 ]; then
107     print_debug "Normal estimate shouldn't detect test1 file in $tmp/log3.out"
108     dstat=2
109 fi
110
111 grep test1 $tmp/log4.out > /dev/null
112 if [ $? != 0 ]; then
113     print_debug "Accurate=yes estimate should detect test1 file in $tmp/log4.out"
114     dstat=2
115 fi
116
117 grep test1 $tmp/log5.out > /dev/null
118 if [ $? != 0 ]; then
119     print_debug "Accurate estimate should detect test1 file in $tmp/log5.out"
120     dstat=2
121 fi
122
123 grep test1 $tmp/log6.out > /dev/null
124 if [ $? = 0 ]; then
125     print_debug "Accurate=no estimate shouldn't detect test1 file in $tmp/log6.out"
126     dstat=2
127 fi
128
129 check_for_zombie_jobs storage=File
130
131 stop_bacula
132 end_test