]> git.sur5r.net Git - bacula/bacula/commitdiff
Tweak multi-storage-test
authorKern Sibbald <kern@sibbald.com>
Sat, 13 Feb 2010 13:45:58 +0000 (14:45 +0100)
committerEric Bollengier <eric@eb.homelinux.org>
Mon, 2 Aug 2010 14:49:29 +0000 (16:49 +0200)
regress/scripts/bacula-dir-tape.conf.in
regress/tests/multi2-storage-test [new file with mode: 0755]

index 24229a6d6caf5cf59bdf0ed33f42043e505575e5..0a71657ba4c86963a9070a9d8ba2b2d27b112d13 100644 (file)
@@ -190,6 +190,42 @@ Storage {
   Maximum Concurrent Jobs = 100
 }
 
+# Definition of File2 storage device
+Storage {
+  Name = File2
+  Address = @hostname@                # N.B. Use a fully qualified name here
+  SDPort = @sdport@
+  Password = "ccV3lVTsQRsdIUGyab0N4sMDavui2hOBkmpBU0aQKOr9"          # password for Storage daemon
+  Device = FileStorage                # must be same as Device in Storage daemon
+  Media Type = FileMedia              # must be same as MediaType in Storage daemon
+  Maximum Concurrent Jobs = 100
+}
+
+
+# Definition of File3 storage device
+Storage {
+  Name = File3
+  Address = @hostname@                # N.B. Use a fully qualified name here
+  SDPort = @sdport@
+  Password = "ccV3lVTsQRsdIUGyab0N4sMDavui2hOBkmpBU0aQKOr9"          # password for Storage daemon
+  Device = FileStorage                # must be same as Device in Storage daemon
+  Media Type = FileMedia              # must be same as MediaType in Storage daemon
+  Maximum Concurrent Jobs = 100
+}
+
+# Definition of File4 storage device
+Storage {
+  Name = File4
+  Address = @hostname@                # N.B. Use a fully qualified name here
+  SDPort = @sdport@
+  Password = "ccV3lVTsQRsdIUGyab0N4sMDavui2hOBkmpBU0aQKOr9"          # password for Storage daemon
+  Device = FileStorage                # must be same as Device in Storage daemon
+  Media Type = FileMedia              # must be same as MediaType in Storage daemon
+  Maximum Concurrent Jobs = 100
+}
+
+
+
 # Definition of Virtual storage device
 Storage {
   Name = Virtual
diff --git a/regress/tests/multi2-storage-test b/regress/tests/multi2-storage-test
new file mode 100755 (executable)
index 0000000..c33daed
--- /dev/null
@@ -0,0 +1,107 @@
+#!/bin/sh
+#
+# This script uses the virtual disk autochanger
+#
+TestName="multi-storage-test"
+JobName=backup
+. scripts/functions
+
+scripts/cleanup
+scripts/copy-2disk-confs
+scripts/prepare-disk-changer
+
+# create a new bacula-sd.confs
+for sd in 2 3 4; do
+  perl -ne '
+  if (/SDPort = /) { $_ =~ s/(\d+)/1810$sd/;}
+  if (/Name = .+?-sd/) { $_ =~ s/-sd/-sd$sd/;}
+  if (/WorkingDirectory/) { $_ =~ s/"$/$sd"/; }
+  if (/Pid Directory/) { $_ =~ s/"$/$sd"/; }
+  print;
+  ' $conf/bacula-sd.conf > $conf/bacula-sd$sd.conf
+  mkdir -p ${working}$sd
+  sed 's/bacula-sd.conf/bacula-sd$sd.conf/' $scripts/bacula-ctl-sd \
+      > $tmp/bacula-ctl-sd$sd
+  chmod +x $tmp/bacula-ctl-sd$sd
+done
+
+# Patch up bacula-dir.conf
+perl -ne '
+if (/^Storage {/) { $in=1; $nb++; }
+if (/^}/) { $in=0 }
+if (/SDPort = (\d+)/ && $in) {if ($nb == 2) { $_ = "  SDPort = 18102\n"; }}
+if (/SDPort = (\d+)/ && $in) {if ($nb == 3) { $_ = "  SDPort = 18103\n"; }}
+if (/SDPort = (\d+)/ && $in) {if ($nb == 4) { $_ = "  SDPort = 18104\n"; }}
+print;
+' $conf/bacula-dir.conf > $tmp/1
+cp $tmp/1 $conf/bacula-dir.conf
+
+disable_pluguins
+
+echo "${cwd}/build" >${cwd}/tmp/file-list
+
+change_jobname $JobName
+start_test
+
+# Write out bconsole commands
+cat <<END_OF_DATA >${cwd}/tmp/bconcmds
+@$out /dev/null
+messages
+@$out ${cwd}/tmp/log1.out
+label storage=tape volume=TestVolume001 Pool=Default slot=1 drive=0
+label storage=File  volume=TestVolume002 Pool=Default
+run job=$JobName storage=tape yes
+wait
+messages
+quit
+END_OF_DATA
+
+# Start SDs
+for sd in 2 3 4; do
+  $tmp/bacula-ctl-sd$sd start &> /dev/null
+done
+
+run_bacula
+
+echo "ficheriro1.txt" >${cwd}/build/po/ficheriro1.txt
+echo "ficheriro2.txt" >${cwd}/build/po/ficheriro2.txt
+
+
+cat <<END_OF_DATA >${cwd}/tmp/bconcmds
+@$out /dev/null
+messages
+@$out ${cwd}/tmp/log1.out
+@# Force Incremental on the second Volume
+run level=Incremental storage=File job=$JobName yes
+wait
+messages
+@# 
+@# now do a restore
+@#
+@$out ${cwd}/tmp/log2.out
+setdebug trace=1 level=110 client
+setdebug trace=1 level=110 director
+restore where=${cwd}/tmp/bacula-restores select all done yes
+wait
+messages
+sql
+select * in Storage;
+
+
+quit
+END_OF_DATA
+
+run_bconsole
+
+check_for_zombie_jobs storage=File
+check_for_zombie_jobs storage=tape
+
+stop_bacula
+for sd in 2 3 4; do
+  $tmp/bacula-ctl-sd$sd stop &> /dev/null
+done
+
+check_two_logs
+check_restore_diff
+
+end_test