Skip to content

Commit 19896ec

Browse files
Zuulopenstack-gerrit
authored andcommitted
Merge "Adds command image metadef object delete"
2 parents 1678f87 + 5d1afce commit 19896ec

5 files changed

Lines changed: 103 additions & 4 deletions

File tree

doc/source/cli/command-objects/image-metadef.rst

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,3 +21,24 @@ Image v2
2121

2222
.. autoprogram-cliff:: openstack.image.v2
2323
:command: image metadef resource type list
24+
25+
.. autoprogram-cliff:: openstack.image.v2
26+
:command: image metadef object create
27+
28+
.. autoprogram-cliff:: openstack.image.v2
29+
:command: image metadef object show
30+
31+
.. autoprogram-cliff:: openstack.image.v2
32+
:command: image metadef object list
33+
34+
.. autoprogram-cliff:: openstack.image.v2
35+
:command: image metadef object delete
36+
37+
.. autoprogram-cliff:: openstack.image.v2
38+
:command: image metadef property create
39+
40+
.. autoprogram-cliff:: openstack.image.v2
41+
:command: image metadef property list
42+
43+
.. autoprogram-cliff:: openstack.image.v2
44+
:command: image metadef property show

doc/source/cli/data/glance.csv

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,10 +33,10 @@ md-namespace-show,image metadef namespace show,Describe a specific metadata defi
3333
md-namespace-tags-delete,,Delete all metadata definitions tags inside a specific namespace.
3434
md-namespace-update,,Update an existing metadata definitions namespace.
3535
md-object-create,image metadef object create,Create a new metadata definitions object inside a namespace.
36-
md-object-delete,,Delete a specific metadata definitions object inside a namespace.
36+
md-object-show,image metadef object show,Describe a specific metadata definitions object inside a namespace.
3737
md-object-list,image metadef object list,List metadata definitions objects inside a specific namespace.
38+
md-object-delete,image metadef object delete,Delete a specific metadata definitions object inside a namespace.
3839
md-object-property-show,,Describe a specific metadata definitions property inside an object.
39-
md-object-show,image metadef object show,Describe a specific metadata definitions object inside a namespace.
4040
md-object-update,,Update metadata definitions object inside a namespace.
4141
md-property-create,image metadef property create,Create a new metadata definitions property inside a namespace.
4242
md-property-delete,image metadef property delete,Delete a specific metadata definitions property inside a namespace.

openstackclient/image/v2/metadef_objects.py

Lines changed: 55 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -15,13 +15,18 @@
1515

1616
"""Image V2 Action Implementations"""
1717

18+
import logging
1819

1920
from osc_lib.command import command
21+
from osc_lib import exceptions
2022
from osc_lib import utils
2123

2224
from openstackclient.i18n import _
2325

2426

27+
LOG = logging.getLogger(__name__)
28+
29+
2530
def _format_object(md_object):
2631
fields_to_show = (
2732
'created_at',
@@ -77,7 +82,7 @@ def take_action(self, parsed_args):
7782

7883
class ShowMetadefObjects(command.ShowOne):
7984
_description = _(
80-
"Describe a specific metadata definitions" "object inside a namespace"
85+
"Describe a specific metadata definitions object inside a namespace"
8186
)
8287

8388
def get_parser(self, prog_name):
@@ -107,6 +112,55 @@ def take_action(self, parsed_args):
107112
return fields, value
108113

109114

115+
class DeleteMetadefObject(command.Command):
116+
_description = _(
117+
"Delete a specific metadata definitions object inside a namespace"
118+
)
119+
120+
def get_parser(self, prog_name):
121+
parser = super().get_parser(prog_name)
122+
parser.add_argument(
123+
"namespace_name",
124+
metavar="<namespace_name>",
125+
help=_("Namespace (name) for the namespace"),
126+
)
127+
parser.add_argument(
128+
"object_name",
129+
metavar="<object_name>",
130+
nargs="+",
131+
help=_("Name of an object."),
132+
)
133+
return parser
134+
135+
def take_action(self, parsed_args):
136+
image_client = self.app.client_manager.image
137+
138+
namespace_name = parsed_args.namespace_name
139+
140+
result = 0
141+
for i in parsed_args.object_name:
142+
try:
143+
object = image_client.get_metadef_object(i, namespace_name)
144+
image_client.delete_metadef_object(object, namespace_name)
145+
except Exception as e:
146+
result += 1
147+
LOG.error(
148+
_(
149+
"Failed to delete object with name or "
150+
"ID '%(object)s': %(e)s"
151+
),
152+
{'object': i, 'e': e},
153+
)
154+
155+
if result > 0:
156+
total = len(parsed_args.namespace_name)
157+
msg = _("%(result)s of %(total)s object failed to delete.") % {
158+
'result': result,
159+
'total': total,
160+
}
161+
raise exceptions.CommandError(msg)
162+
163+
110164
class ListMetadefObjects(command.Lister):
111165
_description = _("List metadef objects inside a specific namespace.")
112166

openstackclient/tests/unit/image/v2/test_metadef_objects.py

Lines changed: 24 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -97,13 +97,36 @@ def test_object_show(self):
9797
]
9898
verifylist = []
9999
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
100-
101100
columns, data = self.cmd.take_action(parsed_args)
102101

103102
self.assertEqual(self.expected_columns, columns)
104103
self.assertEqual(self.expected_data, data)
105104

106105

106+
class TestMetadefObjectDelete(fakes.TestImagev2):
107+
_metadef_namespace = fakes.create_one_metadef_namespace()
108+
_metadef_objects = fakes.create_one_metadef_object()
109+
110+
def setUp(self):
111+
super().setUp()
112+
113+
self.image_client.delete_metadef_object.return_value = None
114+
self.cmd = metadef_objects.DeleteMetadefObject(self.app, None)
115+
116+
def test_object_delete(self):
117+
arglist = [
118+
self._metadef_namespace.namespace,
119+
self._metadef_objects.name,
120+
]
121+
122+
verifylist = []
123+
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
124+
125+
result = self.cmd.take_action(parsed_args)
126+
127+
self.assertIsNone(result)
128+
129+
107130
class TestMetadefObjectList(fakes.TestImagev2):
108131
_metadef_namespace = fakes.create_one_metadef_namespace()
109132
_metadef_objects = [fakes.create_one_metadef_object()]

setup.cfg

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -401,6 +401,7 @@ openstack.image.v2 =
401401
image_metadef_object_create = openstackclient.image.v2.metadef_objects:CreateMetadefObjects
402402
image_metadef_object_show = openstackclient.image.v2.metadef_objects:ShowMetadefObjects
403403
image_metadef_object_list = openstackclient.image.v2.metadef_objects:ListMetadefObjects
404+
image_metadef_object_delete = openstackclient.image.v2.metadef_objects:DeleteMetadefObject
404405

405406

406407
image_metadef_property_create = openstackclient.image.v2.metadef_properties:CreateMetadefProperty

0 commit comments

Comments
 (0)