Merge remote-tracking branch 'origin/release4.0'
This commit is contained in:
commit
eee9964b11
@ -692,6 +692,10 @@ class Qubes(qubes.PropertyHolder):
|
||||
default=None,
|
||||
doc='Default DispVM base for service calls', allow_none=True)
|
||||
|
||||
management_dispvm = qubes.VMProperty('management_dispvm', load_stage=3,
|
||||
default=None,
|
||||
doc='Default DispVM base for managing VMs', allow_none=True)
|
||||
|
||||
default_pool = qubes.property('default_pool', load_stage=3,
|
||||
default=_default_pool,
|
||||
setter=_setter_pool,
|
||||
|
@ -498,6 +498,36 @@ class TC_90_QubesVM(QubesVMTestsMixin, qubes.tests.QubesTestCase):
|
||||
'qubes-vm@{}.service'.format(vm.name)),
|
||||
"systemd service not disabled by resetting autostart")
|
||||
|
||||
def test_290_management_dispvm(self):
|
||||
vm = self.get_vm()
|
||||
vm2 = self.get_vm('test2', qid=2)
|
||||
self.app.management_dispvm = None
|
||||
self.assertPropertyDefaultValue(vm, 'management_dispvm', None)
|
||||
self.app.management_dispvm = vm
|
||||
try:
|
||||
self.assertPropertyDefaultValue(vm, 'management_dispvm', vm)
|
||||
self.assertPropertyValue(vm, 'management_dispvm',
|
||||
'test-inst-test2', vm2)
|
||||
finally:
|
||||
self.app.management_dispvm = None
|
||||
|
||||
def test_291_management_dispvm_template_based(self):
|
||||
tpl = self.get_vm(name='tpl', cls=qubes.vm.templatevm.TemplateVM)
|
||||
vm = self.get_vm(cls=qubes.vm.appvm.AppVM, template=tpl, qid=2)
|
||||
vm2 = self.get_vm('test2', qid=3)
|
||||
del vm.volumes
|
||||
self.app.management_dispvm = None
|
||||
try:
|
||||
self.assertPropertyDefaultValue(vm, 'management_dispvm', None)
|
||||
self.app.management_dispvm = vm
|
||||
self.assertPropertyDefaultValue(vm, 'management_dispvm', vm)
|
||||
tpl.management_dispvm = vm2
|
||||
self.assertPropertyDefaultValue(vm, 'management_dispvm', vm2)
|
||||
self.assertPropertyValue(vm, 'management_dispvm',
|
||||
'test-inst-test2', vm2)
|
||||
finally:
|
||||
self.app.management_dispvm = None
|
||||
|
||||
@unittest.skip('TODO')
|
||||
def test_320_seamless_gui_mode(self):
|
||||
vm = self.get_vm()
|
||||
|
@ -554,6 +554,13 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
|
||||
default=(lambda self: self.app.default_dispvm),
|
||||
doc='Default VM to be used as Disposable VM for service calls.')
|
||||
|
||||
management_dispvm = qubes.VMProperty('management_dispvm',
|
||||
load_stage=4,
|
||||
allow_none=True,
|
||||
default=_default_with_template('management_dispvm',
|
||||
(lambda self: self.app.management_dispvm)),
|
||||
doc='Default DVM template for Disposable VM for managing this VM.')
|
||||
|
||||
updateable = qubes.property('updateable',
|
||||
default=(lambda self: not hasattr(self, 'template')),
|
||||
type=bool,
|
||||
|
Loading…
Reference in New Issue
Block a user