qubes/tests/vm/qubesvm: add basic tests for QubesVM

And already one fix to instantiation.
This commit is contained in:
Wojtek Porczyk 2015-12-29 20:35:04 +01:00
parent 66475e5ca7
commit bf4dbe07d5
5 changed files with 82 additions and 30 deletions

View File

@ -28,7 +28,7 @@ import qubes.vm.adminvm
import qubes.tools.qvm_ls import qubes.tools.qvm_ls
import qubes.tests import qubes.tests
import qubes.tests.vm.adminvm import qubes.tests.vm
class TC_00_Column(qubes.tests.QubesTestCase): class TC_00_Column(qubes.tests.QubesTestCase):
def test_000_collected(self): def test_000_collected(self):
@ -63,7 +63,7 @@ class TC_90_globals(qubes.tests.QubesTestCase):
# TODO after serious testing of QubesVM and Qubes app, this should be # TODO after serious testing of QubesVM and Qubes app, this should be
# using normal components # using normal components
app = qubes.tests.vm.adminvm.TestApp() app = qubes.tests.vm.TestApp()
vm = qubes.vm.adminvm.AdminVM(app, None, vm = qubes.vm.adminvm.AdminVM(app, None,
qid=0, name='dom0', internal='False') qid=0, name='dom0', internal='False')

View File

@ -0,0 +1,42 @@
#!/usr/bin/python2 -O
# vim: fileencoding=utf-8
# pylint: disable=protected-access,pointless-statement
#
# The Qubes OS Project, https://www.qubes-os.org/
#
# Copyright (C) 2015 Joanna Rutkowska <joanna@invisiblethingslab.com>
# Copyright (C) 2015 Wojtek Porczyk <woju@invisiblethingslab.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#
import qubes.tests
class TestVMM(object):
# pylint: disable=too-few-public-methods
def __init__(self, offline_mode=False):
self.offline_mode = offline_mode
class TestHost(object):
# pylint: disable=too-few-public-methods
def __init__(self):
self.memory_total = 1000
class TestApp(qubes.tests.TestEmitter):
def __init__(self):
super(TestApp, self).__init__()
self.vmm = TestVMM()
self.host = TestHost()

View File

@ -26,33 +26,16 @@ import unittest
import qubes import qubes
import qubes.exc import qubes.exc
import qubes.vm
import qubes.vm.adminvm import qubes.vm.adminvm
import qubes.tests import qubes.tests
class TestVMM(object):
# pylint: disable=too-few-public-methods
def __init__(self, offline_mode=False):
self.offline_mode = offline_mode
class TestHost(object):
# pylint: disable=too-few-public-methods
def __init__(self):
self.memory_total = 1000
# this probably can be shared and not as dummy as is
class TestApp(qubes.tests.TestEmitter):
def __init__(self):
super(TestApp, self).__init__()
self.vmm = TestVMM()
self.host = TestHost()
@qubes.tests.skipUnlessDom0 @qubes.tests.skipUnlessDom0
class TC_00_AdminVM(qubes.tests.QubesTestCase): class TC_00_AdminVM(qubes.tests.QubesTestCase):
def setUp(self): def setUp(self):
try: try:
self.app = TestApp() self.app = qubes.tests.vm.TestApp()
self.vm = qubes.vm.adminvm.AdminVM(self.app, self.vm = qubes.vm.adminvm.AdminVM(self.app,
xml=None, qid=0, name='dom0') xml=None, qid=0, name='dom0')
except: # pylint: disable=bare-except except: # pylint: disable=bare-except

View File

@ -73,27 +73,32 @@ class TC_00_setters(qubes.tests.QubesTestCase):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'test_name-1'), qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'test_name-1'),
'test_name-1') 'test_name-1')
def test_011_setter_name_longer_than_31(self): def test_011_setter_name_not_a_string(self):
# pylint: disable=invalid-name
with self.assertRaises(TypeError):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, False)
def test_012_setter_name_longer_than_31(self):
# pylint: disable=invalid-name # pylint: disable=invalid-name
with self.assertRaises(ValueError): with self.assertRaises(ValueError):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, 't' * 32) qubes.vm.qubesvm._setter_name(self.vm, self.prop, 't' * 32)
def test_012_setter_name_illegal_character(self): def test_013_setter_name_illegal_character(self):
# pylint: disable=invalid-name # pylint: disable=invalid-name
with self.assertRaises(ValueError): with self.assertRaises(ValueError):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'test#') qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'test#')
def test_013_setter_name_first_not_letter(self): def test_014_setter_name_first_not_letter(self):
# pylint: disable=invalid-name # pylint: disable=invalid-name
with self.assertRaises(ValueError): with self.assertRaises(ValueError):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, '1test') qubes.vm.qubesvm._setter_name(self.vm, self.prop, '1test')
def test_014_setter_name_running(self): def test_015_setter_name_running(self):
self.vm.running = True self.vm.running = True
with self.assertRaises(qubes.exc.QubesVMNotHaltedError): with self.assertRaises(qubes.exc.QubesVMNotHaltedError):
qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'testname') qubes.vm.qubesvm._setter_name(self.vm, self.prop, 'testname')
def test_015_setter_name_installed_by_rpm(self): def test_016_setter_name_installed_by_rpm(self):
# pylint: disable=invalid-name # pylint: disable=invalid-name
self.vm.installed_by_rpm = True self.vm.installed_by_rpm = True
with self.assertRaises(qubes.exc.QubesException): with self.assertRaises(qubes.exc.QubesException):
@ -106,6 +111,28 @@ class TC_00_setters(qubes.tests.QubesTestCase):
class TC_90_QubesVM(qubes.tests.QubesTestCase): class TC_90_QubesVM(qubes.tests.QubesTestCase):
@unittest.skip('test not implemented') def setUp(self):
super(TC_90_QubesVM, self).setUp()
self.app = qubes.tests.vm.TestApp()
def test_000_init(self): def test_000_init(self):
pass vm = qubes.vm.qubesvm.QubesVM(self.app, None,
qid=1, name=qubes.tests.VMPREFIX + 'test')
def test_001_init_no_qid_or_name(self):
with self.assertRaises(AssertionError):
qubes.vm.qubesvm.QubesVM(self.app, None,
name=qubes.tests.VMPREFIX + 'test')
with self.assertRaises(AssertionError):
qubes.vm.qubesvm.QubesVM(self.app, None,
qid=1)
def test_003_init_fire_domain_init(self):
class TestVM2(qubes.vm.qubesvm.QubesVM):
event_fired = False
@qubes.events.handler('domain-init')
def on_domain_init(self, event):
self.__class__.event_fired = True
vm = TestVM2(self.app, None, qid=1, name=qubes.tests.VMPREFIX + 'test')
self.assertTrue(TestVM2.event_fired)

View File

@ -483,8 +483,8 @@ class QubesVM(qubes.vm.BaseVM):
if xml is None: if xml is None:
# we are creating new VM and attributes came through kwargs # we are creating new VM and attributes came through kwargs
assert self.qid < qubes.config.max_qid, "VM id out of bounds!" assert hasattr(self, 'qid')
assert self.name is not None assert hasattr(self, 'name')
# Not in generic way to not create QubesHost() to frequently # Not in generic way to not create QubesHost() to frequently
# XXX this doesn't apply, host is instantiated once # XXX this doesn't apply, host is instantiated once