Merge "image: Unset properties rather than setting to None"
This commit is contained in:
commit
23afc0af92
@ -1193,7 +1193,7 @@ class UnsetImage(command.Command):
|
|||||||
if parsed_args.properties:
|
if parsed_args.properties:
|
||||||
for k in parsed_args.properties:
|
for k in parsed_args.properties:
|
||||||
if k in image:
|
if k in image:
|
||||||
kwargs[k] = None
|
delattr(image, k)
|
||||||
elif k in image.properties:
|
elif k in image.properties:
|
||||||
# Since image is an "evil" object from SDK POV we need to
|
# Since image is an "evil" object from SDK POV we need to
|
||||||
# pass modified properties object, so that SDK can figure
|
# pass modified properties object, so that SDK can figure
|
||||||
|
@ -119,6 +119,7 @@ class ImageTests(base.BaseImageTests):
|
|||||||
'image set ' +
|
'image set ' +
|
||||||
'--property a=b ' +
|
'--property a=b ' +
|
||||||
'--property c=d ' +
|
'--property c=d ' +
|
||||||
|
'--property hw_rng_model=virtio ' +
|
||||||
'--public ' +
|
'--public ' +
|
||||||
self.name
|
self.name
|
||||||
)
|
)
|
||||||
@ -133,6 +134,7 @@ class ImageTests(base.BaseImageTests):
|
|||||||
'image unset ' +
|
'image unset ' +
|
||||||
'--property a ' +
|
'--property a ' +
|
||||||
'--property c ' +
|
'--property c ' +
|
||||||
|
'--property hw_rng_model ' +
|
||||||
self.name
|
self.name
|
||||||
)
|
)
|
||||||
json_output = json.loads(self.openstack(
|
json_output = json.loads(self.openstack(
|
||||||
|
@ -1516,15 +1516,16 @@ class TestImageShow(TestImage):
|
|||||||
|
|
||||||
class TestImageUnset(TestImage):
|
class TestImageUnset(TestImage):
|
||||||
|
|
||||||
attrs = {}
|
|
||||||
attrs['tags'] = ['test']
|
|
||||||
attrs['prop'] = 'test'
|
|
||||||
attrs['prop2'] = 'fake'
|
|
||||||
image = image_fakes.FakeImage.create_one_image(attrs)
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestImageUnset, self).setUp()
|
super(TestImageUnset, self).setUp()
|
||||||
|
|
||||||
|
attrs = {}
|
||||||
|
attrs['tags'] = ['test']
|
||||||
|
attrs['hw_rng_model'] = 'virtio'
|
||||||
|
attrs['prop'] = 'test'
|
||||||
|
attrs['prop2'] = 'fake'
|
||||||
|
self.image = image_fakes.FakeImage.create_one_image(attrs)
|
||||||
|
|
||||||
self.client.find_image.return_value = self.image
|
self.client.find_image.return_value = self.image
|
||||||
self.client.remove_tag.return_value = self.image
|
self.client.remove_tag.return_value = self.image
|
||||||
self.client.update_image.return_value = self.image
|
self.client.update_image.return_value = self.image
|
||||||
@ -1567,22 +1568,20 @@ class TestImageUnset(TestImage):
|
|||||||
def test_image_unset_property_option(self):
|
def test_image_unset_property_option(self):
|
||||||
|
|
||||||
arglist = [
|
arglist = [
|
||||||
|
'--property', 'hw_rng_model',
|
||||||
'--property', 'prop',
|
'--property', 'prop',
|
||||||
self.image.id,
|
self.image.id,
|
||||||
]
|
]
|
||||||
|
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('properties', ['prop']),
|
('properties', ['hw_rng_model', 'prop']),
|
||||||
('image', self.image.id)
|
('image', self.image.id)
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
result = self.cmd.take_action(parsed_args)
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
kwargs = {}
|
|
||||||
self.client.update_image.assert_called_with(
|
self.client.update_image.assert_called_with(
|
||||||
self.image,
|
self.image, properties={'prop2': 'fake'})
|
||||||
properties={'prop2': 'fake'},
|
|
||||||
**kwargs)
|
|
||||||
|
|
||||||
self.assertIsNone(result)
|
self.assertIsNone(result)
|
||||||
|
|
||||||
@ -1590,23 +1589,21 @@ class TestImageUnset(TestImage):
|
|||||||
|
|
||||||
arglist = [
|
arglist = [
|
||||||
'--tag', 'test',
|
'--tag', 'test',
|
||||||
|
'--property', 'hw_rng_model',
|
||||||
'--property', 'prop',
|
'--property', 'prop',
|
||||||
self.image.id,
|
self.image.id,
|
||||||
]
|
]
|
||||||
|
|
||||||
verifylist = [
|
verifylist = [
|
||||||
('tags', ['test']),
|
('tags', ['test']),
|
||||||
('properties', ['prop']),
|
('properties', ['hw_rng_model', 'prop']),
|
||||||
('image', self.image.id)
|
('image', self.image.id)
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
result = self.cmd.take_action(parsed_args)
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
kwargs = {}
|
|
||||||
self.client.update_image.assert_called_with(
|
self.client.update_image.assert_called_with(
|
||||||
self.image,
|
self.image, properties={'prop2': 'fake'})
|
||||||
properties={'prop2': 'fake'},
|
|
||||||
**kwargs)
|
|
||||||
|
|
||||||
self.client.remove_tag.assert_called_with(
|
self.client.remove_tag.assert_called_with(
|
||||||
self.image.id, 'test'
|
self.image.id, 'test'
|
||||||
|
Loading…
Reference in New Issue
Block a user