From 20d53fbf69e02c4e64b1e09c48d87c3f2bb866c0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Mon, 4 Apr 2016 14:11:19 +0200 Subject: [PATCH] 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). --- qubes/tests/__init__.py | 17 +++++++++++++++++ qubes/tests/int/backup.py | 18 +++++++++--------- 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/qubes/tests/__init__.py b/qubes/tests/__init__.py index 09d74a3e..e95ae3d4 100644 --- a/qubes/tests/__init__.py +++ b/qubes/tests/__init__.py @@ -718,6 +718,23 @@ class BackupTestsMixin(SystemTestsMixin): self.fill_image(testvm2.root_img, 1024*1024*1024, True) 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() return vms diff --git a/qubes/tests/int/backup.py b/qubes/tests/int/backup.py index 2acb2754..c11b0948 100644 --- a/qubes/tests/int/backup.py +++ b/qubes/tests/int/backup.py @@ -38,7 +38,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase): def test_000_basic_backup(self): vms = self.create_backup_vms() self.make_backup(vms) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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): vms = self.create_backup_vms() self.make_backup(vms, compressed=True) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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): vms = self.create_backup_vms() self.make_backup(vms, encrypted=True) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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): vms = self.create_backup_vms() self.make_backup(vms, compressed=True, encrypted=True) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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.make_backup(vms) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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): vms = self.create_backup_vms() self.make_backup(vms, compressed="bzip2") - self.remove_vms(vms) + self.remove_vms(reversed(vms)) self.restore_backup() for vm in vms: 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() self.make_backup(vms) - self.remove_vms(vms) + self.remove_vms(reversed(vms)) test_dir = vms[0].dir_path os.mkdir(test_dir) 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, compressed=True, encrypted=True, target='/var/tmp/backup directory') - self.remove_vms(vms) + self.remove_vms(reversed(vms)) p = self.backupvm.run("ls /var/tmp/backup*/qubes-backup*", passio_popen=True) (backup_path, _) = p.communicate() @@ -174,7 +174,7 @@ class TC_10_BackupVMMixin(qubes.tests.BackupTestsMixin): self.make_backup(vms, target_vm=self.backupvm, compressed=True, encrypted=True, 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', appvm=self.backupvm)