diff options
| author | Jenkins <jenkins@review.openstack.org> | 2016-06-20 22:24:26 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2016-06-20 22:24:27 +0000 |
| commit | 7cda2b2a066cd45c7aeb9a6d92c1a83e49d48128 (patch) | |
| tree | 63a3e4962d1a3d212e5814ea273a8bd620f0eaa8 /openstackclient/network | |
| parent | 8c850cadcfc481319b91850ba759e68256fee138 (diff) | |
| parent | 8b6626e9b60abb15a94c6c2eac2d1536f6a1918b (diff) | |
| download | python-openstackclient-7cda2b2a066cd45c7aeb9a6d92c1a83e49d48128.tar.gz | |
Merge "Error handling of "router delete" command"
Diffstat (limited to 'openstackclient/network')
| -rw-r--r-- | openstackclient/network/v2/router.py | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/openstackclient/network/v2/router.py b/openstackclient/network/v2/router.py index 92ecf84d..6271a878 100644 --- a/openstackclient/network/v2/router.py +++ b/openstackclient/network/v2/router.py @@ -19,6 +19,7 @@ import logging from osc_lib.cli import parseractions from osc_lib.command import command +from osc_lib import exceptions from osc_lib import utils from openstackclient.i18n import _ @@ -222,9 +223,23 @@ class DeleteRouter(command.Command): def take_action(self, parsed_args): client = self.app.client_manager.network + result = 0 + for router in parsed_args.router: - obj = client.find_router(router) - client.delete_router(obj) + try: + obj = client.find_router(router, ignore_missing=False) + client.delete_router(obj) + except Exception as e: + result += 1 + LOG.error(_("Failed to delete router with " + "name or ID '%(router)s': %(e)s") + % {'router': router, 'e': e}) + + if result > 0: + total = len(parsed_args.router) + msg = (_("%(result)s of %(total)s routers failed " + "to delete.") % {'result': result, 'total': total}) + raise exceptions.CommandError(msg) class ListRouter(command.Lister): |
