Fix storage test and simplify TestVM
This commit is contained in:
parent
88238c80f3
commit
79ac3d3770
@ -17,9 +17,12 @@
|
|||||||
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
import qubes.log
|
import qubes.log
|
||||||
from qubes.storage import StoragePoolException, pool_drivers
|
from qubes.exc import QubesException
|
||||||
|
from qubes.storage import pool_drivers
|
||||||
from qubes.storage.xen import XenPool
|
from qubes.storage.xen import XenPool
|
||||||
from qubes.tests import QubesTestCase
|
from qubes.tests import QubesTestCase, SystemTestsMixin
|
||||||
|
|
||||||
|
# :pylint: disable=invalid-name
|
||||||
|
|
||||||
|
|
||||||
class TestApp(qubes.tests.TestEmitter):
|
class TestApp(qubes.tests.TestEmitter):
|
||||||
@ -27,30 +30,26 @@ class TestApp(qubes.tests.TestEmitter):
|
|||||||
|
|
||||||
|
|
||||||
class TestVM(object):
|
class TestVM(object):
|
||||||
def __init__(self, app, qid, name, pool_name, template=None):
|
def __init__(self, test, template=None):
|
||||||
super(TestVM, self).__init__()
|
self.app = test.app
|
||||||
self.app = app
|
self.name = test.make_vm_name('appvm')
|
||||||
self.qid = qid
|
|
||||||
self.name = name
|
|
||||||
self.pool_name = pool_name
|
|
||||||
self.template = template
|
|
||||||
self.hvm = False
|
|
||||||
self.storage = qubes.storage.get_pool(self.pool_name,
|
|
||||||
self).get_storage()
|
|
||||||
self.log = qubes.log.get_vm_logger(self.name)
|
self.log = qubes.log.get_vm_logger(self.name)
|
||||||
|
|
||||||
|
if template:
|
||||||
|
self.template = template
|
||||||
|
|
||||||
def is_template(self):
|
def is_template(self):
|
||||||
|
# :pylint: disable=no-self-use
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def is_disposablevm(self):
|
def is_disposablevm(self):
|
||||||
|
# :pylint: disable=no-self-use
|
||||||
return False
|
return False
|
||||||
|
|
||||||
@property
|
|
||||||
def dir_path(self):
|
|
||||||
return self.storage.vmdir
|
|
||||||
|
|
||||||
|
|
||||||
class TestTemplateVM(TestVM):
|
class TestTemplateVM(TestVM):
|
||||||
|
dir_path_prefix = qubes.config.system_path['qubes_templates_dir']
|
||||||
|
|
||||||
def is_template(self):
|
def is_template(self):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -60,46 +59,47 @@ class TestDisposableVM(TestVM):
|
|||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
class TC_00_Pool(QubesTestCase):
|
class TC_00_Pool(SystemTestsMixin, QubesTestCase):
|
||||||
""" This class tests the utility methods from :mod:``qubes.storage`` """
|
""" This class tests the utility methods from :mod:``qubes.storage`` """
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TC_00_Pool, self).setUp()
|
super(TC_00_Pool, self).setUp()
|
||||||
|
self.init_default_template()
|
||||||
|
|
||||||
def test_000_unknown_pool_driver(self):
|
def test_000_unknown_pool_driver(self):
|
||||||
# :pylint: disable=protected-access
|
# :pylint: disable=protected-access
|
||||||
""" Expect an exception when unknown pool is requested"""
|
""" Expect an exception when unknown pool is requested"""
|
||||||
with self.assertRaises(StoragePoolException):
|
with self.assertRaises(QubesException):
|
||||||
qubes.storage._get_pool_klass('foo-bar')
|
self.app.get_pool('foo-bar')
|
||||||
|
|
||||||
def test_001_all_pool_drivers(self):
|
def test_001_all_pool_drivers(self):
|
||||||
""" The only predefined pool driver is file """
|
""" The only predefined pool driver is xen """
|
||||||
self.assertEquals(["xen"], pool_drivers())
|
self.assertEquals(["xen"], pool_drivers())
|
||||||
|
|
||||||
def test_002_get_pool_klass(self):
|
def test_002_get_pool_klass(self):
|
||||||
""" Expect the default pool to be `XenPool` """
|
""" Expect the default pool to be `XenPool` """
|
||||||
# :pylint: disable=protected-access
|
# :pylint: disable=protected-access
|
||||||
result = qubes.storage._get_pool_klass('default')
|
result = self.app.get_pool('default')
|
||||||
self.assertTrue(result is XenPool)
|
self.assertIsInstance(result, XenPool)
|
||||||
|
|
||||||
def test_003_pool_exists_default(self):
|
def test_003_pool_exists_default(self):
|
||||||
""" Expect the default pool to exists """
|
""" Expect the default pool to exists """
|
||||||
self.assertTrue(qubes.storage.pool_exists('default'))
|
self.assertPoolExists('default')
|
||||||
|
|
||||||
def test_004_pool_exists_random(self):
|
def test_004_add_remove_pool(self):
|
||||||
""" Expect this pool to not a exist """
|
|
||||||
self.assertFalse(qubes.storage.pool_exists(
|
|
||||||
'asdh312096r832598213iudhas'))
|
|
||||||
|
|
||||||
def test_005_add_remove_pool(self):
|
|
||||||
""" Tries to adding and removing a pool. """
|
""" Tries to adding and removing a pool. """
|
||||||
pool_name = 'asdjhrp89132'
|
pool_name = 'asdjhrp89132'
|
||||||
|
|
||||||
# make sure it's really does not exist
|
# make sure it's really does not exist
|
||||||
qubes.storage.remove_pool(pool_name)
|
self.app.remove_pool(pool_name)
|
||||||
|
self.assertFalse(self.assertPoolExists(pool_name))
|
||||||
|
|
||||||
qubes.storage.add_pool(pool_name, driver='xen')
|
self.app.add_pool(name=pool_name, driver='xen', dir_path='/tmp/asdjhrp89132')
|
||||||
self.assertTrue(qubes.storage.pool_exists(pool_name))
|
self.assertTrue(self.assertPoolExists(pool_name))
|
||||||
|
|
||||||
qubes.storage.remove_pool(pool_name)
|
self.app.remove_pool(pool_name)
|
||||||
self.assertFalse(qubes.storage.pool_exists(pool_name))
|
self.assertFalse(self.assertPoolExists(pool_name))
|
||||||
|
|
||||||
|
def assertPoolExists(self, pool):
|
||||||
|
""" Check if specified pool exists """
|
||||||
|
return pool in self.app.pools.keys()
|
||||||
|
Loading…
Reference in New Issue
Block a user