3 # Run a backup of the full bacula build directory, but with the
4 # Maximum File Size set. Then do a restore of a few files to kick in
5 # disk seeking (not yet enabled), and ensure that the restored files
6 # match. Even though disk seeking is not yet enabled, this is a good test,
7 # and once it is enabled, this will test it.
10 scripts/copy-test-confs
12 echo "${cwd}/tmp/build" >/tmp/file-list
13 rm -rf ${cwd}/tmp/build
14 mkdir ${cwd}/tmp/build
15 # Copy only the .c files (to be restored)
16 cp -p ${cwd}/build/src/dird/*.c ${cwd}/tmp/build
20 sed s%\^%${cwd}/tmp/build/% 1 >restore-list
21 # At this point restore-list contains the list
22 # of files we will restore
25 # Now backup *everything*
26 rm -rf ${cwd}/tmp/build
27 mkdir ${cwd}/tmp/build
28 cp -fp ${cwd}/build/src/dird/* ${cwd}/tmp/build
29 # Enable MaximumFileSize
30 cp ${cwd}/bin/bacula-sd.conf ${cwd}/tmp/1
31 sed "s%# Maximum File Size% Maximum File Size%" ${cwd}/tmp/1 >${cwd}/bin/bacula-sd.conf
35 echo " === Starting restore-disk-seek-test `date +%R:%S` ==="
36 echo " === Starting restore-disk-seek-test `date +%R:%S` ===" >>working/log
39 bin/bacula start -v -v 2>&1 >/dev/null
40 bin/bconsole -c bin/bconsole.conf <<END_OF_DATA
44 label storage=File volume=TestVolume001
45 run job=CompressedTest yes
53 select * from JobMedia;
55 restore where=${cwd}/tmp/bacula-restores storage=File
57 <${cwd}/tmp/restore-list
65 scripts/check_for_zombie_jobs storage=File
66 bin/bacula stop 2>&1 >/dev/null
67 # Now setup a control directory of only what we *should* restore
68 rm -rf ${cwd}/tmp/build
69 mkdir ${cwd}/tmp/build
70 cp -p ${cwd}/build/src/dird/*.c ${cwd}/tmp/build
71 grep "^ Termination: *Backup OK" tmp/log1.out 2>&1 >/dev/null
73 grep "^ Termination: *Restore OK" tmp/log2.out 2>&1 >/dev/null
75 diff -r tmp/build tmp/bacula-restores${cwd}/tmp/build 2>&1 >/dev/null
76 if [ $? != 0 -o $bstat != 0 -o $rstat != 0 ] ; then
79 echo " !!!!! restore-disk-seek-test Bacula source failed!!! !!!!! "
80 echo " !!!!! restore-disk-seek-test failed!!! !!!!! " >>test.out
81 if [ $bstat != 0 -o $rstat != 0 ] ; then
82 echo " !!!!! Bad Job termination status !!!!! "
83 echo " !!!!! Bad Job termination status !!!!! " >>test.out
85 echo " !!!!! Restored files differ !!!!! "
86 echo " !!!!! Restored files differ !!!!! " >>test.out
90 echo " ===== restore-disk-seek-test Bacula source OK ===== "
91 echo " ===== restore-disk-seek-test OK ===== " >>test.out
93 # rm -rf ${cwd}/tmp/build