From 57eb3762bba0128a254517f4eca38201786b7cab Mon Sep 17 00:00:00 2001 From: "(no author)" <(no author)@91ce42f0-d328-0410-95d8-f526ca767f89> Date: Fri, 26 Nov 2004 22:39:51 +0000 Subject: [PATCH] This commit was manufactured by cvs2svn to create tag 'Release-1.36.1'. git-svn-id: https://bacula.svn.sourceforge.net/svnroot/bacula/tags/Release-1.36.1@1725 91ce42f0-d328-0410-95d8-f526ca767f89 --- bacula/ChangeLog | 26 +- bacula/ReleaseNotes | 123 +++-- bacula/kernstodo | 490 ++++++++++++++++++-- bacula/patches/fix_postgresql_tables | 35 -- bacula/scripts/.cvsignore | 1 - bacula/src/cats/fix_postgresql_tables | 35 -- bacula/src/dird/authenticate.c | 12 +- bacula/src/dird/query.sql | 2 +- bacula/src/version.h | 6 +- regress/.cvsignore | 9 - regress/Makefile.in | 69 --- regress/README | 101 ---- regress/all-non-root-2tape-tests | 12 - regress/all-non-root-tape-tests | 19 - regress/all-non-root-tests | 35 -- regress/all-root-tests | 11 - regress/all-tape-and-file-tests | 6 - regress/all-tests | 8 - regress/config | 9 - regress/do_all | 3 - regress/do_all_tapes | 3 - regress/file | 2 - regress/kern.conf | 15 - regress/prototype.conf | 37 -- regress/run | 3 - regress/scripts/.cvsignore | 17 - regress/scripts/bacula-dir-tape.conf.in | 144 ------ regress/scripts/bacula-sd-2tape.conf.in | 55 --- regress/scripts/bacula-sd-tape.conf.in | 54 --- regress/scripts/bacula-sd.conf.in | 74 --- regress/scripts/check_for_zombie_jobs | 52 --- regress/scripts/cleanup | 18 - regress/scripts/cleanup-2tape.in | 30 -- regress/scripts/cleanup-tape.in | 8 - regress/scripts/copy-2tape-confs | 5 - regress/scripts/copy-confs | 5 - regress/scripts/copy-tape-confs | 5 - regress/scripts/copy-test-confs | 5 - regress/scripts/copy-testa-confs | 5 - regress/scripts/do_sed | 59 --- regress/scripts/exclude-dev-test | 5 - regress/scripts/exclude-etc-test | 1 - regress/scripts/exclude-lib-test | 5 - regress/scripts/flist | 16 - regress/scripts/freebsd_tape_options | 8 - regress/scripts/linux_osst_tape_options | 7 - regress/scripts/linux_tape_options | 1 - regress/scripts/new-test-bacula-dir.conf.in | 312 ------------- regress/scripts/prepare-two-tapes.in | 13 - regress/scripts/regress-config | 21 - regress/scripts/setup | 44 -- regress/scripts/test-bacula-dir.conf.in | 308 ------------ regress/scripts/test-bacula-fd.conf.in | 33 -- regress/scripts/test-bacula-sd.conf.in | 107 ----- regress/scripts/test-console.conf.in | 10 - regress/scripts/testa-bacula-dir.conf.in | 149 ------ regress/tape | 2 - regress/tests/.cvsignore | 1 - regress/tests/auto-label-test | Bin 1801 -> 0 bytes regress/tests/backup-bacula-tape | Bin 2698 -> 0 bytes regress/tests/backup-bacula-test | Bin 1872 -> 0 bytes regress/tests/bextract-test | Bin 1872 -> 0 bytes regress/tests/bscan-tape | Bin 3564 -> 0 bytes regress/tests/bscan-test | Bin 2367 -> 0 bytes regress/tests/bsr-opt-test | Bin 2321 -> 0 bytes regress/tests/btape-fill-full-tape | 34 -- regress/tests/btape-fill-tape | 39 -- regress/tests/compressed-test | Bin 1693 -> 0 bytes regress/tests/concurrent-jobs-test | Bin 2437 -> 0 bytes regress/tests/decremental-test | Bin 2730 -> 0 bytes regress/tests/dev-test-root | 85 ---- regress/tests/etc-test-root | 70 --- regress/tests/fixed-block-size-tape | Bin 1808 -> 0 bytes regress/tests/four-concurrent-jobs-tape | Bin 1578 -> 0 bytes regress/tests/four-concurrent-jobs-test | Bin 2066 -> 0 bytes regress/tests/four-jobs-tape | Bin 3117 -> 0 bytes regress/tests/four-jobs-test | Bin 3367 -> 0 bytes regress/tests/incremental-2tape | Bin 2352 -> 0 bytes regress/tests/incremental-tape | Bin 2099 -> 0 bytes regress/tests/incremental-test | Bin 4080 -> 0 bytes regress/tests/lib-tape-root | 67 --- regress/tests/lib-test-root | 76 --- regress/tests/query-test | Bin 2937 -> 0 bytes regress/tests/recycle-test | Bin 2541 -> 0 bytes regress/tests/restore-by-file-tape | Bin 3179 -> 0 bytes regress/tests/restore-by-file-test | Bin 1869 -> 0 bytes regress/tests/restore-disk-seek-test | Bin 2754 -> 0 bytes regress/tests/restore2-by-file-test | Bin 1678 -> 0 bytes regress/tests/six-vol-test | Bin 1927 -> 0 bytes regress/tests/small-file-size-tape | Bin 1559 -> 0 bytes regress/tests/span-vol-test | Bin 2052 -> 0 bytes regress/tests/sparse-compressed-test | Bin 1726 -> 0 bytes regress/tests/sparse-test | Bin 1627 -> 0 bytes regress/tests/test0 | 3 - regress/tests/two-jobs-test | Bin 2338 -> 0 bytes regress/tests/two-vol-test | Bin 1728 -> 0 bytes regress/tests/two-volume-tape | Bin 1824 -> 0 bytes regress/tests/usr-tape-root | 62 --- regress/tests/verify-vol-test | Bin 1525 -> 0 bytes regress/tests/weird-files-test | Bin 2131 -> 0 bytes regress/tests/weird-files2-test | Bin 2209 -> 0 bytes regress/weird-files.tar.gz | Bin 1699 -> 0 bytes 102 files changed, 528 insertions(+), 2559 deletions(-) delete mode 100755 bacula/patches/fix_postgresql_tables delete mode 100755 bacula/src/cats/fix_postgresql_tables delete mode 100644 regress/.cvsignore delete mode 100644 regress/Makefile.in delete mode 100644 regress/README delete mode 100755 regress/all-non-root-2tape-tests delete mode 100755 regress/all-non-root-tape-tests delete mode 100755 regress/all-non-root-tests delete mode 100755 regress/all-root-tests delete mode 100755 regress/all-tape-and-file-tests delete mode 100755 regress/all-tests delete mode 100755 regress/config delete mode 100755 regress/do_all delete mode 100755 regress/do_all_tapes delete mode 100755 regress/file delete mode 100644 regress/kern.conf delete mode 100644 regress/prototype.conf delete mode 100755 regress/run delete mode 100644 regress/scripts/.cvsignore delete mode 100644 regress/scripts/bacula-dir-tape.conf.in delete mode 100644 regress/scripts/bacula-sd-2tape.conf.in delete mode 100644 regress/scripts/bacula-sd-tape.conf.in delete mode 100644 regress/scripts/bacula-sd.conf.in delete mode 100755 regress/scripts/check_for_zombie_jobs delete mode 100755 regress/scripts/cleanup delete mode 100755 regress/scripts/cleanup-2tape.in delete mode 100755 regress/scripts/cleanup-tape.in delete mode 100755 regress/scripts/copy-2tape-confs delete mode 100755 regress/scripts/copy-confs delete mode 100755 regress/scripts/copy-tape-confs delete mode 100755 regress/scripts/copy-test-confs delete mode 100755 regress/scripts/copy-testa-confs delete mode 100755 regress/scripts/do_sed delete mode 100644 regress/scripts/exclude-dev-test delete mode 100644 regress/scripts/exclude-etc-test delete mode 100644 regress/scripts/exclude-lib-test delete mode 100644 regress/scripts/flist delete mode 100644 regress/scripts/freebsd_tape_options delete mode 100644 regress/scripts/linux_osst_tape_options delete mode 100644 regress/scripts/linux_tape_options delete mode 100644 regress/scripts/new-test-bacula-dir.conf.in delete mode 100755 regress/scripts/prepare-two-tapes.in delete mode 100755 regress/scripts/regress-config delete mode 100755 regress/scripts/setup delete mode 100644 regress/scripts/test-bacula-dir.conf.in delete mode 100644 regress/scripts/test-bacula-fd.conf.in delete mode 100644 regress/scripts/test-bacula-sd.conf.in delete mode 100644 regress/scripts/test-console.conf.in delete mode 100644 regress/scripts/testa-bacula-dir.conf.in delete mode 100755 regress/tape delete mode 100644 regress/tests/.cvsignore delete mode 100755 regress/tests/auto-label-test delete mode 100755 regress/tests/backup-bacula-tape delete mode 100755 regress/tests/backup-bacula-test delete mode 100755 regress/tests/bextract-test delete mode 100755 regress/tests/bscan-tape delete mode 100755 regress/tests/bscan-test delete mode 100755 regress/tests/bsr-opt-test delete mode 100755 regress/tests/btape-fill-full-tape delete mode 100755 regress/tests/btape-fill-tape delete mode 100755 regress/tests/compressed-test delete mode 100755 regress/tests/concurrent-jobs-test delete mode 100755 regress/tests/decremental-test delete mode 100755 regress/tests/dev-test-root delete mode 100755 regress/tests/etc-test-root delete mode 100755 regress/tests/fixed-block-size-tape delete mode 100755 regress/tests/four-concurrent-jobs-tape delete mode 100755 regress/tests/four-concurrent-jobs-test delete mode 100755 regress/tests/four-jobs-tape delete mode 100755 regress/tests/four-jobs-test delete mode 100755 regress/tests/incremental-2tape delete mode 100755 regress/tests/incremental-tape delete mode 100755 regress/tests/incremental-test delete mode 100755 regress/tests/lib-tape-root delete mode 100755 regress/tests/lib-test-root delete mode 100755 regress/tests/query-test delete mode 100755 regress/tests/recycle-test delete mode 100755 regress/tests/restore-by-file-tape delete mode 100755 regress/tests/restore-by-file-test delete mode 100755 regress/tests/restore-disk-seek-test delete mode 100755 regress/tests/restore2-by-file-test delete mode 100755 regress/tests/six-vol-test delete mode 100755 regress/tests/small-file-size-tape delete mode 100755 regress/tests/span-vol-test delete mode 100755 regress/tests/sparse-compressed-test delete mode 100755 regress/tests/sparse-test delete mode 100755 regress/tests/test0 delete mode 100755 regress/tests/two-jobs-test delete mode 100755 regress/tests/two-vol-test delete mode 100755 regress/tests/two-volume-tape delete mode 100755 regress/tests/usr-tape-root delete mode 100755 regress/tests/verify-vol-test delete mode 100755 regress/tests/weird-files-test delete mode 100755 regress/tests/weird-files2-test delete mode 100644 regress/weird-files.tar.gz diff --git a/bacula/ChangeLog b/bacula/ChangeLog index f4d894739e..f2b320cca6 100644 --- a/bacula/ChangeLog +++ b/bacula/ChangeLog @@ -1,5 +1,29 @@ -Version 1.36.1 released xxNov04: +Version 1.36.1 released 26Nov04: +24Nov04 +- Take Dan's fix to the fix_postgresql_tables (thanks Dan) +- Increase Maximum Concurrent Jobs to 20 in SD and FD! +- Fix improper handling of autochanger Volumes that are not + marked InChanger. +22Nov04 +- Update authentication failure message to indicate possible + problem with Maximum Concurrent Jobs. Add to doc too. +- Commit PostgreSQL BIGINT fix -- apparently some people didn't + get it. +- Do not use a slot unless it is InChanger in the autochanger + code, otherwise autochanger gets upset not finding the Volume. +21Nov04 +- Make authentication timeout compile time configurable. + The value is set in src/baconfig.h +- Fix removing items from watchdog queue, which apparently + screwed up if there was more than one item. +- Rework mediaformat part of manual to separate out old + tape format for easier reading. +- Add a lot of debug code to the authentication code. +- Add seconds to the start/end times printed in the job report. +19Nov04 +- Fix mutex deadlock in dequeue of messages. +- Add debug code to FD authorization. 18Nov04 - Increase authentication timeouts to 10 minutes. 15Nov04 diff --git a/bacula/ReleaseNotes b/bacula/ReleaseNotes index 99d6eb5005..0d6e53cf67 100644 --- a/bacula/ReleaseNotes +++ b/bacula/ReleaseNotes @@ -1,81 +1,47 @@ - Release Notes for Bacula 1.36.0 + Release Notes for Bacula 1.36.1 Bacula code: Total files = 396 Total lines = 116,418 (*.h *.c *.in) Major Changes: -- Tray monitor program (really cool) -- Bacula Rescue CDROM (easy to make and essential for emergencies) -- Bacula CD Image Manager -- General bug fixes/stabilization -- French translation of manual by Ludovic Strappazon well - underway. -- UTF-8 is supported in conio. -- Improved conf scanning code allowing FileSet components to - be put on a single line (previously everything had to be on - a different line). -- Win32 files restored to an alternate directory will have the - colon following the drive letter turned into a / e.g. c: - becomes c/. Previously the c: was stripped. This applies only - to files written to an alternate directory (i.e. using a where=). -- Certain open files (Word for example) can now be saved on - Win32 systems. -- Default for Wild-cards on Win32 systems is to fold case this - should correct most of the problems users are having with - exclusion on Win32. -- Lots of improvements in the Rescue scripts -- better - network detection, better mounting code, ... -- The attributes spool file can now exceed 2GB. -- Significant speed improvements when running PostgreSQL. -- Significantly faster restore command with very large - FileSets while building the in memory directory tree. -- Patches directory in the source will have all patches - that have not been applied and released (new releases are - only generated when really critical bugs are found). -- Bacula forces the tape drive into variable block mode - on most systems (providing Bacula is running in variable - block mode). -- dbcheck updated to remove many more orphaned records. -- Support for IPv6 (untested). -- Modifications to the license to termination clause for - more protection from SCO type predators. No change for - normal users. -- SIGHUP to Director causes it to reload conf file. +- There is a new Win32 pebuilder rescue disk thanks to Scott. This + is worth the effort to checkout. +- A number of indexes have been removed from the PostgreSQL + database to improve performance during backups. You may need to + add these indexes if you do Verifies. See the scripts. +- We now have a Gentoo ebuild -- thanks Scott. +- There are a number of new ./configure options for the + bimagemgr. Please see the documentation or ./configure --help +- The RedHat autostart scripts disable using /lib/tls. If you + don't want this you will need to turn it off. +- Corrected a problem with the default SD and FD conf files that + incorrectly set Maximum Concurrent Jobs = 1. This prevented + running a job and obtaining the status at the same time. +- All daemon messages are now prefixed with a short date/time, + and queued messages (generated in the comm routines) have the + time the message was generated rather than the time the message + was sent (usually much later). +- Fixed a bug with the autochanger code not respecting the InChanger + flag. -- Many improvements in the documentation. New Directives: -- Added "Rerun Failed levels = yes/no" in the Job resource - of the Director. It will upgrade the current job to a - higher level (Full or Differential) if a previous job - of that level failed. -- Added "Ignore FileSet Changes = yes/no" in the FileSet - directive of the Director. It prevents the Director from - immediately upgrading the job to a Full save if you modify - the contents of the FileSet. Not recommended. -- Added "Block positioning = yes/no" in Device resource in SD. - If set to no, Bacula should (as yet untested) be able to - recover data from tapes where the drive was set to fixed - blocksize but Bacula is in variable block size. -- Added "Multiple connections = yes/no" in Catalog record for - allowing multiple simultaneous connections to the database. - This is a major performance improvement for PostgreSQL and - SQLite, but it is untested, so please test before putting - it into production. -- Alert Command in SD permits checking for tape drive - alerts at the end of every job (or doing anything you want). - An example of the command is in the default bacula-sd.conf - file as well as in the Storage Configuration chapter of - the manual. +- None since 1.36.0 New Commands: -- umount -- same as unmount. -- delete job now permits multiple jobids and ranges, e.g.: - delete job jobid=1,3,5,11-16 -- reload -- reloads bacula-dir.conf in Director. +- None since 1.36.0 Items to note!!! +- The output from Job reports has been modified to include the + seconds on the start/end times, the Storage device used, and to + indent the output differently. +- If you created a PostgreSQL database under version 1.36.0, there + are two things you might want to do. 1. manually remove some + of the File table indexes to improve backup performance. See the + make_postgresql_tables script. 2. run fix_postgresql_tables (in + src/cats and updatedb) to correct a table. This is necessary only + if you are creating disk Volumes greater than 2GB. - As of 1.35.5 you MUST do a database update. cd scripts-dir (or src/cats) @@ -86,10 +52,25 @@ Items to note!!! - Regular expressions are not supported in the Win32 FD. Other Items: -- Much better error messages from system errors particularly - on Win32 and in running scripts. -- Many improvements in the SD. -- Full support for 64 bit machines. -- btape improved test and fill commands. -- See the ChangeLog for additional details. +- It is now possible to build the Rescue CDROM using a pre-installed + static Bacula FD. +- Corrected a bug in the traceback code when Bacula was executed without + a path. Tracebacks should now work in more cases. +- Corrected a typo in the traceback script. +- Fixed the mtx autochanger script so that it correctly waits on + Linux systems (if you manually enable the code). +- Added grant all on cdimages for PostgreSQL users of bimagemgr. +- The actual Job start time is now correctly recorded in the catalog. +- You can now specify a JobId (or multiple ones separated by commas) on + the restore command line. +- A -d50 will now turn on lots of debug code if you are having + authentication errors. +- Found a workaround to a /lib/tls pthreads bug (a library seg fault). +- Added an ALERT message class for Alert messages. +- Fixed a seg fault in the restore tree routine when attempting + to select certain files in the root directory. +- Allow other jobs to request new Volumes while operator intervention + is needed -- previously all stalled. +- Enhancements to btape test (don't loop if certain tape errors occur). +- Improvements to the Win32 install. diff --git a/bacula/kernstodo b/bacula/kernstodo index 683cd3a5fc..8816726bd6 100644 --- a/bacula/kernstodo +++ b/bacula/kernstodo @@ -1,5 +1,5 @@ Kern's ToDo List - 18 November 2004 + 20 October 2004 Major development: Project Developer @@ -7,51 +7,15 @@ Project Developer IPv6_2 Meno Abels Data encryption Meno Abels (see projects) Communication encryption Meno Abels -Version 1.37 Kern (see below) +Version 1.35 Kern (see below) ======================================================== -For 1.36.1: -- Fix orphanned buffers: - Orphaned buffer: 24 bytes allocated at line 808 of rufus-dir job.c - Orphaned buffer: 40 bytes allocated at line 45 of rufus-dir alist.c -- Add dump of VolSessionId/Time and FileIndex with bls. - -1.37 Projects: -#3 Migration (Move, Copy, Archive Jobs) -#4 Embedded Python Scripting -#5 Events that call a Python program -#6 Select one from among Multiple Storage Devices for Job -#7 Single Job Writing to Multiple Storage Devices - - -1.37 Possibilities: -- Document testing -- Add performance testing hooks -- if 2 concurrent backups are attempted on the same tape - drive (autoloader) into different tape pools, one of them will exit - fatally instead of halting until the drive is idle -- Add seconds to start and end times in the Job report output. -- Add disk seeking on restore. -- Document that ChangerDevice is used for Alert command. -- Include within include does it work? -- Implement a Pool of type Cleaning? -- Implement VolReadTime and VolWriteTime in SD -- Modify Backing up Your Database to include a bootstrap file. -- Add restore of specific JobId to regression. -- Think about making certain database errors fatal. -- Look at correcting the time jump in the sceduler for daylight - savings time changes. -- Add a "real" timer to network connections. -- Tell the "restore" user when browsing is no longer possible. -- Write non-optimized bsrs from the JobMedia and Media records, - even after Files are pruned. -- Document that Bootstrap files can be written with cataloging - turned off. -- Look at adding full Volume and Pool information to a Volume - label so that bscan can get *all* the info. -- Promote to Full = Time period -- Scratch Pool where the volumes can be re-assigned to any Pool. -- Update StartTime if job held in Job Queue. +1.35 Items to do for release: +- Finish recovering from a disaster situation. + - How to get back a catalog. + + +Maybe for 1.35: - Despool attributes simultaneously with data in a separate thread, rejoined at end of data spooling. - Implement Files/Bytes,... stats for restore job. @@ -66,6 +30,7 @@ For 1.36.1: - Add IPv6 to regression - Perhaps add read/write programs and/or plugins to FileSets. - How to handle backing up portables ... +- Add "Rerun failed levels = yes/no" to Job resource. - Add some sort of guaranteed Interval for upgrading jobs. - Can we write the state file after every job terminates? On Win32 the system crashes and the state file is not updated. @@ -111,18 +76,70 @@ For 1.37 Testing/Documentation: up through the prompt. - Detect fixed tape block mode during positioning by looking at block numbers in btape "test". Possibly adjust in Bacula. +- Implement a Client filename case fold option (default = fold + on Win32). - Fix list volumes to output volume retention in some other units, perhaps via a directive. - If opening a tape in read/write mode fails attempt to open it in read-only mode, and mark the tape for read only. - Add a read-only mode to the mount option. +- Add "Allow multiple connections" in Catalog resource to open a new + database connection for each job. - Allow Simultaneous Priorities = yes => run up to Max concurrent jobs even with multiple priorities. +- Fix find_device in stored/dircmd.c:462 (see code) - Add db check test to regression. Test each function like delete, purge, ... - If you use restore replace=never, the directory attributes for non-existent directories will not be restored properly. +Fix: + Kern, + mt status and tapeinfo output are attached. Default blocksize was + originally 512 bytes. I ran the following test on my machine: + + - set defblksize to 512 + - started bacula, labelled tape, ran job + - job completes with the following in log + SD termination status: OK + Termination: Backup OK + - restore attempts with blocksize set to 0 or 512 result in the familiar + "Volume data error! Wanted block-id BB02, got . Buffer discarded." + + + # tapeinfo -f /dev/sg0 + Product Type: Tape Drive + Vendor ID: 'SONY ' + Product ID: 'TSL-11000 ' + Revision: 'L100' + Attached Changer: Yes + SerialNumber: '0010000443' + MinBlock:1 + MaxBlock:16777215 + SCSI ID: 1 + SCSI LUN: 0 + Ready: yes + BufferedMode: yes + Medium Type: Not Loaded + Density Code: 0x26 + BlockSize: 512 + DataCompEnabled: no + DataCompCapable: yes + DataDeCompEnabled: yes + CompType: 0x20 + DeCompType: 0x20 + BOP: yes + Block Position: 0 + + # mt -f /dev/nst0 status + SCSI 2 tape drive: + File number=0, block number=132, partition=0. + Tape block size 512 bytes. Density code 0x26 (DDS-4 or QIC-4GB). + Soft error count since last status=0 + General status bits on (1010000): + ONLINE IM_REP_EN + +Wish list: - see lzma401.zip in others directory for new compression algorithm/library. - Minimal autochanger handling in Bacula and in btape. @@ -189,6 +206,9 @@ For 1.37 Testing/Documentation: - Make ? do a help command (no return needed). - Implement restore directory. - Document streams and how to implement them. +- Possibly implement "Ensure Full Backup = yes" looks for a failed full backup + and upgrades the current backup if one exists. +- Check that barcode reading and update slots scan works. - Try not to re-backup a file if a new hard link is added. - Add feature to backup hard links only, but not the data. - Fix stream handling to be simpler. @@ -196,6 +216,8 @@ For 1.37 Testing/Documentation: - Eliminate Restore "Run Restore Job" prompt by allowing new "run command to be issued" - Remove View FileSet button from Run a Job dialog. +- Don't count higher level non-saved directories in Files expected + in restore report. - Handle prompt for restore job at end of Restore command. - Add display of total selected files to Restore window. - Add tree pane to left of window. @@ -225,6 +247,8 @@ For 1.37 Testing/Documentation: fields. - Fix option 2 of restore -- list where file is backed up -- require Client, then list last 20 backups. +- Add all pools in Dir conf to DB also update them to catch changed + LabelFormats and such. - Pass Director resource name as an option to the Console. - Add a "batch" mode to the Console (no unsolicited queries, ...). - Add a .list all files in the restore tree (probably also a list all files) @@ -235,6 +259,7 @@ For 1.37 Testing/Documentation: did not exist. - Use SHA1 on authentication if possible. - See comtest-xxx.zip for Windows code to talk to USB. +- Make btape accept Device Names in addition to Archive names. - Add Events and Perl scripting. - Add John's appended files: Appended = { /files/server/logs/http/*log } @@ -249,7 +274,8 @@ For 1.37 Testing/Documentation: entirely upon the length.On a restore, the full and all incrementals since it will beapplied in sequence to restore the file. - Add a regression test for dbcheck. -- Allow for optional cancelling of SD and FD in case DIR +- Add disk seeking on restore. - Allow + for optional cancelling of SD and FD in case DIR gets a fatal error. Requested by Jesse Guardiani - Add "limit=n" for "list jobs" - Check new HAVE_WIN32 open bits. @@ -290,6 +316,66 @@ For 1.37 Testing/Documentation: in Job, Client, and Pool, with precedence such that Job overrides Client which in turn overrides Pool. +- Spooling ideas taken from Volker Sauer's and other's emails: + > IMHO job spooling should be turned on + > + > 1) by job + > 2) by schedule + > 3) by sd + > + > where and 2) overrides 1) and 3) is independent. + + Yes, this is the minimum that I think is necessary. + + > + > Reason(s): + > It should be switched by job, because the job that backs up the machine + > with the bacula-sd on doesn't need spooling. + > It should be switched by schedule, because for full-backups I don't need + > spooling, so I can switch it off (because the network faster then the + > tapedrive) + + True, with the exception that if you have enough disk spool space, + and you want to run concurrent jobs, spooling can eliminate the block + interleaving restore inefficiencies. + + > And you should be able to turn it of by sd for sd-machines with low disk + > capacity or if you just don't need or want this feature. + > + > There should be: + > - definitly the possibility for multipe spool direcories + + Having multiple directories is no problem -- having different maximum + sizes creates specification problems. At some point, I will probably + have a common SD pool of spool directories as well as a set of + private spool directories for each device. The first implementation + will be a set of private spool directories for each device since + managing a global pool with a bunch of threads writing into the same + directory is *much* more complicated and prone to error. + + > - the ability to spool parts of a backup (not the whole client) + + This may change in the future, but for the moment, it will spool + either to a job high water mark, or until the directory is full + (reaches max spool size or I/O error). It will then write to tape, + truncate the spool file, and begin spooling again. + + > - spooling while writing to tape + + Not within a job, but yes, if you run concurrent jobs -- each is a + different thread. Within a job could be a feature, but *much* later. + + > - parallel spooling (like parallel jobs/ concurrent jobs) of clients + + Yes, this is one of my main motivations for doing it (aside from + eliminating tape "shoe shine" during incremental backups. + + > - flushing a backup that only went to disk (like amflush in amanda) + + This will be a future feature, since spooling is different from backing + up to disk. The future feature will be "migration" which will move a job + from one backup Volume to another. + - New Storage specifications: - Want to write to multiple storage devices simultaneously - Want to write to multiple storage devices sequentially (in one job) @@ -321,9 +407,10 @@ For 1.37 Testing/Documentation: is contained in only one device. In SD allow Device to have Multiple MediaTypes +After 1.33: - Look at www.nu2.nu/pebuilder as a helper for full windows bare metal restore. -- Ideas from Jerry Scharf: +Ideas from Jerry Scharf: First let's point out some big pluses that bacula has for this it's open source more importantly it's active. Thank you so much for that @@ -347,6 +434,9 @@ For 1.37 Testing/Documentation: support for Oracle database ?? === - Look at adding SQL server and Exchange support for Windows. +- Restore: Enter Filename: 'C:/Documents and Settings/Comercial/My + Documents/MOP/formulário de registro BELAS ARTES.doc' causes Bacula to + crash. - Each DVD-RAM disk would be a volume, just like each tape is a volume. It's a 4.7GB media with random access, but there's nothing about it that I can see that makes it so different than a tape from  bacula's @@ -356,13 +446,20 @@ For 1.37 Testing/Documentation: be an invalid value which happens with BSR. - Create VolAddr for disk files in place of VolFile and VolBlock. This is needed to properly specify ranges. +- Print bsmtp output to job report so that problems will be seen. +- Pass the number of files to be restored to the FD for reporting - Add progress of files/bytes to SD and FD. +- Don't continue Restore if no files selected. - Print warning message if FileId > 4 billion - do a "messages" before the first prompt in Console - Add a date and time stamp at the beginning of every line in the Job report (Volker Sauer). - Client does not show busy during Estimate command. - Implement Console mtx commands. +- Add a default DB password to MySQL. + GRANT all privileges ON bacula.* TO bacula@localhost IDENTIFIED BY + 'bacula_password'; + FLUSH PRIVILEGES; - Implement a Mount Command and an Unmount Command where the users could specify a system command to be performed to do the mount, after which Bacula could attempt to @@ -378,24 +475,63 @@ For 1.37 Testing/Documentation: - Implement dump/print label to UA - Spool to disk only when the tape is full, then when a tape is hung move it to tape. +- Scratch Pool where the volumes can be re-assigned to any Pool. - bextract is sending everything to the log file ****FIXME**** +- Add Progress command that periodically reports the progress of + a job or all jobs. +- Restrict characters permitted in a Resource name, and don't permit + duplicate names. - Allow multiple Storage specifications (or multiple names on a single Storage specification) in the Job record. Thus a job can be backed up to a number of storage devices. - Implement some way for the File daemon to contact the Director to start a job or pass its DHCP obtained IP number. +- Implement multiple Consoles. - Implement a query tape prompt/replace feature for a console +- From Johan? + Two jobs ready to go, first one blocked waiting for media + Cancel 2nd job ("waiting execution" one) + Cancel blocked job + boom - segfault* - Copy console @ code to gnome2-console - Make AES the only encryption algorithm see http://csrc.nist.gov/CryptoToolkit/aes/). It's an officially adopted standard, has survived peer review, and provides keys up to 256 bits. +- Think about how space could be freed up on a tape -- perhaps this + is a Merge or Compact feature that is needed. +- Modify FileSet, did not upgrade the current Increment job, but + waited for the next job to be upgraded. - Take a careful look at SetACL http://setacl.sourceforge.net +- Implement a where command for the tree telling where a file + is located. - Take a careful look at Level for the estimate command, maybe make it a command line option. - Add Volume name to "I cannot write on this volume because" - Make tree walk routines like cd, ls, ... more user friendly by handling spaces better. +- Write your PID file and chown root:wheel before drop. +- Make sure there is no symlink in a file before creating a + file (attack). +- Look at mktemp or mkstemp(3). + mktemp and mkstemp create files with predictable names too. That's + not the vulnerability. The vulnerability is in creating files without + using the O_EXCL flag, which means "only create this file if it doesn't + exist, including if the file is a dangling symlink." + + It is *NOT* enough to do the equivalent of + + if doesn't exist $filename + then create $filename + + because between the test and the create another process could have + gotten the CPU and created the file. You must use atomic functions + (those that don't get interrupted by other processes) and O_EXCL is + the only way for this particular example. +- Automatically create pools, but instead of looking for what + in in Job records, walk through the pool resources. +- Check and double check tree code, why does it take so long? +- Add device name to "Current Volume not acceptable because ..." - Make sure that Bacula rechecks the tape after the 20 min wait. - Set IO_NOWAIT on Bacula TCP/IP packets. - Try doing a raw partition backup and restore by mounting a @@ -409,17 +545,76 @@ For 1.37 Testing/Documentation: By the way can bacula automatically "move" an empty/purged volume say in the "short" pool to the "long" pool if this pool runs out of volume space? +- Eliminate orphaned jobs: dbcheck, normal pruning, delete job command. + Hm.  Well, there are the remaining orphaned job records: + + |   105 | Llioness Save  | 0000-00-00 00:00:00 | B    | D     |        0 |             0 | f         | + |   110 | Llioness Save  | 0000-00-00 00:00:00 | B    | I     |        0 |             0 | f         | + |   115 | Llioness Save  | 2003-09-10 02:22:03 | B    | I     |        0 |             0 | A         | + |   128 | Catalog Save   | 2003-09-11 03:53:32 | B    | I     |        0 |             0 | C         | + |   131 | Catalog Save   | 0000-00-00 00:00:00 | B    | I     |        0 |             0 | f         | + + As you can see, three of the five are failures.  I already deleted the + one restore and one other failure using the by-client option.  Deciding + what is an orphaned job is a tricky problem though, I agree.  All these + records have or had 0 files/ 0 bytes, except for the restore.  With no + files, of course, I don't know of the job ever actually becomes + associated with a Volume. + + (I'm not sure if this is documented anywhere -- what are the meanings of + all the possible JobStatus codes?) + + Looking at my database, it appears to me as though all the "orphaned" + jobs fit into one of two categories: + + 1)  The Job record has a StartTime but no EndTime, and the job is not +     currently running; + or + 2)  The Job record has an EndTime, indicating that it completed, but +     it has no associated JobMedia record. + + + This does suggest an approach.  If failed jobs (or jobs that, for some + other reason, write no files) are associated with a volume via a + JobMedia record, then they should be purged when the associated volume + is purged.  I see two ways to handle jobs that are NOT associated with a + specific volume: + + 1)  purge them automatically whenever any volume is manually purged; + or + 2)  add an option to the purge command to manually purge all jobs with +     no associated volume. + + I think Restore jobs also fall into category 2 above .... so one might + want to make that "The Job record has an EndTime,, but no associated + JobMedia record, and is not a Restore job." +- make "btape /tmp" work. +- Make sure a rescheduled job is properly reported by status. +- Walk through the Pool records rather than the Job records + in dird.c to create/update pools. - What to do about "list files job=xxx". +- When job rescheduled, status gives is waiting for Client Rufus + to connect to Storage File. Dir needs to inform SD that job + is rescheduled. - Make Dmsg look at global before calling subroutine. +- Enable trace output at runtime for Win32 +- Available volumes for autochangers (see patrick@baanboard.com 3 Sep 03 + and 4 Sep) scan slots. - Get and test MySQL 4.0 +- Do a complete audit of all pthreads_mutex, cond, ... to ensure that + any that are dynamically initialized are destroyed when no longer used. - Look at how fuser works and /proc/PID/fd that is how Nic found the file descriptor leak in Bacula. - Implement WrapCounters in Counters. +- Turn on SIGHUP in dird.c and test. +- Use system dependent calls to get more precise info on tape errors. - Add heartbeat from FD to SD if hb interval expires. +- Suppress read error on blank tape when doing a label. - Can we dynamically change FileSets? - If pool specified to label command and Label Format is specified, automatically generate the Volume name. - Why can't SQL do the filename sort for restore? +- Look at libkse (man kse) for FreeBSD threading. - Look into Microsoft Volume Shadowcopy Service VSS for backing up system state components (Active Directory, System Volume, ...) - Add ExhautiveRestoreSearch @@ -427,6 +622,7 @@ For 1.37 Testing/Documentation: data into the restore tree (i.e. do it one directory at a time as the user walks through the tree). - Possibly use the hash code if the user selects all for a restore command. +- Orphaned Dir buffer at parse_conf.c:373 => store_dir - Fix "restore all" to bypass building the tree. - Prohibit backing up archive device (findlib/find_one.c:128) - Implement Release Device in the Job resource to unmount a drive. @@ -434,28 +630,50 @@ For 1.37 Testing/Documentation: be sure this works with admin jobs so that the user can get prompted to insert the correct tape. Possibly some way to say to run the job but don't save the files. +- Implement FileOptions (see end of this document) - Make things like list where a file is saved case independent for Windows. - Implement migrate +- Bacula needs to propagate SD errors. + > > cluster-dir: Start Backup JobId 252, Job=REUTERS.2003-08-11_15.04.12 + > > prod4-sd: REUTERS.2003-08-11_15.04.12 Error: Write error on device + /dev/nst0. ERR=Input/output error. + > > prod4-sd: REUTERS.2003-08-11_15.04.12 Error: Re-read of last block failed. + Last block=5162 Current block=5164. + > > prod4-sd: End of medium on Volume "REU007" Bytes=16,303,521,933 + - Use autochanger to handle multiple devices. - Add SuSE install doc to list. - Check and rechedk "Invalid block number" +- Make bextract release the drive properly between tapes + so that an autochanger can be made to work. - User wants to NOT backup up certain big files (email files). - Maybe remove multiple simultaneous devices code in SD. - On Windows with very long path names, it may be impossible to create a file (and thus restore it) because the total length is too long. We must cd into the directory then create the file without the full path name. +- lstat() is not going to work on Win32 for testing date. - Implement a Recycle command - Add client name to cram-md5 challenge so Director can immediately verify if it is the correct client. +- Add JobLevel in FD status (but make sure it is defined). - Audit all UA commands to ensure that we always prompt where possible. +- Check Jmsg in bnet, may not work, must dup bsock. +- Suppress Job Name in Jmsg for console +- Create Pools that are referenced in a Run statement at startup if possible. +- Use runbeforejob to unload, then reload a volume previously used, + then the next job run gets an error reading the drive. - Make bootstrap filename unique. - Test a second language e.g. french. - Start working on Base jobs. +- Make "make binary-release" work from any directory. - Implement UnsavedFiles DB record. - Implement argc/argv for daemon command line scanning using table driven stuff below. +- Implement table driven single argc/argv scanner to pickup all arguments. + Much like xxx_conf.c scan table. + keyword, handler(store_routine), store_address, code, flags, default. - From Phil Stracchino: It would probably be a per-client option, and would be called something like, say, "Automatically purge obsoleted jobs". What it @@ -472,10 +690,16 @@ For 1.37 Testing/Documentation: - Currently in mount.c:236 the SD simply creates a Volume. It should have explicit permission to do so. It should also mark the tape in error if there is an error. +- Make sure all restore counters are working correctly in the FD. - SD Bytes Read is wrong. +- Look at ALL higher level routines that call block.c to be sure + they don't expect something in errmsg. - Investigate doing RAW backup of Win32 partition. +- Add thread specific data to hold the jcr -- send error messages from + low level routines by accessing it and using Jmsg(). - Cancel waiting for Client connect in SD if FD goes away. +- Examine Bare Metal restore problem (a FD crash exists somewhere ...). - Implement timeout in response() when it should come quickly. - Implement console @echo command. - Implement a Slot priority (loaded/not loaded). @@ -483,6 +707,9 @@ For 1.37 Testing/Documentation: - Implement single pane restore (much like the Gftp panes). - Implement Automatic Mount even in operator wait. - Implement create "FileSet"? +- Fix watchdog pthread crash on Win32 (this is pthread_kill() Cygwin bug) +- Implement "scratch pool" where tapes are defined and can be + taken by any pool that needs them. - Implement restore "current system", but take all files without doing selection tree -- so that jobs without File records can be restored. @@ -526,6 +753,8 @@ For 1.37 Testing/Documentation: - Figure out how to do a bare metal Windows restore - Possibly add email to Watchdog if drive is unmounted too long and a job is waiting on the drive. +- Restore program that errs in SD due to no tape, reports + OK incorrectly in output. - After unmount, if restore job started, ask to mount. - Convert all %x substitution variables, which are hard to remember and read to %(variable-name). Idea from TMDA. @@ -995,8 +1224,167 @@ Block Position: 0 ==== -=== Done -- Add "Rerun failed levels = yes/no" to Job resource. -- Fix CDROM make script to permit picking up already installed - static FD. -- Add date/time to each Jmsg. +=== Done in 1.34.3 +- To pass Include 1 or two letter commands + I Name Include name - first record + B Name Base name - repeat + R "xxx" Regexp + W "xxx" Wild Card + E zzz Exclude expression (wild card) + P "plugin" Plugin + D "reader" Reader program + T "writer" Writer program + O Options In current commpressed format + (compression, signature, onefs, recurse, sparse, + replace, verify options, ...) + N End option set + B BaseName Start second option set any letter + ... + E + F Number Number of filenames to follow + + B Name + ... + N End option set + F Number Number of filenames to follow + + ... +- Add regression of btape "fill" +==== Done in 1.34.4 +- Implement "label slots=1,2... pool=yyy barcodes" +- Mark a non-removable disk Volume in error rather than asking sys op to + mount it. +- Implement Fixed storage LabelFormat test. +- Add reporting in attr despooling. +- Figure out how to use ssh or stunnel to protect Bacula communications. + Add Dan's work to manual See ssl.txt + +==== Done in 1.35.0 +- Implement fast tree insert (doubly linked list) +- Disallow using Internal database +- Feedback while the restore tree is being built. +- Add detection of Whitebox release in ./configure +- Add InChanger to "list media" +- Implement second cut of SIGHUP in Dir + (Implement resources on a single pointer) +- Add regular expressions to FileSets (needs testing). +- Test new despooling error recovery code when partition fills. +- Sort Scheduled jobs status listing by start time. +- Add priority to Scheduled jobs status listing. +- Look at Win32 inc problem when new directory added files not saved??? +- Require resource names to be unique. +- Make sure that all errors from libacl are printed. +- Make FD run on Win95 if possible (not really possible). +- Fix GROUP BYs in all SQL (done by Dan -- thanks) +- Make entering multiple Storage names in Dir illegal. +- Make btape release the drive during the "test" append. +- Fix restore: + You have selected the following JobIds: 739,856,797 + Building directory tree for JobId 739 ... + Building directory tree for JobId 856 ... + Building directory tree for JobId 797 ...3 + Jobs inserted into the tree. +- Fix errno handling in win32 compat routines. +- Add better error codes to run_program (10000+) +- Revisit and revise Disaster Recovery (fix SCSI and RAID + disk detection) +- When passwords do not match, print message that points the + user to the doc. +- Do tape alerts -- see tapealert.txt +- Find memory leaks in address_conf.c +- Network order of port and ip addresses. +- SetIP in dird/fd_cmds.c is broken. +- don't use inet_addr() it is deprecated. +- Fix code in filed.c for init_bsock(); +- Fix code in console.c for init_bsock(); +- Solve the termcap.h problem on Solaris configure. +- Make Verify jobs require exclusive use of Volume as Restore + jobs do. +- Fix restore ++++ that get intermingled with "Building directory tree" +- Fix doc in dirdconf.html for @, where the file must + have not a list of files, but + file = xxx + file = yyy +- Test Win32 errno handling. +- port 1.34.6-block.patch to 1.35 +- Look at Chris' patch for bscan bug. +- Fix error handling in spooling both data and attribute. +- Implement Ignore FileSet Change. +- Doc new duration time input editing. +- Bacula rescue CDROM implement isolinux +- Make sure Qmsgs are dequeued by FD and SD. +- Check if ACLs allocated at dird_conf.c:1214 are being properly + released. +- Test/doc Tape Alerts +- Doc dbcheck eliminate orphaned clients. +- Doc Phil's new delete job jobid scanning code. +- Document that console commands can be abbreviated. +- Doc update AllFromVol +- Doc -p option in stored +- New IP address specification is used as follows: + [sdaddresses|diraddresses|fdaddresses] = { [[ip|ipv4|ipv6] = { + [[addr|port] = [^ ]+[\n;]+] }] } + + so it could look for example like this: + SDaddresses = { ip = { + addr = 1.2.3.4; port = 1205; } + ipv4 = { + addr = 1.2.3.4; port = http; } + ipv6 = { + addr = 1.2.3.4; + port = 1205; + } + ip = { + addr = 1.2.3.4 + port = 1205 + } + ip = { + addr = 1.2.3.4 + } + ip = { + addr = 201:220:222::2 + } + ip = { + addr = bluedot.thun.net + } + } + as a consequence, you can now specify multiple IP addresses and + ports to be used. In the case of a server, it will listen on + all those that you specify. In the case of connecting to the server, + Bacula will attempt connecting to one at a time until it succeeds. + And, in a few other special cases, Bacula will use only the first + address specified. + + The default port numbers are still the same and the services and hosts + are also resolved by name. So now you could use the real names for the + port numbers. + + An ip section will allow resolution to either an ipv4 or an ipv6 address. + An ipv4 section forces the resolution to be only ipv4, and an ipv6 section + forces the resolution to be only ipv6. +- Fix silly restriction requiring Include { Options { xxx } } to be + on separate lines. +- Restore c: with a prefix into /prefix/c/ to prevent c: and d: + files with the same name from overwritting each other. +- Add "Multiple connections = yes/no" to catalog resource. +- Add new DCR calling sequences everywhere in SD. This will permit + simultaneous use of multiple devices by a single job. +- Fix bscan so that it releases the drive when requesting a new tape. +- List verify options for DiskToCatalog in doc. +- Turn on transactions if multiple connections are on in DB. +- Fix storage overrides in Run directives. +- Look into failing Excludes in Win32 +- Make restore check if the file size restored is correct. +- Backspace to beginning of line (conio) does not erase first char. +- Fix possible bug in update volumefrompool (email 9/28 from + jesk@killall.org +- Add relabel regression test. +- Document a get out of jail procedure if everything breaks if + you lost/broke the Catalog -- do the same for "I know my + file is there how do I get it back?". +- Fix documentation for readline. +- Add File indexes as suggested by Martin -- modify update + scripts to add them. +- Modify postgresql update script to remove bigint FilenameId + reference. +- Kill daemons at levels in the teens rather than late. diff --git a/bacula/patches/fix_postgresql_tables b/bacula/patches/fix_postgresql_tables deleted file mode 100755 index 2d69f89278..0000000000 --- a/bacula/patches/fix_postgresql_tables +++ /dev/null @@ -1,35 +0,0 @@ -#!/bin/sh -# -# Shell script to fix PostgreSQL tables in version 8 -# -echo " " -echo "This script will fix a Bacula PostgreSQL database version 8" -echo "Depending on the size of your database," -echo "this script may take several minutes to run." -echo " " -# -# Set the following to the path to psql. -bindir=****EDIT-ME to be the path to psql**** - -if $bindir/psql $* -f - < -# e.g. -# -# ./config kern.conf -# -# - -# suck in user's configuration -@CONFIG@ - -WHICHDB?="--with-sqlite=${SQLITE_DIR}" - -first_rule: all - -all: - -setup: bacula - -# -# Some machines cannot handle the sticky bit and other garbage that -# is in weird-files, so we load and run it only on Linux machines. -# -bacula: all - @rm -rf bin build weird-files tmp - (if test x`uname` = xLinux -o x`uname` = xFreeBSD ; then \ - tar xfz weird-files.tar.gz ;\ - fi) - rm -rf tmp working - mkdir tmp working - scripts/setup ${BACULA_SOURCE} ${EMAIL} ${WHICHDB} - scripts/do_sed ${EMAIL} ${TAPE_DRIVE} ${AUTOCHANGER} ${AUTOCHANGER_PATH} - -# Run all non-root userid tests -test: - ./all-non-root-tests - -# run all file and tape tests -full_test: - ./all-tape-and-file-tests - -# These tests require you to run as root -root_test: - ./all-root-tests - -clean: - scripts/cleanup - rm -f /tmp/file-list - rm -f tmp/* working/* - rm -f test.out - rm -f diff - rm -f 1 2 3 scripts/1 scripts/2 scripts/3 tests/1 tests/2 tests/3 - -# Reset our userid after running as root -reset: - chown -R ${USER}:${USER} . tmp working - scripts/cleanup - rm -f /tmp/file-list tmp/file-list - rm -f tmp/* working/* - -distclean: clean - rm -rf bin build weird-files weird-files weird-files2 tmp working - rm -f scripts/*.conf - diff --git a/regress/README b/regress/README deleted file mode 100644 index c63b737ed7..0000000000 --- a/regress/README +++ /dev/null @@ -1,101 +0,0 @@ - Bacula Regression - Kern Sibbald - December 2003 - -This is Bacula's regression script directory. At this time -(December 2003), it is still in development, so all the tests are -not complete. - -To set it up, create your personal configuration file, by -copying prototype.conf to xxx.conf or simply editing prototype.conf -directly. - -Then edit your conf file and define appropriate values -for the variables that are in that file. If you want to see -a real example, look at kern.conf, but please don't use my -email address! - -Make sure that depkgs is pre-built if it isn't -already: (cd your-depkgs; make sqlite). - -Then do: - - ./config xxx.conf - make setup - -You run the above one time. This will build a Makefile from -Makefile.in and your xxx.conf file, copy the Bacula source, -configure, build it, and configure all the Bacula scripts -and conf files. If you change your source, you will need to -redo this command. - -Then you can run any of the tests in the tests subdirectory. -Each test whose name ends in -root requires you to be root for -a resonable run. Each test is totally independent of any other -test. Aside from the required "make setup", each test is totally -self-initalizing and should clean up after itself. - -Not all the tests yet report OK. This is simply because there are -some spurious differences that I haven't yet taken the time to -eliminate. The working scrips as of 24 Apr 03 are: - -backup-bacula-test -sparse-test -compressed-test -sparse-compressed-test -two-jobs-test -wierd-files-test -verify-vol-test - -The tests expect you to execute them from the main regress -directory! - -You can run them individually as: - - tests/two-jobs-test - -or all non-root tests (my normal testing under my account) - - ./all-non-root-tests - -or all tests (I only run these before a production release): - - su - ./all-tests - - -after running the root tests, while still root, it is a good idea -to do: - - make reset - -this cleans up any files that may be created with root permissions. - -If you want to add more tests, do so by putting the shell script -in the tests subdirectory. Be careful when adding (or better not) -new clients, pools, and such to the test-bacula-dir.conf.in file -as it may invalidate a good number of tests, which respond to -questions by answering with a number (i.e. the order of the selection -list is known). It might be better to add your own testb-bacula... -configuration file. - -To avoid re-doing a make setup if you have made a change to the -conf files, and you do not need a new copy of the source, you can simply do: - - scripts/do-sed - -Debugging failed tests: -The simplest thing to do is to edit tests/xxxx where xxxx is the name of -a or the test that is failing and change all: - - @output - -to - - @tee - -re-run the test. The output will display on your terminal. In rare cases, -for example to get bacula debug output, you might want to remove the -"2>&1 >/dev/null" from the end of the bin/bacula call or from the end -of the diff call, assuming you want to "see" the diff output. - diff --git a/regress/all-non-root-2tape-tests b/regress/all-non-root-2tape-tests deleted file mode 100755 index 5201731263..0000000000 --- a/regress/all-non-root-2tape-tests +++ /dev/null @@ -1,12 +0,0 @@ -#!/bin/sh -# -# Run all tape tests -# -tests/test0 -tests/two-volume-tape -tests/incremental-2tape -echo " " -echo " " -echo "2 Tape Test results" -cat test.out -scripts/cleanup diff --git a/regress/all-non-root-tape-tests b/regress/all-non-root-tape-tests deleted file mode 100755 index 7af5fbf961..0000000000 --- a/regress/all-non-root-tape-tests +++ /dev/null @@ -1,19 +0,0 @@ -#!/bin/sh -# -# Run all tape tests -# -tests/test0 -tests/backup-bacula-tape -tests/small-file-size-tape -tests/restore-by-file-tape -tests/incremental-tape -tests/four-concurrent-jobs-tape -tests/four-jobs-tape -tests/fixed-block-size-tape -tests/bscan-tape -tests/btape-fill-tape -echo " " -echo " " -echo "Test results" -cat test.out -scripts/cleanup diff --git a/regress/all-non-root-tests b/regress/all-non-root-tests deleted file mode 100755 index c36f440458..0000000000 --- a/regress/all-non-root-tests +++ /dev/null @@ -1,35 +0,0 @@ -#!/bin/sh -# -# Run all tests -# -tests/test0 -tests/backup-bacula-test -tests/verify-vol-test -tests/sparse-test -tests/compressed-test -tests/sparse-compressed-test -tests/weird-files-test -tests/two-jobs-test -tests/two-vol-test -tests/six-vol-test -tests/bscan-test -tests/weird-files2-test -tests/concurrent-jobs-test -tests/four-concurrent-jobs-test -tests/bsr-opt-test -tests/bextract-test -tests/recycle-test -tests/span-vol-test -tests/restore-by-file-test -tests/restore2-by-file-test -tests/four-jobs-test -tests/incremental-test -tests/decremental-test -tests/restore-disk-seek-test -tests/query-test -tests/auto-label-test -echo " " -echo " " -echo "Test results" -cat test.out -scripts/cleanup diff --git a/regress/all-root-tests b/regress/all-root-tests deleted file mode 100755 index 3f077bba4c..0000000000 --- a/regress/all-root-tests +++ /dev/null @@ -1,11 +0,0 @@ -#!/bin/sh -# -# Run all root tests -# -rm -f test.out -tests/dev-test-root -tests/etc-test-root -tests/lib-test-root -tests/usr-tape-root -cat test.out -scripts/cleanup diff --git a/regress/all-tape-and-file-tests b/regress/all-tape-and-file-tests deleted file mode 100755 index 9bc3e7676c..0000000000 --- a/regress/all-tape-and-file-tests +++ /dev/null @@ -1,6 +0,0 @@ -#!/bin/sh -# -# Run all tests -# -./all-non-root-tests -./all-non-root-tape-tests diff --git a/regress/all-tests b/regress/all-tests deleted file mode 100755 index b1b2b35e86..0000000000 --- a/regress/all-tests +++ /dev/null @@ -1,8 +0,0 @@ -#!/bin/sh -# -# Run all tests -# -./all-non-root-tests -./all-root-tests -cat test.out -scripts/cleanup diff --git a/regress/config b/regress/config deleted file mode 100755 index 4bc4f52703..0000000000 --- a/regress/config +++ /dev/null @@ -1,9 +0,0 @@ -#/bin/sh -# -# First argument is expected to be a user's configuration file -# -if ! test -e $1 ; then - echo "Arg1 must specify a config file (e.g. prototype.conf)" - exit 1 -fi -sed -e "/@CONFIG@/r $1" -e "s/@CONFIG@//" Makefile.in >Makefile diff --git a/regress/do_all b/regress/do_all deleted file mode 100755 index ce86177ef9..0000000000 --- a/regress/do_all +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh -make setup -./all-tape-and-file-tests diff --git a/regress/do_all_tapes b/regress/do_all_tapes deleted file mode 100755 index dd07d2ec99..0000000000 --- a/regress/do_all_tapes +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh -make setup -./all-non-root-tape-tests diff --git a/regress/file b/regress/file deleted file mode 100755 index 8f2089051b..0000000000 --- a/regress/file +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -./all-non-root-tests diff --git a/regress/kern.conf b/regress/kern.conf deleted file mode 100644 index dbe0c96ca4..0000000000 --- a/regress/kern.conf +++ /dev/null @@ -1,15 +0,0 @@ -# Where to get the source to be tested -BACULA_SOURCE="${HOME}/bacula/k" - -# Where to send email !!!!! Change me !!!!!!! -EMAIL=kern@sibbald.com - -# Full "default" path where to find sqlite (no quotes!) -SQLITE_DIR=${HOME}/bacula/depkgs/sqlite - -TAPE_DRIVE="/dev/nst0" -# if you don't have an autochanger set AUTOCHANGER to /dev/null -AUTOCHANGER="/dev/sg0" - -# This must be the path to the autochanger including its name -AUTOCHANGER_PATH="/usr/local/bin/mtx" diff --git a/regress/prototype.conf b/regress/prototype.conf deleted file mode 100644 index 14592a3f94..0000000000 --- a/regress/prototype.conf +++ /dev/null @@ -1,37 +0,0 @@ -# -# Prototype personal configuration file for the regression -# scripts. Either edit this file directly, or better copy -# it elsewhere so it won't get overwritten. -# - -# -# Where to get the source to be tested -# -BACULA_SOURCE= - -# Where to send email messages -# -EMAIL= - -# Full "default" path where to find sqlite. -# This is only used if you do not specify a database override on the -# make command. -# -# N.B. DON'T PUT QOUTES AROUND THE PATH. -# -SQLITE_DIR=${HOME}/bacula/depkgs/sqlite - -# -# The device name of your tape drive if you have one -# -TAPE_DRIVE=/dev/nst0 - -# -# if you don't have an autochanger set AUTOCHANGER to /dev/null -# -AUTOCHANGER=/dev/sg0 - -# -# This must be the path to the autochanger including its name -# -AUTOCHANGER_PATH=/bin/mtx diff --git a/regress/run b/regress/run deleted file mode 100755 index d48e2623c6..0000000000 --- a/regress/run +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh -bin/bacula start -bin/bconsole -c bin/bconsole.conf diff --git a/regress/scripts/.cvsignore b/regress/scripts/.cvsignore deleted file mode 100644 index 002e974d47..0000000000 --- a/regress/scripts/.cvsignore +++ /dev/null @@ -1,17 +0,0 @@ -new-test-bacula-dir.conf -bacula-dir.conf -bacula-fd.conf -bacula-sd.conf -console.conf -bconsole.conf -test-bacula-dir.conf -test-bacula-fd.conf -test-bacula-sd.conf -test-console.conf -testa-bacula-dir.conf -bacula-dir-tape.conf -bacula-sd-tape.conf -bacula-sd-2tape.conf -cleanup-tape -cleanup-2tape -prepare-two-tapes diff --git a/regress/scripts/bacula-dir-tape.conf.in b/regress/scripts/bacula-dir-tape.conf.in deleted file mode 100644 index 9cbb557727..0000000000 --- a/regress/scripts/bacula-dir-tape.conf.in +++ /dev/null @@ -1,144 +0,0 @@ -# -# Default Bacula Director Configuration file -# -# The only thing that MUST be changed is to add one or more -# file or directory names in the Include directive of the -# FileSet resource. -# -# For Bacula release 1.33 -# -# You might also want to change the default email address -# from root to your address. See the "mail" and "operator" -# directives in the Messages resource. -# - -Director { # define myself - Name = @hostname@-dir - DIRport = 8101 # where we listen for UA connections - QueryFile = "@scriptdir@/query.sql" - WorkingDirectory = "@working_dir@" - PidDirectory = "@piddir@" - Maximum Concurrent Jobs = 4 - Password = "pNvX1WiXnwv2C/F7E52LGvw6rKjbbPvu2kyuPa9pVaL3" - Messages = Daemon -} - -# -# Define the main nightly save backup job -# By default, this job will back up to disk in /tmp -Job { - Name = "NightlySave" - Type = Backup - Client=@hostname@-fd - FileSet="Full Set" - Storage = DDS-4 - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" - Maximum Concurrent Jobs = 4 - SpoolData = yes -} - - -# Standard Restore template, to be changed by Console program -Job { - Name = "RestoreFiles" - Type = Restore - Client=@hostname@-fd - FileSet="Full Set" - Storage = DDS-4 - Messages = Standard - Pool = Default - Where = /tmp/bacula-restores -} - - -# List of files to be backed up -FileSet { - Name = "Full Set" - Include = signature=MD5 { - &1 >/dev/null -if [ $? != 0 ] ; then - echo " " - echo " !!!! Zombie Jobs in Director !!!!" - echo " !!!! Zombie Jobs in Director !!!!" >>test.out - echo " " -fi -grep "No Jobs running." tmp/fd.out 2>&1 >/dev/null -if [ $? != 0 ] ; then - echo " " - echo " !!!! Zombie Jobs in File daemon !!!!" - echo " !!!! Zombie Jobs in File daemon !!!!" >>test.out - echo " " -fi -grep "No Jobs running." tmp/sd.out 2>&1 >/dev/null -if [ $? != 0 ] ; then - echo " " - echo " !!!! Zombie Jobs in Storage daemon !!!!" - echo " !!!! Zombie Jobs in Storage daemon !!!!" >>test.out - echo " " -fi -grep "ERROR" tmp/log*.out 2>&1 >/dev/null -if [ $? = 0 ] ; then - echo " " - echo " !!!! ERROR in log output !!!!" - echo " !!!! ERROR in log output !!!!" >>test.out - echo " " -fi -grep "Fatal Error" tmp/log*.out 2>&1 >/dev/null -if [ $? = 0 ] ; then - echo " " - echo " !!!! Fatal Error in log output !!!!" - echo " !!!! Fatal Error in log output !!!!" >>test.out - echo " " -fi - - diff --git a/regress/scripts/cleanup b/regress/scripts/cleanup deleted file mode 100755 index 3651759bc3..0000000000 --- a/regress/scripts/cleanup +++ /dev/null @@ -1,18 +0,0 @@ -#!/bin/sh -# -# Cleanup left over files -- both before and after test run -# -rm -rf /tmp/TestVolume001 /tmp/bacula-restores /tmp/Small* -rm -rf tmp/original tmp/bacula-restores tmp/Small* tmp/TestVolume* -rm -rf tmp/restored tmp/largefile tmp/bscan.bsr tmp/log*.out -rm -rf /tmp/sed_tmp /tmp/file-list -rm -rf tmp/build tmp/restore-list tmp/restore2-list -rm -rf tmp/fd.out tmp/dir.out tmp/sd.out -rm -rf working/log tmp/TEST-* - -bin/bacula stop 2>&1 >/dev/null -cd bin -./drop_bacula_tables >/dev/null 2>&1 -./make_bacula_tables >/dev/null 2>&1 -./grant_bacula_privileges >/dev/null 2>&1 -cd .. diff --git a/regress/scripts/cleanup-2tape.in b/regress/scripts/cleanup-2tape.in deleted file mode 100755 index 70e6b7b0f0..0000000000 --- a/regress/scripts/cleanup-2tape.in +++ /dev/null @@ -1,30 +0,0 @@ -#!/bin/sh -# -# Cleanup left over files -- both before and after test run -# -scripts/cleanup - -if ! test x@autochanger@ = x/dev/null; then - drive=`bin/mtx-changer @autochanger@ loaded` - if ! test x$drive = x2; then - bin/mtx-changer @autochanger@ unload - bin/mtx-changer @autochanger@ load 2 - fi - mt -f @tape_drive@ rewind - mt -f @tape_drive@ weof -fi - - -# -# If we have an autochanger always load tape in slot 1 -# -if ! test x@autochanger@ = x/dev/null; then - drive=`bin/mtx-changer @autochanger@ loaded` - if ! test x$drive = x1; then - bin/mtx-changer @autochanger@ unload - bin/mtx-changer @autochanger@ load 1 - fi -fi - -mt -f @tape_drive@ rewind -mt -f @tape_drive@ weof diff --git a/regress/scripts/cleanup-tape.in b/regress/scripts/cleanup-tape.in deleted file mode 100755 index 98ed537766..0000000000 --- a/regress/scripts/cleanup-tape.in +++ /dev/null @@ -1,8 +0,0 @@ -#!/bin/sh -# -# Cleanup left over files -- both before and after test run -# -scripts/cleanup - -mt -f @tape_drive@ rewind -mt -f @tape_drive@ weof diff --git a/regress/scripts/copy-2tape-confs b/regress/scripts/copy-2tape-confs deleted file mode 100755 index dbf9466330..0000000000 --- a/regress/scripts/copy-2tape-confs +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh -/bin/cp -f scripts/bacula-dir-tape.conf bin/bacula-dir.conf -/bin/cp -f scripts/bacula-sd-2tape.conf bin/bacula-sd.conf -/bin/cp -f scripts/test-bacula-fd.conf bin/bacula-fd.conf -/bin/cp -f scripts/test-console.conf bin/bconsole.conf diff --git a/regress/scripts/copy-confs b/regress/scripts/copy-confs deleted file mode 100755 index d1e6cc1c36..0000000000 --- a/regress/scripts/copy-confs +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh -/bin/cp -f scripts/bacula-dir.conf bin/bacula-dir.conf -/bin/cp -f scripts/bacula-sd.conf bin/bacula-sd.conf -/bin/cp -f scripts/bacula-fd.conf bin/bacula-fd.conf -/bin/cp -f scripts/bconsole.conf bin/bconsole.conf diff --git a/regress/scripts/copy-tape-confs b/regress/scripts/copy-tape-confs deleted file mode 100755 index 588dddc35b..0000000000 --- a/regress/scripts/copy-tape-confs +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh -/bin/cp -f scripts/bacula-dir-tape.conf bin/bacula-dir.conf -/bin/cp -f scripts/bacula-sd-tape.conf bin/bacula-sd.conf -/bin/cp -f scripts/test-bacula-fd.conf bin/bacula-fd.conf -/bin/cp -f scripts/test-console.conf bin/bconsole.conf diff --git a/regress/scripts/copy-test-confs b/regress/scripts/copy-test-confs deleted file mode 100755 index 61b120f610..0000000000 --- a/regress/scripts/copy-test-confs +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh -/bin/cp -f scripts/new-test-bacula-dir.conf bin/bacula-dir.conf -/bin/cp -f scripts/test-bacula-sd.conf bin/bacula-sd.conf -/bin/cp -f scripts/test-bacula-fd.conf bin/bacula-fd.conf -/bin/cp -f scripts/test-console.conf bin/bconsole.conf diff --git a/regress/scripts/copy-testa-confs b/regress/scripts/copy-testa-confs deleted file mode 100755 index 6b5f30c3ef..0000000000 --- a/regress/scripts/copy-testa-confs +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh -/bin/cp -f scripts/testa-bacula-dir.conf bin/bacula-dir.conf -/bin/cp -f scripts/test-bacula-sd.conf bin/bacula-sd.conf -/bin/cp -f scripts/test-bacula-fd.conf bin/bacula-fd.conf -/bin/cp -f scripts/test-console.conf bin/bconsole.conf diff --git a/regress/scripts/do_sed b/regress/scripts/do_sed deleted file mode 100755 index e999a521fc..0000000000 --- a/regress/scripts/do_sed +++ /dev/null @@ -1,59 +0,0 @@ -#!/bin/sh -# -if test $# != 4 ; then - echo "First arg must be email name" - echo " and the second must be a tape drive" - echo " and the third must be a tape control name or /dev/null" - echo " and the fourth must be the full path to the mtx program" - exit 1 -fi -out="/tmp/sed_tmp" -cwd=`pwd` -host=`hostname | tr '.' ' ' | cut -f 1 -d ' '` -if test x$host = x ; then - host=localhost -fi -# Create sed command script -echo "s%@sbindir@%${cwd}/bin%g" >${out} -echo "s%@scriptdir@%${cwd}/bin%g" >>${out} -echo "s%@working_dir@%${cwd}/working%g" >>${out} -echo "s%@piddir@%${cwd}/working%g" >>${out} -echo "s%@subsysdir@%${cwd}/working%g" >>${out} -echo "s%@job_email@%${1}%g" >>${out} -echo "s%@tape_drive@%${2}%g" >>${out} -echo "s%@autochanger@%${3}%g" >>${out} -echo "s%@tmpdir@%${cwd}/tmp%g" >>${out} -echo "s%@hostname@%${host}%g" >>${out} -echo "s%@changer_path@%${4}%g" >>${out} - -# process .in files with sed script -sed -f ${out} ${cwd}/scripts/test-bacula-dir.conf.in >${cwd}/scripts/test-bacula-dir.conf -sed -f ${out} ${cwd}/scripts/new-test-bacula-dir.conf.in >${cwd}/scripts/new-test-bacula-dir.conf -sed -f ${out} ${cwd}/scripts/testa-bacula-dir.conf.in >${cwd}/scripts/testa-bacula-dir.conf -sed -f ${out} ${cwd}/scripts/test-bacula-fd.conf.in >${cwd}/scripts/test-bacula-fd.conf -sed -f ${out} ${cwd}/scripts/test-bacula-sd.conf.in >${cwd}/scripts/test-bacula-sd.conf -sed -f ${out} ${cwd}/scripts/test-console.conf.in >${cwd}/scripts/test-console.conf -sed -f ${out} ${cwd}/scripts/bacula-dir-tape.conf.in >${cwd}/scripts/bacula-dir-tape.conf -sed -f ${out} ${cwd}/scripts/bacula-sd-tape.conf.in >${cwd}/scripts/bacula-sd-tape.conf -sed -f ${out} ${cwd}/scripts/bacula-sd-2tape.conf.in >${cwd}/scripts/bacula-sd-2tape.conf -sed -f ${out} ${cwd}/scripts/cleanup-tape.in >${cwd}/scripts/cleanup-tape -sed -f ${out} ${cwd}/scripts/cleanup-2tape.in >${cwd}/scripts/cleanup-2tape -sed -f ${out} ${cwd}/scripts/prepare-two-tapes.in >${cwd}/scripts/prepare-two-tapes -cp ${cwd}/bin/bacula-sd.conf /tmp/bac$$ -sed s%/tmp%${cwd}/tmp%g /tmp/bac$$ >${cwd}/bin/bacula-sd.conf -chmod 777 ${cwd}/scripts/cleanup-*tape ${cwd}/scripts/prepare-two-tapes -rm -f /tmp/bac$$ -cp ${cwd}/bin/mtx-changer /tmp/bac$$ -sed "s%^MTX.*$%MTX=${4}%g" /tmp/bac$$ >${cwd}/bin/mtx-changer -chmod 777 ${cwd}/bin/mtx-changer - -# get proper SD tape definitions -if test x`uname` = xLinux ; then \ - cp -f scripts/linux_tape_options bin/tape_options ; \ -fi -if test x`uname` = xFreeBSD ; then \ - cp -f scripts/freebsd_tape_options bin/tape_options ; \ -fi - -rm -f ${out} -rm -f /tmp/bac$$ diff --git a/regress/scripts/exclude-dev-test b/regress/scripts/exclude-dev-test deleted file mode 100644 index 4165ea1ae7..0000000000 --- a/regress/scripts/exclude-dev-test +++ /dev/null @@ -1,5 +0,0 @@ -dev/ptmx -dev/pts -dev/rd/c5d2 -dev/rd -dev/shm diff --git a/regress/scripts/exclude-etc-test b/regress/scripts/exclude-etc-test deleted file mode 100644 index f59ca8df2a..0000000000 --- a/regress/scripts/exclude-etc-test +++ /dev/null @@ -1 +0,0 @@ -etc/mail/statistics diff --git a/regress/scripts/exclude-lib-test b/regress/scripts/exclude-lib-test deleted file mode 100644 index 5be32f443b..0000000000 --- a/regress/scripts/exclude-lib-test +++ /dev/null @@ -1,5 +0,0 @@ -lib/ld-2.2.5.so -lib/libtermcap.so.2.0.8 -lib/libc-2.2.5.so -lib/libnsl-2.2.5.so -lib/libnss_files-2.2.5.so diff --git a/regress/scripts/flist b/regress/scripts/flist deleted file mode 100644 index 7e7e1f0bf8..0000000000 --- a/regress/scripts/flist +++ /dev/null @@ -1,16 +0,0 @@ -/build/doc/bacula.pdf -/build/configure -/build/src/stored/bextract -/build/src/tools/testfind -/build/Makefile.in -/build/src/dird/bacula-dir -/build/src/console/bconsole -/build/src/filed/bacula-fd -/build/src/findlib/find_one.c -/build/src/jcr.h -/build/platforms/Makefile.in -/build/platforms/redhat/Makefile.in -/build/scripts/Makefile.in -/build/src/filed/win32/bin/cygwin1.dll -/build/src/filed/win32/winservice.cpp -/build/src/filed/restore.c diff --git a/regress/scripts/freebsd_tape_options b/regress/scripts/freebsd_tape_options deleted file mode 100644 index 05be3449c4..0000000000 --- a/regress/scripts/freebsd_tape_options +++ /dev/null @@ -1,8 +0,0 @@ -# -# FreeBSD tape drive options -# -Hardware End of Medium = no -Fast Forward Space File = no -BSF at EOM = yes -Backward Space Record = no -TWO EOF = yes diff --git a/regress/scripts/linux_osst_tape_options b/regress/scripts/linux_osst_tape_options deleted file mode 100644 index 5def0c08cb..0000000000 --- a/regress/scripts/linux_osst_tape_options +++ /dev/null @@ -1,7 +0,0 @@ - Minimum Block Size = 32768 - Maximum Block Size = 32768 - Hardware End of Medium = yes - BSF at EOM = yes - Fast Forward Space File = yes - Two EOF = no - diff --git a/regress/scripts/linux_tape_options b/regress/scripts/linux_tape_options deleted file mode 100644 index 601eb82aa5..0000000000 --- a/regress/scripts/linux_tape_options +++ /dev/null @@ -1 +0,0 @@ -# nothing needed for Linux diff --git a/regress/scripts/new-test-bacula-dir.conf.in b/regress/scripts/new-test-bacula-dir.conf.in deleted file mode 100644 index d1c849f6d1..0000000000 --- a/regress/scripts/new-test-bacula-dir.conf.in +++ /dev/null @@ -1,312 +0,0 @@ -# -# Default Bacula Director Configuration file -# -# The only thing that MUST be changed is to add one or more -# file or directory names in the Include directive of the -# FileSet resource. -# -# For Bacula release 1.33 -# -# You might also want to change the default email address -# from root to your address. See the "mail" and "operator" -# directives in the Messages resource. -# - -Director { # define myself - Name = @hostname@-dir - DIRport = 8101 # where we listen for UA connections - QueryFile = "@scriptdir@/query.sql" - WorkingDirectory = "@working_dir@" - PidDirectory = "@piddir@" - SubSysDirectory = "@subsysdir@" - Maximum Concurrent Jobs = 4 - Password = "pNvX1WiXnwv2C/F7E52LGvw6rKjbbPvu2kyuPa9pVaL3" # Console password - Messages = Standard -} - -# -# Define the main nightly save backup job -# By default, this job will back up to disk in /tmp -Job { - Name = "NightlySave" - Type = Backup - Client=@hostname@-fd - FileSet="Full Set" - Storage = File - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" - Maximum Concurrent Jobs = 4 - SpoolData=yes -} - -Job { - Name = "MonsterSave" - Type = Backup - Client=@hostname@-fd - FileSet="Full Set" - Storage = File1 - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" -} - - -Job { - Name = "VerifyVolume" - Type = Verify - Level = VolumeToCatalog - Client=@hostname@-fd - FileSet="Full Set" - Storage = File - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" -} - - -Job { - Name = "SparseTest" - Type = Backup - Client=@hostname@-fd - FileSet="SparseSet" - Storage = File - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" -} - -Job { - Name = "CompressedTest" - Type = Backup - Client=@hostname@-fd - FileSet="CompressedSet" - Storage = File - Messages = Standard - Pool = Default - Maximum Concurrent Jobs = 4 - Write Bootstrap = "@working_dir@/NightlySave.bsr" -} - -Job { - Name = "SparseCompressedTest" - Type = Backup - Client=@hostname@-fd - FileSet="SparseCompressedSet" - Storage = File - Messages = Standard - Pool = Default - Write Bootstrap = "@working_dir@/NightlySave.bsr" -} - - -# Backup the catalog database (after the nightly save) -Job { - Name = "BackupCatalog" - Type = Backup - Client=@hostname@-fd - FileSet="Catalog" -# Schedule = "WeeklyCycleAfterBackup" - Storage = File - Messages = Standard - Pool = Default - # This creates an ASCII copy of the catalog - RunBeforeJob = "@sbindir@/make_catalog_backup -u bacula" - # This deletes the copy of the catalog - RunAfterJob = "@sbindir@/delete_catalog_backup" - Write Bootstrap = "@working_dir@/BackupCatalog.bsr" -} - -# Standard Restore template, to be changed by Console program -Job { - Name = "RestoreFiles" - Type = Restore - Client=@hostname@-fd - FileSet="Full Set" - Storage = File - Messages = Standard - Pool = Default - Where = /tmp/bacula-restores -} - - -# List of files to be backed up -FileSet { - Name = "Full Set" - Include = signature=MD5 { - @&Q5aq02u}xAAopDWjggX78^uSkVpu>e>QrTK3BC=#8xtYT7-&xsC?8Jq3 z$ia~;y|+*McIEM2oJt+L1sk(5zzsSNGKUMERfOg8=dOFNkn5^sm@N#9Ccg;zJ5DR9#0aLb zFUmNV3L_<*XDlmWy@ONZ#1kts?*g%4N^@FpArc%bh8cHSiC&!f|ZH zrSF9p13MdoHY*T@%8M9@2}0V@7u+u4 zfVF>_skCRx(Hkl)dgf9K_`sJKDv?oD(_+}mD5|8YLUzg)s7fY`Mix%FbDAdE>_41b0HC=+s6ihd!(R9e8Z_r*st7C1dLRB&2=#5a+3HfH;En#L ziSD$v!7jLfwKz12(KZ{y^It-q2Hg>o n%Pr&9x>{GmMN0Q<`26&**Xwuf!j^51?cIsIX~XtYL`wbuH?A*8 diff --git a/regress/tests/backup-bacula-tape b/regress/tests/backup-bacula-tape deleted file mode 100755 index 4eedff42f82851aa76ba88dd139fcf28c6595fd0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2698 zcmeHJOK%e~5a#S(F-;;470IR%C+Mav3S26+Qd@CBD0RHEiK(+*Y;U&#@!uKmBfEL2 z5=iAj4$<14w`V?o-J@V8lfW)mmv!MLOMruw%TyuExOm7?&@s3L!Urxg#bK676+t8o z3a8BqND07c(sDdSFPVTrOJ@kuy@4Dd(zMMTxLgX7(13}}=-6)->Leq00zw;aRjq)h zDJD^4c0j?2JPPmAJi2FA7@0a72%WC_-fLgzB(}}ILY`!4al{ykg@#V=C+YtRis(Bq z4%{*gVyUpNq;<6rbSmlQBMd{hb=)|a%*fztEF74sKB z#rEa3-WQCql8B(0`v=?f?ns`bDp52vReuO`#$Pt(c8-32?>nM*SV zjfEvz%jamDAO9bgx=hUI72u*>j?a7XGg3Pz_W*}_<*+3+n?f{a1E3WE@EfNGp^>e{v zhX$71;~b?EV-8}$6OTPz=5!_&&<5kc8WGTQ5(UQtQDLI<*y{fXsSgN0Jw5$<*gOOg zn{}nj-MHYYT-80j{5@BX1N)v)8@4Zf{jM%hJWOM4ra$y@CUHtIxD9xl#oyB*b3-`Q zd3A?oDHHCbPTs*WaR|>St}i>#et&k_Yvw^V?47Z_R&J;>JiTa{DMn+*jH%5;GLE5d zD)O>tSlS)AV@AgC1$t+26v7bt8hS-|&9ZP)F2BP2f&wujMJ4edDzX0?j{I+zQ&c?5 z>dX*ZiaC*#$P1R@ZEJ@t?C22j@Y7VlM>`l)7F*GIIzx1)3ZP**n-N`KR&pDm98hh9 Ow_;fLTFKQ|EZJ}C{eIp6 diff --git a/regress/tests/backup-bacula-test b/regress/tests/backup-bacula-test deleted file mode 100755 index ecf1d3bef43c0272f2ab59df3358737139f806ef..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1872 zcmds2OK;mS4BlD4f_Y$v0g00yw>oXNu7?#^fG*f&7*apzM2l>Bl3XJl_TNX@s_i<# zknOO;d`KiwBtMcLsnNg-dFJUY8?h1G6&VDed72A^Fo6E*$Sd>!j$eJhQrgg_`4k%t5p|<|uZ1Hjq3oph8 zFDrzoFA#h!DKnD@Dh0Qn+OXjK{Qbx4_3~zYeYLt`m$EQPw$IgaHk&g=MfoN}|DE8NnK|sq27xq%CahACP5*`q{5NL;F^Bno z=c^33VQqy*z%ECS$r55o4dJ*=XZ_-x+2R4PC-#?HROpX?5dVLAw!k&1CQeQjLqVMb zfe>UmLuQNFb6zuteJ==7mr_k9Z86%d6RFmZG7UMdi5xvDJfpMB57@j>RK?+o6{?hH zf#EWH4X<2(EpLa=rRIThXvyb~FW6BlcWw@J%+yKhca(ZE6Z0g2iE^XmNYY$7>(SFU z!xQ)d;|m!0FoTJNaRsm4R&MI;S9nv+Dn>J_89B$-FtFdTk&^_}Yq1s9SB4#Hf1pK^ z$WW%L-X{ok6sJLN5jXx~_#i_tZ8_}}vjf6@9h`ru+5?M1qmBB&nyY;b3FS!BE0H9q z>WlXGcR)^4?Ey)6C;9XcI9#r__I055!_k`l>~yc5jpePAJuBV`*L(h(j&u(h;rRt$ CmQIxb diff --git a/regress/tests/bextract-test b/regress/tests/bextract-test deleted file mode 100755 index 8a55c19da0b787b0a5e02c18d7f7b0282db9c945..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1872 zcmbVNQE!_t5Z<$Y#WjicFpZFOZ(B**sO!V3wNhK{Wtvh0Ch=l0vrT9=?Z5AgNg&W} zQ;`w@zWeUGyYG(SkstER*DEq4L%1z6prCo03kD&L)dU|{sN5fsx1$sm$x zO0yX3uh7VYJsL$L1ebdoYoBnz^cZR~9M4`)kzdRHU$-9a&7rXi5YPnZVdmp-pg!C7ISu4DPY0U#fmiCe!~l zJSIgRQ^UY{9)iGU`iSr6TkKcxZc<%Dp%A~zFu3N+l@Z%Jih4TavqkbH<%Tq=41t^t zA(LgTF)NZ#t4b(%(#`d_%5|r@a>W!2YDw5?xDI&rxdzPyY96TQRwkAiBbn^7aWyAD z3gp;s#$KZ<7OfYFREwW74LMt2z8Ixl^g|`cyeEWojgtso4$t#;7`qYjLfC1pPHb!| zw9`-}I#0(=L=EU)@Ozw=isdkPbFi3si;w+L{?pT379dv#_UbE!sC z7AnFmL~%S~YvpX)P*1w|9AGxHtEy5X(s0zD;oH!xvF9{~Pcj74l-n*1Q)o1WHm4W5 zcGxkYnJrci?bdDY*sW#!LL>=O&d~n1it|F(4v~Z(^lZngZm8YExTSZW4!4{S8+UV6 V8y$4)DZj?D!(l(l^=Ab+{Q=60P)h&+ diff --git a/regress/tests/bscan-tape b/regress/tests/bscan-tape deleted file mode 100755 index 8858b6a8776e3b1bc18aee37705ee2387be32cab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3564 zcmd^CU2oeq6x}m_#f_crp_r^V>(f@b?T`g1iZwtJ>}42SN}_DelBkiCJ$KlD-ytR2 zQlvE4nzsfBAd~lAUf!>BI6VtvS%zlKrffXJAaSyZ{8m?xXMB9)O{3;KyCbsY=)*w^JT0WvbR>Wg*OWBzUr>owRF`WuiqP zO3U*`+UunXj>IP6aHvcPhH;#j`MtN6%v#m(LyJFaxI)}gF1WGu0Q&l>?m!6@7^NXRR+znkd1eEIYHtL4r0^6Jgqn}PmoRokkzbh3yFkOjAb{!nrB zUartE=1K z1b!QbjDq626)Kb=v%661cfAr&N_!c@i3(gqSI5_8Ev3>^rUC5E&5swYCD-LNmfpvZdNls#Vp}4R8{NHIDhD-13+k;iyFF zfQ-#TC%J3@aEV(!8_>sY=T&MkpX?0EjqxHe-F@g}3){x2b_K z+(A(|IP*MU25!`t@(e53Q48}F6ciW=wiLwF6F&~eKF9IcH}K-A>A?|@Pjuio8SjnR zOOMsBr^N8@lj@jc%OA1E+E3c8K@+1EhWu5Vo3;DEK9Pgu5(nP)klq&!8;_HfN*rS8UYEhlYhy z$BYm6z>GeaacrCd-98&eqTHnc12ZzC-{|}mokes(fui%+***RA$232Gryu?6!C`&V z10clX-*o2wx`Y_fac>)gX_$b-aI|3RL>j@aouTeP8l2f8PQDDg4u~8hZk&@h!RRqHRLBL;)G+0u z`0PV?Yk&%kfg~amJmZEX&X+wHmSaYyjSCG$sTQnC1~f;MOfa)siDj1IsvhD=<8>0= z73<`V=veW>=us?-O<-dMvCLCluM0-=vLGy8O6U!~q34g0D?$%uBa;=QlnWLJt_`V- zpx1c`!w_x^RfgvaUjdg305^8lzchl`TB>_=A7Pp5_{5TjrLxp$n*gS>=MzMhu+=Cp zh42P=CM}WDAO`19eGlzf;qdUy<=On|e13LvdqR$7X$mB@j)2r@x?p;@WlxPLCPOqO zf<{bWZmG~FJjY^8$Sv0KgCl)Bp8VEgO3EUkNR)R8Ti)=VKH&Q42Du4ej@?5P%Jj30 z!b`qb8nL;dsJ1qO4Z>YhR9OdneXip^IqpL)*OhXt$~^>JCrvfAAw9h{B`wMAxmiq4 z?@x){-@*M-BKRgRJE1OFd_Pa6ntzp9#MvARq4!ST5``=}n($&?IfmLGzc-6NMTuLk z-IX0iT6rGRk1CV=Q_2^L70`Qj%T&g5 zYPif_!3*r^w!>dt^c->9JKd!PTZ;(?N955c*S<#0Fs_)LFlrkn;b{tis)mUdjn~Mw zh|NaZiNjO)2!kUy2w@C?gh6Bj*Pkwr|NI26-Pj>Gp}gv`J3syo2li=p=W66>S*n;p zO0l;k*2Eh&<8*yH)-ao43o}k-2*97=&w$r>t30PPfp-#bTg|5J{-)Gu3Qc@}>ADA& z3C(QPI?*cX6R<;2<8MKl;`rV@jY9pU>mHDlx5(S#s+hIY6bG$qSAM>>8N9lvELzlc ToNBXXcKpZLwczTX0MYyeyQ=au diff --git a/regress/tests/bsr-opt-test b/regress/tests/bsr-opt-test deleted file mode 100755 index 7284cc1565d1aae0b419ca8732ec48d390816625..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2321 zcmbVN-*3|}5a!u`#jTxqK(yJ$8<4V10|^jJ8WTJqRGh?V&0IU!&O(Ry-#PzinluF_ ztg1@lyYqK<-*+A#BpH{9S&}gs!&NPTg5j%5Fvw_rQ&*r$uuBH#G_M7PtmdMCf@_vr zrPugw0UZHMCAjsLROd^6%YaL(z%~kQm8e(DJa)ShG&AVQyi>^qGoU2?#2WwD=CtSn zR2IObsWn4qYQ2*~qwr71z`zYiWuZ2#m;$_>vMFRngQ_fF@jGg{lHRdV`o>H#(Yz_r zuT@igB_`LrvL?w@wVqf+Hp!JN&Gx%sRMr(?`BK5?@F#lyN_-7QFiY&JN?ZyP!Hp%+ z2u6d4G)>`yrP^}2aL^_Q&7TH zo5)&-V1RiUg;W9wLcZ6SMz>!r ziI*(DnU_k>@6;;eY>p*CINiSV$)c(OSKJi1UZSF$7&gk%j0)7JW`fg9pu9ez7NKF# zP>GsXu7KPGajH%JLv4q4#xcNys$DUosxf3c27;+OABAU_bgErwRza6gC$JGjto_u< ze!zaCQ5H5md=Vmy9$YiM;?mEBr|<{|n;UbNZ%5E&^`1C?i*gmFS~rZR%^*w*rr>1> z6CEaMO9SvAb||%%FoVdvgwJsJ0uE9*f{B7dtcJ_H`=R&R+5G~~{B$Nb$-}I}F}D91 z4&3UGF|45tglxHc)`b%^(7@4D>s?DDOH%_E}U0M60v diff --git a/regress/tests/btape-fill-full-tape b/regress/tests/btape-fill-full-tape deleted file mode 100755 index a2d5b5a281..0000000000 --- a/regress/tests/btape-fill-full-tape +++ /dev/null @@ -1,34 +0,0 @@ -#!/bin/sh -# -# Test the fill command in btape -# -cwd=`pwd` -scripts/copy-tape-confs -scripts/cleanup-tape - -echo " " -echo " " -echo " === Starting btape fill test ===" -echo " === Starting btape fill test ===" >>working/log -echo " " - -bin/btape -c bin/bacula-sd.conf DDS-4 <&1 >tmp/log1.out -fill -s - -quit -END_OF_DATA - - -grep "^The last block on the tape matches\. Test succeeded\." tmp/log1.out 2>&1 >/dev/null -if [ $? != 0 ] ; then - echo " " - echo " " - echo " !!!!! btape fill test failed!!! !!!!! " - echo " !!!!! btape fill test failed!!! !!!!! " >>test.out - echo " " -else - echo " ===== btape fill test OK ===== " - echo " ===== btape fill test OK ===== " >>test.out -# scripts/cleanup -fi diff --git a/regress/tests/btape-fill-tape b/regress/tests/btape-fill-tape deleted file mode 100755 index e32df1e394..0000000000 --- a/regress/tests/btape-fill-tape +++ /dev/null @@ -1,39 +0,0 @@ -#!/bin/sh -# -# Test the fill command in btape -# -cwd=`pwd` -scripts/copy-tape-confs -scripts/cleanup-tape - -echo "${cwd}/build" >/tmp/file-list - -cp ${cwd}/bin/bacula-sd.conf ${cwd}/tmp/1 -sed "s%# MaximumVolumeSize% MaximumVolumeSize%" ${cwd}/tmp/1 >${cwd}/bin/bacula-sd.conf - -echo " " -echo " " -echo " === Starting btape fill test ===" -echo " === Starting btape fill test ===" >>working/log -echo " " -exit -bin/btape -c bin/bacula-sd.conf DDS-4 <&1 >tmp/log1.out -fill -s - -quit -END_OF_DATA - - -grep "^The last block on the tape matches\. Test succeeded\." tmp/log1.out 2>&1 >/dev/null -if [ $? != 0 ] ; then - echo " " - echo " " - echo " !!!!! btape fill test failed!!! !!!!! " - echo " !!!!! btape fill test failed!!! !!!!! " >>test.out - echo " " -else - echo " ===== btape fill test OK ===== " - echo " ===== btape fill test OK ===== " >>test.out -# scripts/cleanup -fi diff --git a/regress/tests/compressed-test b/regress/tests/compressed-test deleted file mode 100755 index 6bd5d415b1c23964ae91026cf2ec6feae286d858..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1693 zcmbVMOK;Oa5aztUVwyx8D!FcZggSjtdY}@OO2q}CbZw85C2OzQN23(+-lgE0MKQfbPQCkyds$NHyjG|0c zh3U>E^2*f=vxS1uPRiDR9%mE@8)eWqg#D3!G@PA% z{CqvTyO~{IK3uX3Ka|0<-0; zPmrrmyr_f0c1 zYU;Khsnzzc;lTd}trjMTQBG$F1*dY%yTU3bW$H0bpkpoJR9!Ou2BqqZnew}$@PQ|pzkJ46bxmBtrd iA;*3|()`>Vo7=g(yA5VrN!;(*+3xVzbZ8j*#On{{&<}6` diff --git a/regress/tests/concurrent-jobs-test b/regress/tests/concurrent-jobs-test deleted file mode 100755 index dcd03a39360d0917931a3860508f7ef824b63d47..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2437 zcmcguO>f&U4Bc73f=!AY3golv4qKgmZ9S~m3UtLT!;mUAooKNwPm&vS!~Xjy*@+d$ zD1siAOD&1ydlLD`b`J(Kkqz{Mby*kgiVVz3!cRHVzzvuMg61iL5h;>IxQc>@d=)(~ z9V(F-_|IR^$xBg@n%GAM*S=FljzWxSC@u670alZP@Q#BD7&5 z1{(=_Aq*mX92AOYkxb#e<&hD+D}~%3oV@*f3Dyl(!YrV&in!qn07^t>DzZ87XUw7B z?{}==~)dqWdM-L#&1t^m`qku zEh*+8k@Fgq)l~x8qQZFcdPGvPg2{>`DGi8+mLw38l5?omeJfHpJ^lFQ!}Rug`r+dK zf}P94OKj8DYN)V(O=A({vXYE~l|n z)88_k37ooq?Wcro*NMz`%4DuEht8{eRH?|g5i)xRN0&TY7CGGBbimK~j`NI4&jg2O ztToDA`G$TN_jo&D)H+NgV(R_=bO5((JgV2GYKb=MpQgxnI6Q-c0EW<$aOlX^O9xsm zf2>E#W^9nG+rQz!{@V3TuSRVhv@BGJ5Ob15WQ|J~KjL#ycKoOX*m3B}j!2dF+V3*; z9V*029>FI$qxrf?w{0J$&}0fe(-*on$gU^iPPD2vA~(M^*uf*b5bc@2V!SqTFrt<1V{18y>-tawHIO>J1i@M&M_$&HsFIXbC&+)#kfK)F z4(nmUKHG=4Z4EhCSv3lw$oYNSfG)u;5zceosvL?| zDgi#9 zhmk009joqX1F(r>yn&<{UI)|E8lDnXq=$1p%&Z(UE++4uSUoKzU!svlAJ5&tj)I9> z?nBuf@@RAtjn=JJ3$wT?%(fn~EQ3E?Zk(*|K#XY*2?Uy5nS31yXJ?%@_v9&6`fgl` zdF~KTJTt6c3r@~n98FIBOTr93H7Z-1C-murY zbxrGF^iZL-`5oHTl+Qm!aXcp|Q+a`k*4BnF*(H@29<*vJ%x;J$e}%`RqvL1dPMDz+ z@V73qUv8-ciy+ z9TYyG$|lr(US%SM{-@&nC|UNz>=PpEv4uX1s#G9Gzgl;F4~`9p-ff<#lW?Ynp4?I2 z!fZ;faMF`FzfS7Vx3kj;I>P!sw|#(yGX0l>wAOxfv(3^p+P=>|)c6Q{|twu zWM0>wtI zQgm$8(x4cD;iAWY- zYBW92|4-8Ojiwuclya?*LtL@S{?0&mib+4-Rn6>test.out - echo " " - exit 1 -fi -cwd=`pwd` -scripts/copy-test-confs -scripts/cleanup -echo "/dev" >/tmp/file-list - -echo " " -echo " " -echo " === Starting dev-test-root test ===" -echo " " -echo " === Note, this test can fail for trivial ===" -echo " === reasons on non-Linux systems. ===" -echo " " -echo " " - -bin/bacula start 2>&1 >/dev/null -bin/bconsole -c bin/bconsole.conf <&1 >/dev/null -cd / -${cwd}/bin/testls -e ${cwd}/scripts/exclude-etc-test dev >${cwd}/tmp/original -cd ${cwd}/tmp/bacula-restores -${cwd}/bin/testls -e ${cwd}/scripts/exclude-etc-test dev >${cwd}/tmp/restored -cd ${cwd}/tmp -# -# Use sed to cut out parts that *always* change -# -cat >sed.scr <1 -sed -f sed.scr 1 | sort >original -# -mv -f restored 1 -sed -f sed.scr 1 | sort >restored -rm -f sed.scr -# -cd ${cwd} -diff tmp/original tmp/restored 2>&1 1>/dev/null -if [ $? != 0 ] ; then - echo " " - echo " " - echo " ===== !!!! dev-test-root failed !!!! ===== " - echo " ===== !!!! dev-test-root failed !!!! ===== " >>test.out - echo " " -else - echo " ===== dev-test-root OK ===== " - echo " ===== dev-test-root OK ===== " >>test.out - scripts/cleanup -fi diff --git a/regress/tests/etc-test-root b/regress/tests/etc-test-root deleted file mode 100755 index 859745edf3..0000000000 --- a/regress/tests/etc-test-root +++ /dev/null @@ -1,70 +0,0 @@ -#!/bin/sh -# -# Run a simple backup of the Bacula build directory -# then restore it. -# -MUID=`/usr/bin/id -u` -if [ $MUID != 0 ] ; then - echo " " - echo "You must be root to run this test." - echo " ===== !!!! etc-test-root not run !!!! ===== " - echo " ===== !!!! etc-test-root not run !!!! ===== " >>test.out - echo " " - exit 1 -fi -echo " " -echo " " -echo " === Starting /etc save/restore test ===" -echo " " -echo " " -cwd=`pwd` -scripts/copy-test-confs -scripts/cleanup -echo "/etc" >/tmp/file-list - -bin/bacula start 2>&1 >/dev/null -bin/bconsole -c bin/bconsole.conf <&1 >/dev/null -cd / -${cwd}/bin/testls -e ${cwd}/scripts/exclude-etc-test etc >${cwd}/tmp/1 -cd ${cwd}/tmp/bacula-restores -${cwd}/bin/testls -e ${cwd}/scripts/exclude-etc-test etc >${cwd}/tmp/2 -sort <${cwd}/tmp/1 >${cwd}/tmp/original -sort <${cwd}/tmp/2 >${cwd}/tmp/restored -rm -f ${cwd}/tmp/1 ${cwd}/tmp/2 -cd ${cwd} -diff tmp/original tmp/restored 2>&1 1>/dev/null -if [ $? != 0 ] ; then - echo " " - echo " " - echo " ===== !!!! etc-test-root failed !!!! ===== " - echo " ===== !!!! etc-test-root failed !!!! ===== " >>test.out - echo " " -else - echo " ===== etc-test-root OK ===== " - echo " ===== etc-test-root OK ===== " >>test.out - scripts/cleanup -fi diff --git a/regress/tests/fixed-block-size-tape b/regress/tests/fixed-block-size-tape deleted file mode 100755 index 23fe49a390bee16f545de3b6d5c5da04a163a55b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1808 zcmb7FO>^2X5basNV);l9nQ;tEPi>s9p}Az5%!EuYoeq)hHK@pzE6E`w)BoO;ZNLVS zX*qzAcHcg&_C5DHekd~E%vq21;J(O!gAr*i5keje$)bx#D(3WYb$V6JCz_S=q{#-tXQbmh0(TEo`CsaCG#=&F0j31ea zw8*XTBbBc_hv`KsOU!m%BF~Dv++rBb6?FTrl>WyrsdeGZw`uMtLZT;yv5ZAItRv{8 zbSgTBXW|owyWVjr!y3*U_264g^~zC&3DG=)LyJ_d#&!s!CPIDiHp2cQA+#Y3#^AMx zjan=>72UnHPs2n4KcIgOod5>#6TY}B$Qa#F)hOs5e(unRZY+jet59MJB7M!fpJw~boOybvlHW!pA}M80W=~;krccL%7prVH9DuKUvJ0LyX)!r^5K$Q zsKVxjg)Ksg#_$=M&6XPxVlh0SP$qeZl4>hWF~N8|@jk(ml0}Na19kd)`8XI1!ANC; z0n;SSUn&f4#cXcnYQmooRs_D}!m@3t9pfSqz zVAcDErbCkA+k9D(rCcxInAJbA%8(r(RkeowE{JNgXB(~0Fh+Adw`orbO*skGDG*=xzzQ_wHzRjPJ>%QF8fa;U`nhPJ3t&fbkGbcB#_ zvd`GLLMix`Z@de$mq-G1#!(Ji(}z$RY?u*{p2+|Xn@*eC-Ax_bw4rzNw;4?~^y1pg KU-eFL2KE=p%sV;& diff --git a/regress/tests/four-concurrent-jobs-tape b/regress/tests/four-concurrent-jobs-tape deleted file mode 100755 index 17f9d350f98c6ece0af962e26f89ff7399eea05f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1578 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 diff --git a/regress/tests/lib-tape-root b/regress/tests/lib-tape-root deleted file mode 100755 index 8701602d4e..0000000000 --- a/regress/tests/lib-tape-root +++ /dev/null @@ -1,67 +0,0 @@ -#!/bin/sh -# -# Run a simple backup of the /lib directory -# then restore it. -# -cwd=`pwd` -bin/bacula stop 2>&1 >/dev/null -cd bin -./drop_bacula_tables >/dev/null 2>&1 -./make_bacula_tables >/dev/null 2>&1 -./grant_bacula_privileges 2>&1 >/dev/null -cd .. - -scripts/copy-tape-confs -scripts/cleanup-tape -echo "/lib" >/tmp/file-list -echo " " -echo " " -echo " === Starting lib-tape-root test ===" -echo " " -echo " " -bin/bacula start 2>&1 >/dev/null -bin/bconsole -c bin/bconsole.conf <&1 >/dev/null -cd / -${cwd}/bin/testls -e ${cwd}/scripts/exclude-usr-test lib >${cwd}/tmp/original -cd ${cwd}/tmp/bacula-restores -${cwd}/bin/testls -e ${cwd}/scripts/exclude-usr-test lib >${cwd}/tmp/restored -cd ${cwd}/tmp -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% original >1 -sort <1 >original -# -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% restored >1 -sort <1 >restored -rm -f 1 -# -cd ${cwd} -diff tmp/original tmp/restored 2>&1 1>/dev/nul -if [ $? != 0 ] ; then - echo " " - echo " " - echo " ===== lib-tape-root failed!!! ===== " - echo " ===== lib-tape-root failed!!! ===== " >>test.out - echo " " -else - echo " ===== lib-tape-root OK ===== " - echo " ===== lib-tape-root OK ===== " >>test.out - scripts/cleanup -fi diff --git a/regress/tests/lib-test-root b/regress/tests/lib-test-root deleted file mode 100755 index 7efeb34779..0000000000 --- a/regress/tests/lib-test-root +++ /dev/null @@ -1,76 +0,0 @@ -#!/bin/sh -# -# Run a simple backup of the Bacula build directory -# then restore it. -# -MUID=`/usr/bin/id -u` -if [ $MUID != 0 ] ; then - echo " " - echo "You must be root to run this test." - echo " ===== !!!! lib-test-root not run !!!! ===== " - echo " ===== !!!! lib-test-root not run !!!! ===== " >>test.out - echo " " - exit 1 -fi -cwd=`pwd` -scripts/copy-test-confs -scripts/cleanup -echo "/lib" >/tmp/file-list - -echo " " -echo " " -echo " === Starting /lib save/restore test ===" -echo " " -echo " " - -bin/bacula start 2>&1 >/dev/null -bin/bconsole -c bin/bconsole.conf <&1 >/dev/null -cd / -${cwd}/bin/testls -e ${cwd}/scripts/exclude-lib-test lib >${cwd}/tmp/original -cd ${cwd}/tmp/bacula-restores -${cwd}/bin/testls -e ${cwd}/scripts/exclude-lib-test lib >${cwd}/tmp/restored -cd ${cwd}/tmp -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% original >1 -sort <1 >original -# -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% restored >1 -sort <1 >restored -rm -f 1 -# -cd ${cwd} -diff tmp/original tmp/restored 2>&1 1>/dev/nul -if [ $? != 0 ] ; then - echo " " - echo " " - echo " ===== !!!! lib-test-root failed !!!! ===== " - echo " ===== !!!! lib-test-root failed !!!! ===== " >>test.out - echo " " -else - echo " ===== lib-test-root OK ===== " - echo " ===== lib-test-root OK ===== " >>test.out - scripts/cleanup -fi diff --git a/regress/tests/query-test b/regress/tests/query-test deleted file mode 100755 index 4c6523b449e51b7bee3c98d3b82ca7d853060356..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2937 zcmd5;OK;;g5bl}3Vqyn9EGjGZ9{P&1FK-TAU;}K^UW&piQKOg*C2C13+O+6@?~s%% z$;uYNwgqa~2}OPL;LPxwS)Rn1sA98cOSXh}O$8|!QPvV6OZjb6gDSx85niUektt-2 zkU8W+BezQ5yH^!(jj2U2szew*qz|CN778KJd>Rt2>y@|(AL^1g2K_snoDYHMPy>iftNKH{n>%&;#p zt(ux4-z!+0{y~y|#aY*u5(z*kZbLX4BgjtbB8@^DUd= z*Jo^tMcPQ)JJf4hZ~C35Bu&R~zbYIh?fZp0NKYIcJ8V2V^!=nI*2QFe2+vtj_kMak zeb-6ON9YMl mh=7=pyq`OS5(D#1Gkf)77Xz44Y1XT_FJP!^1qYYT< z=emT5hK{~1yOzpwQ4|pAVK=O%nHps!%qhnWM-=c2oIZn-1kNB*aOw{~Jo-a~$6w)l z=UByPhzY%yTIa)SIB}nG>+FUlqZ&tjMM|9~caQ)a>zT{W(9~buDC29E90+H4oa2MP zot>9y4nL?2>`*GMHxsiG6vqC2rs$EgC=I%(&9rrO<)%9t4r!n)3e*AU{*D6mnW9II q6k?LR-mfmRZq}hG$TLwGex@0`deb2$shbH6up{e-_TSB)f&U4Bc73f=z-QisiGntxiAC^{@gh&=$K4Ln_;JqD8ShNluy#`|qP{C61Gz zYYPn60yMSa$482fBGo+Th9d2n32U+@+~z58Fk+TTgpfzmJOh=0ogkd^D3=_D@OKmTu`;qs7z;m3C-z(IO5WvPJyBOr%9- zO*c~6vTez>9jP=i)$bB{nr957iGoJ!Ct3dL7W;0%uxn>oHxUxsQW(oT2pT&NK@h;5 z<=VOp_-z&50O-{k{|6Wh7fMfwqAS(7^1+;Dq>od?I43X|zU@MR|2QOhAY?R!StVb_lJ*u<1 zD)ZSkOw;kC0uQdmcw*)9j?ZyR7m0I}K|&P(OOkHEg=LkH{{z>lk%$@ed;ijISEs`r zemaQ#4xJYE*Q7aZ0;9iFEnM^D)IHqcL;7ufOno4OA`t%`78BGM_=e>WWrt|{_XZ3~ zYTNaaVR<^^dJ2ck|BF?MY`1uP3fT9YN@}xntlQ}Xqv72*#Nrhl5Mcu%% zxgjWQM)*q8tzc0abeY>>^YX{wX1AdWOp>53f$n=FRj)MN3M3IV0atN(b=?(!?gzDN aL0!e0E03wkx5umkZbh&@m;O3K5&Z_I_dw|Y diff --git a/regress/tests/restore-by-file-tape b/regress/tests/restore-by-file-tape deleted file mode 100755 index 45ff1755f31c727c4fb01a6ceb5d619afb70f9f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3179 zcmeHJOK;pZ5bl}3V!V$Yf@s%k1SybMo1}1k31S1W(H`1nO-Z8_Ye`f{YL!jV|DGX5 z?P?!|;Q&6hI!WZb_{}#TH9VO{qMYiC4cQPr)+KPzqNs9&h{yMJ1u_MbA^gnaI_D78 zB2OR@3S%SH8psL2Nb)kgLTEBn=E~kRxY4H_7XwYb^$LvGvn_&qGHAO>; zl41kaT0^R20m4iGuB5@|5Us7J5#@3xz6-LA?*cz3KTvh4VTDwq&Sf)!TUQ#lSt3~* zc=^I7G8s26irtG9a)WfjTG>p<oNqV_B^O3qugg zGS%Dl9C=w+Zi``@Nf?a&Cij1)4$T3~r>3Z;_7FiXv|*YG(BnToja#!Zc=Ik%YOP@I zSFNuH@T~P`an-rl=29c6b%9PMwyti+y3JgwfgTUxgYVa+ZPg96Y79r#20PxH5)QL4 ze^3}4yo6y0H-;?05aS7KEeg&^G2$BYTh)L%WZPDtr4`%4rlWp zX9RtMt7%#1d22ujX-NnKF*pbR-6D5>{>#A zfisDWC6}9`z4G>Hw68MO{0m)AGlsdw-r?X<5EAaPp^IiSd)My?0_v?QAW%Evy+;-| z8CTuxYb51Lx;xwsh>zGY{RxHcJA~^=bc_AO{#~Z14^Q&2N9f;UbnhWv{VzViitUlQr=-B7#z_q7W44gRC=MF0Q* diff --git a/regress/tests/restore-by-file-test b/regress/tests/restore-by-file-test deleted file mode 100755 index 5d1762c1381879a88593ddb9675a11612cfae9b1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1869 zcmbVNOK;mS4BlD4f=$vL3fOLX8L-vqW8DrbumWAN%O0sM%ZV1*@+7%IHtfHTlAp1Q zqG%3*Eqx?E@+0Z#K@jsi&}%X!Q@Aa2h(PnK5DemoZps2=3TDmVGNPr3ATGH`AmNHp zBh?N{&GVH5P?;5qY0VOlh2b(se_(HNz+(h6;Ks)=ben|t#WuMonkrrx9Z*^9JcA&Q z$~@KGxnNOV7KG8YgvsnLTK)@6Rs@d41QzZk<$`&FYeTXP5`!U*&;q=oId-OjRy06t z5*+!oxoI5}nvBnchK273b9?Fg#HOhazyCZOMhgyM4vRYDik8a2OTk%IXi{eclhH#M zhVaEi%Gk0tUgDkSlC&iPM6_nlL&IXRm1=_?10h#kNMe;om94JY#)Ol_Ya|~e>>k8u8kidx}&~)Z@%@hm!TDr1$^}XKXNZyds9<))(wIF$fQ&kl5yF{k_YPIdZ zW^}VmrCR=xS^+{sH<+ElK?uj-NtijB z-Kz^%z5alAZqX22IMuGe$$I=54(zY#3vX|->J_JDsVIXq!gfq7xH9Q`e9Ftn4#&?9 zuIo1>Rps@(WV#&ch?h|UpJWWC6WWfhDK$c&&-8_+1F}qLW-B@JR(C}Lb}?!EAfzc% x70~|oO7=q20g;sN3EJ?g)wW9!7iTkxPpEoxU1Rs;e8Rjl7%*z5xBf^W!~cpbNY4NO diff --git a/regress/tests/restore-disk-seek-test b/regress/tests/restore-disk-seek-test deleted file mode 100755 index c9dba179001b928760e13778763c12ca1b1eb15a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2754 zcmbVO-*4MC5Z*KYii;f&tr1CaUk0p^+q6v|R|k;%xEOyOfy0EIP8wp9r#1)Fh5D=FPlC2^+`k^vK% zCsyhG1uj^qh0UBL`UAYDe~Y}z;jNGyK8dd!47VZNWxN2U5L|PEuH2zhNO=t@S{kql zwj$YrC_D@kW{aMDD~b&~DU^jhx4;X!mYhAk09r77GZg~aj9Q;)i_98C50g`yWFg$_ zFuKiDwaGB~0kSY~f_;H@xQagt8>JXn%=f~BxtOX*I0) zUXuovVHhn4ZiXQ-oPnAB{^#t}Ihw%&mTk$JgH7Su6%wf}l_+eNncoED%u-QcqhL#V z9hG zZhYT%v*AX=O@<@9rNxb4Gh%^Zq3e%s$2G#j(>O7+X$R4d*X*8=n@x_qVfkPb(smt8 zMh|fu!zW9%braat$qi57#?m)3pv}SYTkT=Ftd(|i9Z9w6!;+o@FfJ|xJNJ9G{1F=^ zVtf}Bs6>q!GGr7AOpt(gYu_8@uC8uAyjk78UA?)!yCyGHWlL149wFz(&kfnk1?e3pkx_OwyRX>)mN3T1z#Z#ClQZ|smf6mn{mXe z0q+^=hg&PzUo392y<*i)+;O_+2Gv`#dDn^E&<>8}6{}UjVgEPl|6ANPnwK#7;g0KE z6x0e;{0#F~&CPiGZUV!m869tp9c<(C7vx@)kJu>g3LL=r(vM(t2g5{~qU!sg{yfdo zam`P;7{Q4YeuMKDa2CTQ1Pac5n*FN}*S!7#&z;g11h4ewVnT_y{~6BQUsssmL?Vze z_u*hvrSaxWDb5pf=8e-3^KqP!C+dj1O#R4UV$IpU?LhrG+L*5>b3=yr_o3KMgKTBc z6o$Eer|U_wTpI4!9HF(H(SE|wSv9X;V3MjIDY$7LV(_9KPKpOPYhb>W*&4w0Ll8WFK{rB!t56h7e zR40m@on6lCa(ogdG7s&BjoBFP%N$~`a$6_?Nz5P10(1s$Bj8=kOBF*>N|iz?jo?n3 z9h6q)YY*UhTNq)jNI@4)>KyriPIAC)1Pi3jLj&HF!FEcYZ}2KblV~%(m+Y;7*%3Vzx_C^VW-f* z+Z-98VA1SSY*XjFj&G8{Xt0Q)2tK>mIJ$cml>`Ire zC>`t>wrE_u7PdPgIk1Y^8A6$g6QMA-Hi(ICQDJz}s@#g`0q^?7FQ?NPGuS>qbrQYr zT7k}ChrCrR9ouIa1G^eSt}942wnd{M?maJH?h9xesM-i4qMl>5EJ1T_4{IbhqKh87 zv!k+N!C*sl_c?F-hn4BrU;xXiR!{?^+>iY4CmFzKOLx)^x1Hll#hs|R7WGLLCa z-ohIkE*iDFk0a;{KL}3He-}+I*-@5z6r0AZN8{xi(3qAc^@}OP8-WCw!-~hQos+>t ztj@_TU^v#P%rcnBKJ=Lt6G=Fk!B?1E!bt>E_zvg(J)i^p>f|%}%Op#6E?5os2X#oG zVd5{n|MkTW3F{XDhZX6Ltl@;dw$bLn!LXwIezMjqeVdfkxYv79eVF+)LXU+s7fyE7619kSQ$<=A#c`Ud|qj9yDb|Pbhk=@JZ{& b;{|co;p9~2IB+Ri|S3oxl{$%%*~89ka7hX2k=c4Ozk zz%&QPlJ@cG+i%zXUXlr!m>KDlKD^bOS`HMBhF9lMh?2un*coUlnOZ>hXt{~uoaS>7 z7F-2Z!4Z5`rCV@={s5fjGsu-RR#PE4^A;l?%o!o4U}qTJS+$^6@X0gzNK@JJy_laxLzwz#p_$>KML3FL2fT5Mhc?`GS(ac3vaTb4-QLueLs6$c+ zk}p|$S1s8cF}W6%HA$|j$AQmA2Z*^a?Lo<@bQP%+?fpX6--%sRNlEpTdtxFOhYkNe zD21^teTPT8$Ya#fCSIV~-N}Gk z4v}`rSP6T^^ZBGudh$~(GQlT!W6ao1wN?mK!B!!rnpY6LxaE2wB=)P4uVLT!KKA|1 zWdvPTx12L9u1)t&$j&Gq8;&|*0(o0u^ivon3Y-hw286KOAa!SBY$^;V%oo@@fnEwj z7%12aVB2L#S}(uB=Fq{8Sq-4Icj)=wddDDJLFmfqoI^oTVayxVrrk)pytnMJsr;}C zGD8scJ^l}Ti@C{kP8obq8P3{Od3{4#XV4V72%qV?0hX7Bd*-&HHCkZdb7R04n(Nxo zKRZ-C({%#~ehAt?IL;be^`s9o4hP`c+*_~W&844%XtP$ndTY(CHQYe3YSQK-gNXhB Dxi?i3 diff --git a/regress/tests/small-file-size-tape b/regress/tests/small-file-size-tape deleted file mode 100755 index 9b7fa3faa2fd1755c0f445f679183feb583c5bdd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1559 zcma)6O>^2X5basNVq-`TnQ;tEPi;(+4$UQ#WF};K>2!!}uR%q&TuFwKPXBvXw!tRQ zOu1l5`*z=cz1~R>i99e1)?+<*EOX#sL{>z=iUqFqXvyYz-(w%7*y+COLP0 zw=WJcWCj!P%xMqq8qzn8@09qS!jU^~4-MmgM%nTNuOZxigkcC%%e58x9HtqU5_Uns zqOm|0JJ|nO!+5+_dPyDwspf4+<~m&G55~oW(fIw4>XqOs$V(|}1FDNrl(!#41!&H7 zy)G`k+)ri?H?zt0(>1$Nr7cPet%nSa;d3;*Cs$cwF+3+zCV7OCVk=EH;bb!PKfp@K zGQ;qRa{XF;4hBOoQrU1o4Y3JE$I`Y~Je`4x6UBG@8+A-rWF8n*LXu$~@zG31_VNOH_{R z2&uYq>}N?-yCvPt{{rLXELD2;qOwTfj1r}g-O}y%Qxym8oNFw=d-sGo6FIj+tG1-W-4<8W9`zFWFHqk985dZmQ}XxY1iTiAYoMb)y_d>bYH?N?Be{rbyu% z^e^EggaP;p`W3zQScR#N-{F%}o}7^))%rl|cKjPo-0%3_QJtL78CB{SA>||mi8HPt zU5{^hIl$3!y0xw*txF1}!46Be_D&j(DZ)Ophug+>kJ20P7SQEF`n?;yT4Gr$*k5)k B^VI+V diff --git a/regress/tests/span-vol-test b/regress/tests/span-vol-test deleted file mode 100755 index 2b68dc0d9caa7ab6486af77275655b0b21c0b6a2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2052 zcmbVN-*3|}5a!u`#jUM)m`KxgJi*fa&_IHTP1+`25bB)7X-r)^*v?8p{O_EdtV!Am z%JR_0@ppHh@4Gwq55kzs(Bz~~`fyuHpkVl-5Da3P%*z5)1~zAKL6cHYh)XU~NV#T- zReFVM3up*n3c;;MQk~@dkpY)hL8eL#k4lsaW?q3^D(7#R^CSnVnYXmcQXy85l|l^R z!;lSOLFWuisTn$?7Gk5pFo7WrAQUVun5n{YnTRswa)wA{n0K;5GE_>I4)IXQGL0UJ zW%@u&qIqFWn5beESY~XHD4Ch&yI@q71z}09pf~u1mcK)P-X2UsyC}kp3l<1&EU7`z z+j@zj2<|M^)^Tz?0zADB2Y`EPgMZ;*vQ&DGPC}t(O%&qPLS>v5#)X0Lh;i_7*0;!U0+Ub-cK*j@6XAZDs6!(HXcwaLubsax7^v0#nBL< zM9`QCjIA_cqW74RqgvqT9+UdnYdsnr?F$_53q0Nz_?nbON-cwmOP3aWqCfEa#R@AR zIv)AwFZl6);*WRYHTKmv6-U>6mRqs9qu3tZ46ZQUOUg05SYA&JLmDOeK+gIg)e=&L zEvhlo3j61*zbVq#i&XDpr!mcICN&S~9$;g^vL#nDA z^1Vdf?UGt|TF#RBG*f!|Q!Qf7rkDc^*)E-KJ*#4?oM)O9(0g&u^ny!jxsq?-5QmW) zO*dCPXxHYJaf~fuqroZJ>E*UcV%v?+-j*BvTBkRvX-DZY+Y*PN<4vLAb5Jpd~{D;l`9ATjt4wUgi(XW=3dd<4oyQR8`pS zULvo&W|++t3`T#+^Iu$NAHXDbrH%_BF_OYM7AhdL0UssPa6EZ`L`FG2#+8?nwLxI8 z^N=J7+&OMssKVA25ROt4YKwV|3&>{e_*#3IOqR+lC~7R#tV_EImGbUjt!p7FtRe}b z4EpDBpa@P*zI?l!-ds&D&+pIKnetA12VJ!#Vdpcn>sNs+LUA-EQzm(eGSFnmCb=RG z;ZaFnVscL+e6Jr55099kR`{jTq>=UWnv-A!D~i74!m%#b5ZKueDz$`MQ4h7U)7>_V z;{b!YgFSV|a*hU*R^foPkuqxETd*jp+kne0+_|cd?SaxT!hU-K*r#gUa&ycU(?Xf) zA62FTr&K3p=~J?))1H=^8PqU%caNqN6%Q@{5kAn2go(Mi9zdV-U5%~dE*YJ&y-{x4 ziRp!DINNS(^Asi*MFEj%hjR~w{qfmBBMSHdqfn+&1g)P{L5Z=CuuUyifmNrM-bN!{uMtf}pF1$A|_IWKq) zUsVdO6Pdb%J8#Jp`dHuSx&;=c#lYrHw6-I12rJLh_ALrDjbZrjk@iN{Eg*&15cLUH jt9V$5v^JmFmYd4nT({O6lD-(AbJ;?*9^dxMKq&tM4r3bx diff --git a/regress/tests/sparse-test b/regress/tests/sparse-test deleted file mode 100755 index 33ee35f7385b7386a9880487b5e6823a5314456e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1627 zcmbVMO;6iE5bb$?#gIfjAUOt(Ee;=|9EwyVK)qB|Sli=do3+>74c zzk)NOS~P&inrnlgYAaMlxxjy|K%*fbg0NF6k*)LOxnAeb%w$^B*2I~rUn5JPC{tBo zy6+Nsqe9c#UFVJj{{I!Y2>6D;M@)RZ2R+=!$EvW%7O1cu0CzA7P z^LTP{$~2k!L#0V;kUxW0%DLvkvaZ4y*yR{1wT4_#4+Puj+kWx0rufFz^%6BE!5&Yq zl_U!11`JASl^vSQRVCLeIA-Brt}0{)IJJVXpN^RJmD={s60_C3POE0LRqqzV+|#M$ngh5S)_pHkn+ogIOLz>-W+$;tkU1 zO`2R31w=Yb*#SBGb1+CF3it+-3ph&P1R@2KhFVKh94pW(>= z?F>)Y1x7iYArzciFZY-h*-vyJcmSsf^Yh=d6;Wt!@qg4i#-Y$P&*8I5!FG1~>9o!e z6#4|;7`jImr9rRTAY1T02fw8ZEzF`o-2(k@PpLPC?hz@(j(rtest.out -rm -f bin/working/* diff --git a/regress/tests/two-jobs-test b/regress/tests/two-jobs-test deleted file mode 100755 index 9ae89ea5a23d1a5567444e4b052aecd5be467fe4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2338 zcmb_eS#Q%o5axM*#Waa{sFb>?#0%8vLFofXR4NrO2&HR#oGe*;%^tA=;=eO%JBMov zN@=7dyWTmz`Q}&;4}wVKfmyI28^W#2frAlQArT@TFI@pD1-n4F3G2%jw1wu+=w<8LZ5l{)}B+baA`4yMym=_OeSq?+&CFi$X%>FG1x51dS2P6%Lv zs~~q$)&dloQAGPVhDxE?ANi2s^z_}wtJ%%HCalou{@dEZMEigI`s2`Hx@F=dD$iv%~IvJ*i`w4waf*+B<7IXcKur4F# zLtymHRY?I+JFZZ3xoJNGRsrV5Q74uNaot@Ip)HZR*mFe6Jteeh-*SN(!-gFXu&(-X zb50DSq`3jq^KG&{xjVGaY;Hql!`MkxYyaw_)n6{pxL(2`YyR5sx8>J3X8%!!?b)G< z&ghtHEMV~B4s}Me)Q{cQaM%>>&4&T(mq|xCqH$!y(HZNta!XC;hw`48io1>(y)l!B zG=;HlE{UE3*l(PU8Ii&l7@fgE2*)s1Fsk6~ww0TD`xV|)Hw&X1rXKz@*ZbFS;6Gqn zbDapPrm=E5Mo2jg&BRO9viqib)jJ9_`u+7(RTjahBY7PB9qPu_B~ReJioottO3lKp zGb9T85TB^}04z#_p1Y2WQikfTW_8!VRt_zy2zwi~3J_ Yy!p@wwG!B;x08H;Vf)6>yjc*Y-|=Dg00000 diff --git a/regress/tests/two-vol-test b/regress/tests/two-vol-test deleted file mode 100755 index adef8e4d1e838c5aa437679d7b79966fc7689829..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1728 zcmbVNO>dh(5bb$?#rQ)#R3g~!tqo3Mr8zWeEG1SiRpl(Om~GZ9-Ca!Gs{g&S3o&3U zH3|odW#7!adGq1Xzz=!m>y(Vh2=0pvC}_UT1%r@APel$g0h2OV(5Mg;!h(w!Vy;+Z zq}t=z02%`5TyW!%R7EM@G2oezU`h!)DT*!A7$GX-;4v@bN1`LebEEx8=6laDZM;Zk ziEh3NMzbO(EJ`H|$A8fBukV5nVeXr4?k8L@PjGEW4T53sB?tm|FjN_yZ7dZJskmqW zcy+-42L|&}swZ^e3%O}x5Gx#tWM$Dd2+Zbhr^qg5J3lLgr~sIkmMEtefitMjXEt9r zKmT-hy|lkG zes#J}CexP!XQaquY8X_OT_^B`{=)BzJyt7tKXDIH*f2k27~JtqYQ+A5V%@uZ_DH^@ z+>j=f5s=FfWU_=$y?SZepG!;Hi3wUF;(f+mqJw!xQ)h z;|mxBFab}(*zs$QE>3m)4j=6@$Ox{6YKCz<}(>hi~6 zH=)LzoFq(DK>OR0>XoKPL=xU9;4`nfx^|)Bw(Tt0ZWWieHKtR(6J`zYh{0hl>pur% F^bcf-7z_Xa diff --git a/regress/tests/two-volume-tape b/regress/tests/two-volume-tape deleted file mode 100755 index d33e4e58b2d13e0f1a0e507e9cfce25337a8ec4b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1824 zcma)7O>f#j5bb$?#RNzXm5hP*)W+mPG?yqr3aFQ=a@O`5wyeF|-8Ga%`R|>z4VVw5 zL5hOCGxOfOoq4p+{D|kinUgkY!()*H1;aBX7(_H)6bfVtcFy32#)Y5|6@~p_p_mFZdY4|e(Zon|>lKS_E8n2SzNv)D6;)o!q zgE3YrfWh!%ABKLymVRCcK}@WhaAQfF078?lpJ=JVia}^;B(R$uddUWZGP+>@4Vr11+f9_xe2HK) zEO*!uLU+4F7B*-(PKG5R{%_T^&3PN{YY}gqeiPL198SEOVOO0Otn*4@1)FxadU_`5 zI;A!z4y#WP4LtYG z#5V1H(J&mYq+Vb}U&z@Gdw*CE^GMoqny_gjQ8+JlSL{dib0x;b#rKC%IKB->*VAiq zg(|4R!fxC$W(>t!+a5XDkVU_Xp+wM#2{))3V}j9W;(dW-*>Et$UaQ`Fy*?NrZP0&j z{Gf^-kU}NYvRcD~k~kDt|7MM%2A_N7hiKg0-!cjw_-t;)dP0{B)<}Luxh1<++CZ+_ zkjoV$5_erARjC=iJM3~$c3GcSTOHI>;dH3h#H-KUN(;0EpyE)IMCOc~AX3Rq{uD^B zc@NtqpR;%orc#H`GK)A1u{nfk>b*Y%=op9VHA6pu)`uz68PBQZGXDyn(8-*yjqh5} zywIcM$XIHF&Lufn<*^d3S*BF%sEpo}NqCxqr)vv6q2XrdN{c;gg{SZnI+t)3Ko2|# zos!<}v4p7}f5A8Bzd1o`uKW*o^z?T)bDz`8iaM26EDIeoNGTdn;)1J`X2rLv9OdCg wJ1;1wt4WFp!x}7|SD>Gqw2^&g/tmp/file-list - -echo " " -echo " " -echo " === Starting usr-tape-root test ===" -echo " " -echo " " - -bin/bacula start 2>&1 >/dev/null -bin/bconsole -c bin/bconsole.conf <&1 >/dev/null -cd / -${cwd}/bin/testls -e ${cwd}/scripts/exclude-usr-test lib >${cwd}/tmp/original -cd ${cwd}/tmp/bacula-restores -${cwd}/bin/testls -e ${cwd}/scripts/exclude-usr-test lib >${cwd}/tmp/restored -cd ${cwd}/tmp -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% original >1 -sort <1 >original -# -sed s%.*lib/kbd/consolefonts$%lib/kbd/consolefonts% restored >1 -sort <1 >restored -rm -f 1 -# -cd ${cwd} -diff tmp/original tmp/restored 2>&1 1>/dev/nul -if [ $? != 0 ] ; then - echo " " - echo " " - echo " ===== !!!! usr-tape-root failed !!!! ===== " - echo " ===== !!!! usr-tape-root failed !!!! ===== " >>test.out - echo " " -else - echo " ===== usr-tape-root OK ===== " - echo " ===== usr-tape-root OK ===== " >>test.out - scripts/cleanup -fi diff --git a/regress/tests/verify-vol-test b/regress/tests/verify-vol-test deleted file mode 100755 index 0fcc2ea5b537e827095e63d7ea68c940ce42d166..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1525 zcmbVMTW{Jh6yCFc#o?koOoBikw}xKS^ z%|n#gF zLowjYIjm5NbW^#;+;XY1A(^%hWslcM_*SfwH)dij3TuK`6`O%YV+XOyQ`4MFz zjOPlv{XZ1>H>iNSFbV9k2vQ+&Ace84c7pEFM;M0iV!5^=&$jGdl`NMCQ^EwY?}E

C^n$Vlbh!qOIsHg0r;c%Wa54EfCZY+hg1nT{JJ1!4B2@=5Q~~w>&|MuaFTXzC z&7SUOcQ?};cCAWVlopx{OEiXOXm%zi0Q^Jcf8jYEz^8Zv(_$acum75p7Lf8=MnhVPs4n1JkJ;>D>5=HG&SKenN z%Z_ASImcCLk%^qk9mH$ZE*_el!0-~VUnL>$Yhxs00T)fL%rRcfQl)3V)iM$|BmSm+ z)pmgtMIY2B)0DFNVTyW59Ia6KXZS?@?z;c!p$q$B9|cELa~t-r*vTyZnpKt)Y8)jK zDSU_i6?8%v!9YR3%I<%Ez?W*$7|oQQ3~Kt*-_UUn)ZkuZNI7*w;?BKwKlr==ngBPg zRnHNyC;K0U4Y4}+El=Q^ioiB1yK%9lAy?Sv^v=)&b|?)xd5*F@(-oA)1l$raw93*H xwRd#yJ#pR{dO#!t;AXs$FvK+ff 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 -- 2.39.5