#!/bin/sh # # Copyright (C) 2000-2015 Kern Sibbald # License: BSD 2-Clause; see file LICENSE-FOSS # # # Run a simple backup of the Bacula build directory # then restore it. # TestName="backup-bacula-test" JobName=backup . scripts/functions scripts/cleanup scripts/copy-confs # # Zap out any schedule in default conf file so that # it doesn't start during our test # outf="$tmp/sed_tmp" echo "s% Schedule =%# Schedule =%g" >${outf} cp $scripts/bacula-dir.conf $tmp/1 sed -f ${outf} $tmp/1 >$scripts/bacula-dir.conf change_jobname BackupClient1 $JobName start_test cat <$tmp/bconcmds @$out /dev/null messages @$out $tmp/log1.out setdebug level=4 storage=File1 label volume=TestVolume001 storage=File1 pool=File slot=1 drive=0 show job=$JobName show jobs run job=$JobName yes status storage=File1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 @sleep 1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 @sleep 1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 status storage=File1 wait messages @# @# now do a restore @# @$out $tmp/log2.out setdebug level=4 storage=File1 restore where=$tmp/bacula-restores select all done yes wait messages quit END_OF_DATA run_bacula check_for_zombie_jobs storage=File1 stop_bacula cat <$tmp/bconcmds @$out /dev/null messages @$out $tmp/log1.out setdebug level=4 storage=File1 run job=$JobName yes wait messages @# @# now do a restore @# @$out $tmp/log2.out #setbandwidth client=$CLIENT limit=100 setdebug level=4 storage=File1 restore where=$tmp/bacula-restores select all done yes wait messages quit END_OF_DATA # # Now do a second backup after making a few changes # touch ${cwd}/build/src/dird/*.o echo "test test" > ${cwd}/build/src/dird/xxx # run_bacula check_for_zombie_jobs storage=File1 stop_bacula check_two_logs check_restore_diff end_test