Fix storage test and simplify TestVM

This commit is contained in:
Bahtiar `kalkin-` Gadimov 2016-04-15 20:10:53 +02:00
parent 88238c80f3
commit 79ac3d3770

View File

@ -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()