]> git.ipfire.org Git - thirdparty/bacula.git/commitdiff
BEE Backport regress/tests/virtual-corruption-test
authorEric Bollengier <eric@baculasystems.com>
Wed, 2 Sep 2020 13:37:22 +0000 (15:37 +0200)
committerEric Bollengier <eric@baculasystems.com>
Thu, 24 Mar 2022 08:02:56 +0000 (09:02 +0100)
This commit is the result of the squash of the following main commits:

Author: Eric Bollengier <eric@baculasystems.com>
Date:   Tue Jul 21 10:28:13 2020 +0200

    regress: Add copyright to regress scripts

Author: Eric Bollengier <eric@baculasystems.com>
Date:   Wed Jun 25 11:17:37 2014 +0200

    regress: Backport virtual-corruption-test from 6.6

regress/tests/virtual-corruption-test [new file with mode: 0755]

diff --git a/regress/tests/virtual-corruption-test b/regress/tests/virtual-corruption-test
new file mode 100755 (executable)
index 0000000..51e2df6
--- /dev/null
@@ -0,0 +1,140 @@
+#!/bin/sh
+#
+# Copyright (C) 2000-2020 Kern Sibbald
+# License: BSD 2-Clause; see file LICENSE-FOSS
+#
+# Run a backup of the Bacula build directory then do a 
+#   Virtual Full backup to another device.
+#
+TestName="virtual-corruption-test"
+JobName=Vbackup
+. scripts/functions
+
+
+scripts/cleanup
+scripts/copy-test-confs
+cp -f scripts/vf-bug-bacula-dir.conf $conf/bacula-dir.conf
+cp -f scripts/vf-bug-bacula-sd.conf $conf/bacula-sd.conf
+
+$bperl -e "create_many_files_size('$tmp/build', 50000)"
+echo "${cwd}/tmp/build" >${cwd}/tmp/file-list
+
+
+change_jobname NightlySave $JobName
+start_test
+
+#
+# Note, we first backup into Pool Default, 
+#          then Migrate into Pool Full. 
+#              Pool Default uses Storage=disk
+#              Pool Full    uses Storage=disk2
+
+# Write out bconsole commands
+cat <<END_OF_DATA >${cwd}/tmp/bconcmds
+@output /dev/null
+messages
+@$out $tmp/log1.out
+@# run several jobs
+@exec "sh -c 'date > ${cwd}/build/date'"
+run client=client1-fd job=$JobName level=Full yes
+run client=client2-fd job=$JobName level=Full yes
+run client=client3-fd job=$JobName level=Full yes
+run client=client4-fd job=$JobName level=Full yes
+run client=client5-fd job=$JobName level=Full yes
+run client=client6-fd job=$JobName level=Full yes
+run client=client7-fd job=$JobName level=Full yes
+run client=client8-fd job=$JobName level=Full yes
+wait
+messages
+list jobs
+@exec "sh -c 'touch ${cwd}/tmp/build/A/*'"
+run client=client1-fd job=$JobName level=Incremental yes
+run client=client2-fd job=$JobName level=Incremental yes
+run client=client3-fd job=$JobName level=Incremental yes
+run client=client4-fd job=$JobName level=Incremental yes
+run client=client5-fd job=$JobName level=Incremental yes
+run client=client6-fd job=$JobName level=Incremental yes
+run client=client7-fd job=$JobName level=Incremental yes
+run client=client8-fd job=$JobName level=Incremental yes
+wait
+messages
+list jobs
+@exec "sh -c 'touch ${cwd}/tmp/build/B/*'"
+run client=client1-fd job=$JobName level=Differential yes
+run client=client2-fd job=$JobName level=Differential yes
+run client=client3-fd job=$JobName level=Differential yes
+run client=client4-fd job=$JobName level=Differential yes
+run client=client5-fd job=$JobName level=Differential yes
+run client=client6-fd job=$JobName level=Differential yes
+run client=client7-fd job=$JobName level=Differential yes
+run client=client8-fd job=$JobName level=Differential yes
+wait
+messages
+list jobs
+@exec "sh -c 'touch ${cwd}/tmp/build/C/*'"
+run client=client1-fd job=$JobName level=Incremental yes
+run client=client2-fd job=$JobName level=Incremental yes
+run client=client3-fd job=$JobName level=Incremental yes
+run client=client4-fd job=$JobName level=Incremental yes
+run client=client5-fd job=$JobName level=Incremental yes
+run client=client6-fd job=$JobName level=Incremental yes
+run client=client7-fd job=$JobName level=Incremental yes
+run client=client8-fd job=$JobName level=Incremental yes
+wait
+messages
+list jobs
+list volumes
+@# 
+@# now do a normal restore of normal backups
+@#
+setdebug level=10 dir trace=1
+restore where=${cwd}/tmp/bacula-restores client=client1-fd select
+unmark *
+mark *
+done
+yes
+list volumes
+@# should Consolidate Full, Differential and Incremental
+setdebug level=150 storage=disk2 trace=1
+setdebug level=100 dir trace=1
+run client=client1-fd job=$JobName level=VirtualFull yes
+run client=client2-fd job=$JobName level=VirtualFull yes
+run client=client3-fd job=$JobName level=VirtualFull yes
+run client=client4-fd job=$JobName level=VirtualFull yes
+run client=client5-fd job=$JobName level=VirtualFull yes
+run client=client6-fd job=$JobName level=VirtualFull yes
+run client=client7-fd job=$JobName level=VirtualFull yes
+run client=client8-fd job=$JobName level=VirtualFull yes
+wait
+messages
+list volumes
+list jobs
+@$out $tmp/log2.out
+@# 
+@# now do a restore of the consolidated Full
+@#
+restore where=${cwd}/tmp/bacula-restores client=client1-fd select storage=disk2
+unmark *
+mark *
+done
+yes
+wait
+list volumes
+list jobs
+st client=client1-fd
+messages
+quit
+END_OF_DATA
+
+run_bacula
+check_for_zombie_jobs storage=disk
+stop_bacula
+
+#
+# We only used one log so copy it to the second log
+#  so that any restore errors will be picked up
+#
+cp -f ${cwd}/tmp/log1.out ${cwd}/tmp/log2.out
+check_two_logs
+src=$cwd/tmp/build check_restore_diff
+end_test