admin-api: fix handling admin.vm.property.Set with None VM value
Setting VMProperty to None VM should be encoded as '' value (according to VMProperty._none_value). But value validation rejected this value. QubesOS/qubes-issues#2622
This commit is contained in:
parent
305fb5b6d0
commit
607dcbaf37
@ -155,6 +155,17 @@ class TC_00_VMs(AdminAPITestCase):
|
|||||||
mock.assert_called_once_with(self.vm, 'test-net')
|
mock.assert_called_once_with(self.vm, 'test-net')
|
||||||
self.app.save.assert_called_once_with()
|
self.app.save.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_0301_vm_property_set_vm_none(self):
|
||||||
|
netvm = self.app.add_new_vm('AppVM', label='red', name='test-net',
|
||||||
|
template='test-template', provides_network=True)
|
||||||
|
|
||||||
|
with unittest.mock.patch('qubes.vm.VMProperty.__set__') as mock:
|
||||||
|
value = self.call_mgmt_func(b'admin.vm.property.Set', b'test-vm1',
|
||||||
|
b'netvm', b'')
|
||||||
|
self.assertIsNone(value)
|
||||||
|
mock.assert_called_once_with(self.vm, '')
|
||||||
|
self.app.save.assert_called_once_with()
|
||||||
|
|
||||||
def test_032_vm_property_set_vm_invalid1(self):
|
def test_032_vm_property_set_vm_invalid1(self):
|
||||||
with unittest.mock.patch('qubes.vm.VMProperty.__set__') as mock:
|
with unittest.mock.patch('qubes.vm.VMProperty.__set__') as mock:
|
||||||
with self.assertRaises(qubes.exc.QubesValueError):
|
with self.assertRaises(qubes.exc.QubesValueError):
|
||||||
|
@ -442,5 +442,9 @@ class VMProperty(qubes.property):
|
|||||||
untrusted_vmname = untrusted_newvalue.decode('ascii')
|
untrusted_vmname = untrusted_newvalue.decode('ascii')
|
||||||
except UnicodeDecodeError:
|
except UnicodeDecodeError:
|
||||||
raise qubes.exc.QubesValueError
|
raise qubes.exc.QubesValueError
|
||||||
|
if untrusted_vmname == '':
|
||||||
|
# allow empty VM name for setting VMProperty value, because it's
|
||||||
|
# string representation of None (see self._none_value)
|
||||||
|
return untrusted_vmname
|
||||||
validate_name(None, self, untrusted_vmname)
|
validate_name(None, self, untrusted_vmname)
|
||||||
return untrusted_vmname
|
return untrusted_vmname
|
||||||
|
Loading…
Reference in New Issue
Block a user