tests: improve error reporting in backup tests

This commit is contained in:
Marek Marczykowski-Górecki 2014-09-26 14:26:24 +02:00
parent 6d3ff57466
commit d5c63786d9

View File

@ -20,7 +20,7 @@
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
# #
# #
from multiprocessing import Event from multiprocessing import Event, Queue
import os import os
import shutil import shutil
@ -34,7 +34,7 @@ VM_PREFIX = "test-"
class BackupTests(unittest.TestCase): class BackupTests(unittest.TestCase):
def setUp(self): def setUp(self):
self.error_detected = Event() self.error_detected = Queue()
self.verbose = False self.verbose = False
self.qc = QubesVmCollection() self.qc = QubesVmCollection()
self.qc.lock_db_for_writing() self.qc.lock_db_for_writing()
@ -64,7 +64,7 @@ class BackupTests(unittest.TestCase):
print >> sys.stderr, "\r-> Backing up files: {0}%...".format(progress) print >> sys.stderr, "\r-> Backing up files: {0}%...".format(progress)
def error_callback(self, message): def error_callback(self, message):
self.error_detected.set() self.error_detected.put(message)
if self.verbose: if self.verbose:
print >> sys.stderr, "ERROR: {0}".format(message) print >> sys.stderr, "ERROR: {0}".format(message)
@ -137,10 +137,6 @@ class BackupTests(unittest.TestCase):
self.qc.save() self.qc.save()
self.qc.unlock_db() self.qc.unlock_db()
def print_callback(self, msg):
if self.verbose:
print msg
def make_backup(self, vms, prepare_kwargs=dict(), do_kwargs=dict()): def make_backup(self, vms, prepare_kwargs=dict(), do_kwargs=dict()):
try: try:
files_to_backup = \ files_to_backup = \
@ -177,8 +173,12 @@ class BackupTests(unittest.TestCase):
# TODO: print_callback=self.print_callback if self.verbose else None, # TODO: print_callback=self.print_callback if self.verbose else None,
except QubesException as e: except QubesException as e:
self.fail("QubesException during backup_restore_do: %s" % str(e)) self.fail("QubesException during backup_restore_do: %s" % str(e))
self.assertFalse(self.error_detected.is_set(), errors = []
"Error detected during backup_restore_do") while not self.error_detected.empty():
errors.append(self.error_detected.get())
self.assertTrue(len(errors) == 0,
"Error(s) detected during backup_restore_do: %s" %
'\n'.join(errors))
os.unlink(backupfile) os.unlink(backupfile)
def test_basic_backup(self): def test_basic_backup(self):