scripts/copy-test-confs
echo "${cwd}/build/technotes" >${cwd}/tmp/file-list
+# increase the maximum concurrent jobs for FD, SD and DIR
+perl -Mscripts::functions -e 'set_maximum_concurent_jobs("$conf/bacula-dir.conf",100)'
+perl -Mscripts::functions -e 'set_maximum_concurent_jobs("$conf/bacula-sd.conf",100)'
+perl -Mscripts::functions -e 'set_maximum_concurent_jobs("$conf/bacula-fd.conf",100)'
# extract a Job and add a runscript on it
perl -Mscripts::functions \
-e "extract_resource('$conf/bacula-dir.conf', 'Job', 'CompressedTest')" \
| sed 's%Standard%Standard; ClientRunBeforeJob="sleep 6"%' > $tmp/1
-
outf="$tmp/sed_tmp"
echo 's%CompressedTest%AllowDuplicateYes%' > $outf
echo 's%Backup%Backup; AllowDuplicateJobs = yes%' >> $outf
echo 's%Backup%Backup; AllowDuplicateJobs = no;CancelLowerLevelDuplicates=no;CancelQueuedDuplicates=no; CancelRunningDuplicates=no%' >> $outf
sed -f $outf $tmp/1 >> $conf/bacula-dir.conf
-when=`perl -MPOSIX -e "print strftime('%F %T', localtime(time+300))"`
+for i in `seq 1 40`; do
+ echo "s%CompressedTest%CancelLowerLevelDuplicatesYes-$i%" > $outf
+ echo 's%Backup%Backup; AllowDuplicateJobs = no; CancelLowerLevelDuplicates=yes%' >> $outf
+ echo 's%sleep 6%sleep 20%' >> $outf
+ sed -f $outf $tmp/1 >> $conf/bacula-dir.conf
+done
+
+when=`perl -Mscripts::functions -e "get_time(300)"`
start_test
run comment="Should fail" level=Full job=CancelRunningDuplicatesNo yes
wait
messages
+@$out $tmp/log61.out
+@##########################
+@# run a bunch of job
+@##########################
+END_OF_DATA
+
+for i in `seq 1 40`; do
+ cat <<EOF >>${cwd}/tmp/bconcmds
+run comment="Should work" level=Full job=CancelLowerLevelDuplicatesYes-$i yes
+EOF
+done
+
+echo "wait" >> ${cwd}/tmp/bconcmds
+echo "messages" >> ${cwd}/tmp/bconcmds
+
+for i in `seq 1 40`; do
+ cat <<EOF >>${cwd}/tmp/bconcmds
+run comment="Should fail" level=Incremental job=CancelLowerLevelDuplicatesYes-$i yes
+EOF
+done
+
+echo "@sleep 5" >> ${cwd}/tmp/bconcmds
+
+for i in `seq 1 40`; do
+ cat <<EOF >>${cwd}/tmp/bconcmds
+run comment="Should work" level=Full job=CancelLowerLevelDuplicatesYes-$i yes
+EOF
+done
+
+echo "wait" >> ${cwd}/tmp/bconcmds
+echo "messages" >> ${cwd}/tmp/bconcmds
+
+cat <<END_OF_DATA >>${cwd}/tmp/bconcmds
@$out $tmp/log7.out
sql
SELECT JobId, Name, Level, Comment, JobStatus from Job
touch $tmp/log2.out
check_two_logs
-grep '^| [0-9]' $tmp/log7.out > /dev/null
+grep '^| *[0-9]' $tmp/log7.out > /dev/null
if [ $? = 0 ]; then
- print_debug "E: Found errors in $tmp/log7.out"
+ print_debug "ERROR: Found errors in $tmp/log7.out"
print_debug `cat $tmp/log7.out`
estat=1
fi
-grep '^| [0-9]' $tmp/log8.out > /dev/null
+grep '^| *[0-9]' $tmp/log8.out > /dev/null
if [ $? = 0 ]; then
- print_debug "E: Found errors in $tmp/log8.out"
+ print_debug "ERROR: Found errors in $tmp/log8.out"
print_debug `cat $tmp/log8.out`
estat=1
fi
+nb=`grep '^| *[0-9]' $tmp/log9.out | wc -l`
+if [ $nb -lt 80 ]; then
+ print_debug "ERROR: no enough results in $tmp/log9.out"
+ print_debug `cat $tmp/log9.out`
+ estat=1
+fi
+
end_test