tests: add/remove services in dom0

This commit is contained in:
Frédéric Pierret (fepitre) 2020-02-20 14:53:44 +01:00
parent 0b8e5400a3
commit 9a6ff177ce
No known key found for this signature in database
GPG Key ID: 484010B5CDC576E2
2 changed files with 61 additions and 15 deletions

View File

@ -24,8 +24,6 @@ import os
import qubes.ext import qubes.ext
import qubes.config import qubes.config
dom0_services_dir = qubes.config.system_path['dom0_services_dir']
class ServicesExtension(qubes.ext.Extension): class ServicesExtension(qubes.ext.Extension):
"""This extension export features with 'service.' prefix to QubesDB in """This extension export features with 'service.' prefix to QubesDB in
@ -35,21 +33,26 @@ class ServicesExtension(qubes.ext.Extension):
@staticmethod @staticmethod
def add_dom0_services(vm, service): def add_dom0_services(vm, service):
try: try:
os.makedirs(dom0_services_dir, exist_ok=True) os.makedirs(
service = '{}/{}'.format(dom0_services_dir, service) qubes.config.system_path['dom0_services_dir'], exist_ok=True)
service = '{}/{}'.format(
qubes.config.system_path['dom0_services_dir'], service)
if not os.path.exists(service): if not os.path.exists(service):
os.mknod(service) os.mknod(service)
except PermissionError: except PermissionError:
vm.log.warning("Cannot write to {}".format(dom0_services_dir)) vm.log.warning("Cannot write to {}".format(
qubes.config.system_path['dom0_services_dir']))
@staticmethod @staticmethod
def remove_dom0_services(vm, service): def remove_dom0_services(vm, service):
try: try:
service = '{}/{}'.format(dom0_services_dir, service) service = '{}/{}'.format(
qubes.config.system_path['dom0_services_dir'], service)
if os.path.exists(service): if os.path.exists(service):
os.remove(service) os.remove(service)
except PermissionError: except PermissionError:
vm.log.warning("Cannot write to {}".format(dom0_services_dir)) vm.log.warning("Cannot write to {}".format(
qubes.config.system_path['dom0_services_dir']))
# pylint: disable=no-self-use # pylint: disable=no-self-use
@qubes.ext.handler('domain-qdb-create') @qubes.ext.handler('domain-qdb-create')

View File

@ -18,13 +18,13 @@
# You should have received a copy of the GNU Lesser General Public # You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, see <https://www.gnu.org/licenses/>. # License along with this library; if not, see <https://www.gnu.org/licenses/>.
from unittest import mock import os
import qubes.ext.core_features import qubes.ext.core_features
import qubes.ext.services import qubes.ext.services
import qubes.ext.windows import qubes.ext.windows
import qubes.tests import qubes.tests
from unittest import mock
class TC_00_CoreFeatures(qubes.tests.QubesTestCase): class TC_00_CoreFeatures(qubes.tests.QubesTestCase):
def setUp(self): def setUp(self):
@ -235,19 +235,27 @@ class TC_20_Services(qubes.tests.QubesTestCase):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.ext = qubes.ext.services.ServicesExtension() self.ext = qubes.ext.services.ServicesExtension()
self.vm = mock.MagicMock()
self.features = {} self.features = {}
self.vm.configure_mock(**{ specs = {
'template': None,
'maxmem': 1024,
'is_running.return_value': True,
'features.get.side_effect': self.features.get, 'features.get.side_effect': self.features.get,
'features.items.side_effect': self.features.items, 'features.items.side_effect': self.features.items,
'features.__iter__.side_effect': self.features.__iter__, 'features.__iter__.side_effect': self.features.__iter__,
'features.__contains__.side_effect': self.features.__contains__, 'features.__contains__.side_effect': self.features.__contains__,
'features.__setitem__.side_effect': self.features.__setitem__, 'features.__setitem__.side_effect': self.features.__setitem__,
'features.__delitem__.side_effect': self.features.__delitem__, 'features.__delitem__.side_effect': self.features.__delitem__,
}) }
vmspecs = {**specs, **{
'template': None,
'maxmem': 1024,
'is_running.return_value': True,
}}
dom0specs = {**specs, **{
'name': "dom0",
}}
self.vm = mock.MagicMock()
self.vm.configure_mock(**vmspecs)
self.dom0 = mock.MagicMock()
self.dom0.configure_mock(**dom0specs)
def test_000_write_to_qdb(self): def test_000_write_to_qdb(self):
self.features['service.test1'] = '1' self.features['service.test1'] = '1'
@ -322,3 +330,38 @@ class TC_20_Services(qubes.tests.QubesTestCase):
self.assertEqual(self.features, { self.assertEqual(self.features, {
'supported-service.test2': True, 'supported-service.test2': True,
}) })
def test_013_feature_set_dom0(self):
self.test_base_dir = '/tmp/qubes-test-dir'
self.base_dir_patch = mock.patch.dict(
qubes.config.system_path, {'dom0_services_dir': self.test_base_dir})
self.base_dir_patch.start()
service = 'guivm-gui-agent'
service_path = self.test_base_dir + '/' + service
self.ext.on_domain_feature_set(
self.dom0,
'feature-set:service.service.guivm-gui-agent',
'service.guivm-gui-agent', '1')
self.assertEqual(os.path.exists(service_path), True)
def test_014_feature_delete_dom0(self):
self.test_base_dir = '/tmp/qubes-test-dir'
self.base_dir_patch = mock.patch.dict(
qubes.config.system_path, {'dom0_services_dir': self.test_base_dir})
self.base_dir_patch.start()
service = 'guivm-gui-agent'
service_path = self.test_base_dir + '/' + service
self.ext.on_domain_feature_set(
self.dom0,
'feature-set:service.service.guivm-gui-agent',
'service.guivm-gui-agent', '1')
self.ext.on_domain_feature_delete(
self.dom0,
'feature-delete:service.service.guivm-gui-agent',
'service.guivm-gui-agent')
self.assertEqual(os.path.exists(service_path), False)