tests: automatically iterate tests over templates

This commit is contained in:
Marek Marczykowski-Górecki 2015-03-22 01:40:50 +01:00
parent 20e4e26111
commit fbd96532e8
4 changed files with 66 additions and 17 deletions

View File

@ -348,6 +348,7 @@ class BackupTestsMixin(SystemTestsMixin):
if self.verbose: if self.verbose:
print >>sys.stderr, "-> Creating backupvm" print >>sys.stderr, "-> Creating backupvm"
# TODO: allow non-default template
self.backupvm = self.qc.add_new_vm("QubesAppVm", self.backupvm = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('backupvm'), name=self.make_vm_name('backupvm'),
template=self.qc.get_default_template()) template=self.qc.get_default_template())

View File

@ -86,6 +86,7 @@ class TC_00_Backup(qubes.tests.BackupTestsMixin, qubes.tests.QubesTestCase):
self.remove_vms(vms) self.remove_vms(vms)
# TODO: iterate over templates
def test_100_send_to_vm(self): def test_100_send_to_vm(self):
vms = self.create_backup_vms() vms = self.create_backup_vms()
self.backupvm.start() self.backupvm.start()

View File

@ -35,7 +35,7 @@ from qubes.qubes import QubesVmCollection, defaults
import qubes.tests import qubes.tests
class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase): class VmNetworkingMixin(qubes.tests.SystemTestsMixin):
test_ip = '192.168.123.45' test_ip = '192.168.123.45'
test_name = 'test.example.com' test_name = 'test.example.com'
@ -50,14 +50,14 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
return p.wait() return p.wait()
def setUp(self): def setUp(self):
super(VmNetworkingTests, self).setUp() super(VmNetworkingMixin, self).setUp()
self.testnetvm = self.qc.add_new_vm("QubesNetVm", self.testnetvm = self.qc.add_new_vm("QubesNetVm",
name=self.make_vm_name('netvm1'), name=self.make_vm_name('netvm1'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testnetvm.create_on_disk(verbose=False) self.testnetvm.create_on_disk(verbose=False)
self.testvm1 = self.qc.add_new_vm("QubesAppVm", self.testvm1 = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('vm2'), name=self.make_vm_name('vm2'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testvm1.create_on_disk(verbose=False) self.testvm1.create_on_disk(verbose=False)
self.testvm1.netvm = self.testnetvm self.testvm1.netvm = self.testnetvm
self.qc.save() self.qc.save()
@ -98,7 +98,7 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
def test_010_simple_proxyvm(self): def test_010_simple_proxyvm(self):
self.proxy = self.qc.add_new_vm("QubesProxyVm", self.proxy = self.qc.add_new_vm("QubesProxyVm",
name=self.make_vm_name('proxy'), name=self.make_vm_name('proxy'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.proxy.create_on_disk(verbose=False) self.proxy.create_on_disk(verbose=False)
self.proxy.netvm = self.testnetvm self.proxy.netvm = self.testnetvm
self.testvm1.netvm = self.proxy self.testvm1.netvm = self.proxy
@ -121,7 +121,7 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
def test_020_simple_proxyvm_nm(self): def test_020_simple_proxyvm_nm(self):
self.proxy = self.qc.add_new_vm("QubesProxyVm", self.proxy = self.qc.add_new_vm("QubesProxyVm",
name=self.make_vm_name('proxy'), name=self.make_vm_name('proxy'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.proxy.create_on_disk(verbose=False) self.proxy.create_on_disk(verbose=False)
self.proxy.netvm = self.testnetvm self.proxy.netvm = self.testnetvm
self.proxy.services['network-manager'] = True self.proxy.services['network-manager'] = True
@ -165,7 +165,7 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
def test_030_firewallvm_firewall(self): def test_030_firewallvm_firewall(self):
self.proxy = self.qc.add_new_vm("QubesProxyVm", self.proxy = self.qc.add_new_vm("QubesProxyVm",
name=self.make_vm_name('proxy'), name=self.make_vm_name('proxy'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.proxy.create_on_disk(verbose=False) self.proxy.create_on_disk(verbose=False)
self.proxy.netvm = self.testnetvm self.proxy.netvm = self.testnetvm
self.testvm1.netvm = self.proxy self.testvm1.netvm = self.proxy
@ -262,14 +262,14 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
def test_040_inter_vm(self): def test_040_inter_vm(self):
self.proxy = self.qc.add_new_vm("QubesProxyVm", self.proxy = self.qc.add_new_vm("QubesProxyVm",
name=self.make_vm_name('proxy'), name=self.make_vm_name('proxy'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.proxy.create_on_disk(verbose=False) self.proxy.create_on_disk(verbose=False)
self.proxy.netvm = self.testnetvm self.proxy.netvm = self.testnetvm
self.testvm1.netvm = self.proxy self.testvm1.netvm = self.proxy
self.testvm2 = self.qc.add_new_vm("QubesAppVm", self.testvm2 = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('vm3'), name=self.make_vm_name('vm3'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testvm2.create_on_disk(verbose=False) self.testvm2.create_on_disk(verbose=False)
self.testvm2.netvm = self.proxy self.testvm2.netvm = self.proxy
self.qc.save() self.qc.save()
@ -293,3 +293,23 @@ class VmNetworkingTests(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase)
self.ping_cmd.format(target=self.testvm2.ip)), 0) self.ping_cmd.format(target=self.testvm2.ip)), 0)
self.assertNotEqual(self.run_cmd(self.testvm2, self.assertNotEqual(self.run_cmd(self.testvm2,
self.ping_cmd.format(target=self.testvm1.ip)), 0) self.ping_cmd.format(target=self.testvm1.ip)), 0)
def load_tests(loader, tests, pattern):
try:
qc = qubes.qubes.QubesVmCollection()
qc.lock_db_for_reading()
qc.load()
qc.unlock_db()
templates = [vm.name for vm in qc.values() if
isinstance(vm, qubes.qubes.QubesTemplateVm)]
except OSError:
templates = []
for template in templates:
tests.addTests(loader.loadTestsFromTestCase(
type(
'VmNetworking_' + template,
(VmNetworkingMixin, qubes.tests.QubesTestCase),
{'template': template})))
return tests

View File

@ -36,16 +36,16 @@ import qubes.tests
TEST_DATA = "0123456789" * 1024 TEST_DATA = "0123456789" * 1024
class TC_00_AppVM(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase): class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
def setUp(self): def setUp(self):
super(TC_00_AppVM, self).setUp() super(TC_00_AppVMMixin, self).setUp()
self.testvm1 = self.qc.add_new_vm("QubesAppVm", self.testvm1 = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('vm1'), name=self.make_vm_name('vm1'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testvm1.create_on_disk(verbose=False) self.testvm1.create_on_disk(verbose=False)
self.testvm2 = self.qc.add_new_vm("QubesAppVm", self.testvm2 = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('vm2'), name=self.make_vm_name('vm2'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testvm2.create_on_disk(verbose=False) self.testvm2.create_on_disk(verbose=False)
self.qc.save() self.qc.save()
self.qc.unlock_db() self.qc.unlock_db()
@ -395,17 +395,17 @@ class TC_10_HVM(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase):
self.assertRaises(QubesException, self.templatevm.start) self.assertRaises(QubesException, self.templatevm.start)
class TC_20_DispVM(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase): class TC_20_DispVMMixin(qubes.tests.SystemTestsMixin):
def test_000_prepare_dvm(self): def test_000_prepare_dvm(self):
self.qc.unlock_db() self.qc.unlock_db()
retcode = subprocess.call(['/usr/bin/qvm-create-default-dvm', retcode = subprocess.call(['/usr/bin/qvm-create-default-dvm',
'--default-template'], self.template],
stderr=open(os.devnull, 'w')) stderr=open(os.devnull, 'w'))
self.assertEqual(retcode, 0) self.assertEqual(retcode, 0)
self.qc.lock_db_for_writing() self.qc.lock_db_for_writing()
self.qc.load() self.qc.load()
self.assertIsNotNone(self.qc.get_vm_by_name( self.assertIsNotNone(self.qc.get_vm_by_name(
self.qc.get_default_template().name + "-dvm")) self.template + "-dvm"))
# TODO: check mtime of snapshot file # TODO: check mtime of snapshot file
def test_010_simple_dvm_run(self): def test_010_simple_dvm_run(self):
@ -505,7 +505,7 @@ class TC_20_DispVM(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase):
def test_030_edit_file(self): def test_030_edit_file(self):
self.testvm1 = self.qc.add_new_vm("QubesAppVm", self.testvm1 = self.qc.add_new_vm("QubesAppVm",
name=self.make_vm_name('vm1'), name=self.make_vm_name('vm1'),
template=self.qc.get_default_template()) template=self.qc.get_vm_by_name(self.template))
self.testvm1.create_on_disk(verbose=False) self.testvm1.create_on_disk(verbose=False)
self.qc.save() self.qc.save()
@ -539,3 +539,30 @@ class TC_20_DispVM(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase):
(test_txt_content, _) = p.communicate() (test_txt_content, _) = p.communicate()
self.assertEqual(test_txt_content, "test test 2\ntest1\n") self.assertEqual(test_txt_content, "test test 2\ntest1\n")
def load_tests(loader, tests, pattern):
try:
qc = qubes.qubes.QubesVmCollection()
qc.lock_db_for_reading()
qc.load()
qc.unlock_db()
templates = [vm.name for vm in qc.values() if
isinstance(vm, qubes.qubes.QubesTemplateVm)]
except OSError:
templates = []
for template in templates:
tests.addTests(loader.loadTestsFromTestCase(
type(
'TC_00_AppVM_' + template,
(TC_00_AppVMMixin, qubes.tests.QubesTestCase),
{'template': template})))
tests.addTests(loader.loadTestsFromTestCase(
type(
'TC_20_DispVM_' + template,
(TC_20_DispVMMixin, qubes.tests.QubesTestCase),
{'template': template})))
tests.addTests(loader.loadTestsFromTestCase(TC_10_HVM))
return tests