tests: more VMs combinations in backup

VM with custom template, non-default NetVM

This requires to VMs being removed in reversed order (to first remove
VM, then its template).
This commit is contained in:
Marek Marczykowski-Górecki 2016-04-04 14:11:19 +02:00 committed by Wojtek Porczyk
parent 98c8b7cd22
commit 20d53fbf69
2 changed files with 26 additions and 9 deletions

View File

@ -718,6 +718,23 @@ class BackupTestsMixin(SystemTestsMixin):
self.fill_image(testvm2.root_img, 1024*1024*1024, True) self.fill_image(testvm2.root_img, 1024*1024*1024, True)
vms.append(testvm2) vms.append(testvm2)
vmname = self.make_vm_name('template')
if self.verbose:
print >>sys.stderr, "-> Creating %s" % vmname
testvm3 = self.app.add_new_vm(qubes.vm.templatevm.TemplateVM,
name=vmname, label='red')
testvm3.create_on_disk()
self.fill_image(testvm3.root_img, 100*1024*1024, True)
vms.append(testvm3)
vmname = self.make_vm_name('custom')
if self.verbose:
print >>sys.stderr, "-> Creating %s" % vmname
testvm4 = self.app.add_new_vm(qubes.vm.appvm.AppVM,
name=vmname, template=testvm3, label='red')
testvm4.create_on_disk()
vms.append(testvm4)
self.app.save() self.app.save()
return vms return vms

View File

@ -38,7 +38,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
def test_000_basic_backup(self): def test_000_basic_backup(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms) self.make_backup(vms)
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -46,7 +46,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
def test_001_compressed_backup(self): def test_001_compressed_backup(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms, compressed=True) self.make_backup(vms, compressed=True)
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -54,7 +54,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
def test_002_encrypted_backup(self): def test_002_encrypted_backup(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms, encrypted=True) self.make_backup(vms, encrypted=True)
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -62,7 +62,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
def test_003_compressed_encrypted_backup(self): def test_003_compressed_encrypted_backup(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms, compressed=True, encrypted=True) self.make_backup(vms, compressed=True, encrypted=True)
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -85,7 +85,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
self.app.save() self.app.save()
self.make_backup(vms) self.make_backup(vms)
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -94,7 +94,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
def test_005_compressed_custom(self): def test_005_compressed_custom(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms, compressed="bzip2") self.make_backup(vms, compressed="bzip2")
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup() self.restore_backup()
for vm in vms: for vm in vms:
self.assertIn(vm.name, self.app.domains) self.assertIn(vm.name, self.app.domains)
@ -113,7 +113,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
""" """
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.make_backup(vms) self.make_backup(vms)
self.remove_vms(vms) self.remove_vms(reversed(vms))
test_dir = vms[0].dir_path test_dir = vms[0].dir_path
os.mkdir(test_dir) os.mkdir(test_dir)
with open(os.path.join(test_dir, 'some-file.txt'), 'w') as f: with open(os.path.join(test_dir, 'some-file.txt'), 'w') as f:
@ -160,7 +160,7 @@ class TC_10_BackupVMMixin(qubes.tests.BackupTestsMixin):
self.make_backup(vms, target_vm=self.backupvm, self.make_backup(vms, target_vm=self.backupvm,
compressed=True, encrypted=True, compressed=True, encrypted=True,
target='/var/tmp/backup directory') target='/var/tmp/backup directory')
self.remove_vms(vms) self.remove_vms(reversed(vms))
p = self.backupvm.run("ls /var/tmp/backup*/qubes-backup*", p = self.backupvm.run("ls /var/tmp/backup*/qubes-backup*",
passio_popen=True) passio_popen=True)
(backup_path, _) = p.communicate() (backup_path, _) = p.communicate()
@ -174,7 +174,7 @@ class TC_10_BackupVMMixin(qubes.tests.BackupTestsMixin):
self.make_backup(vms, target_vm=self.backupvm, self.make_backup(vms, target_vm=self.backupvm,
compressed=True, encrypted=True, compressed=True, encrypted=True,
target='dd of=/var/tmp/backup-test') target='dd of=/var/tmp/backup-test')
self.remove_vms(vms) self.remove_vms(reversed(vms))
self.restore_backup(source='dd if=/var/tmp/backup-test', self.restore_backup(source='dd if=/var/tmp/backup-test',
appvm=self.backupvm) appvm=self.backupvm)