network.common.NetworkAndComputeShowOne: catch HttpException
Problem: if a user issue the cmd 'openstack floating ip create public' and has already maxed his quota for FIP, OSC exits with a not so useful message: >jordan@jordan-XPS13-9333:~ $ openstack floating ip create public >HttpException: Conflict This patches catch the HttpException earlier and prints a more verbose message: > jordan@jordan-XPS13-9333:~ $ openstack floating ip create public > Error while executing command: Quota exceeded for resources: ['floatingip'] Change-Id: I7c87524d871d230d92f007c32e06439b34c7194a
This commit is contained in:
parent
b37ad9992b
commit
52279b1b04
@ -14,6 +14,7 @@
|
|||||||
import abc
|
import abc
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
|
import openstack.exceptions
|
||||||
from osc_lib.command import command
|
from osc_lib.command import command
|
||||||
from osc_lib import exceptions
|
from osc_lib import exceptions
|
||||||
import six
|
import six
|
||||||
@ -181,12 +182,16 @@ class NetworkAndComputeShowOne(command.ShowOne):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def take_action(self, parsed_args):
|
def take_action(self, parsed_args):
|
||||||
if self.app.client_manager.is_network_endpoint_enabled():
|
try:
|
||||||
return self.take_action_network(self.app.client_manager.network,
|
if self.app.client_manager.is_network_endpoint_enabled():
|
||||||
parsed_args)
|
return self.take_action_network(
|
||||||
else:
|
self.app.client_manager.network, parsed_args)
|
||||||
return self.take_action_compute(self.app.client_manager.compute,
|
else:
|
||||||
parsed_args)
|
return self.take_action_compute(
|
||||||
|
self.app.client_manager.compute, parsed_args)
|
||||||
|
except openstack.exceptions.HttpException as exc:
|
||||||
|
msg = _("Error while executing command: %s") % exc.message
|
||||||
|
raise exceptions.CommandError(msg)
|
||||||
|
|
||||||
def get_parser(self, prog_name):
|
def get_parser(self, prog_name):
|
||||||
LOG.debug('get_parser(%s)', prog_name)
|
LOG.debug('get_parser(%s)', prog_name)
|
||||||
|
@ -14,6 +14,8 @@
|
|||||||
import argparse
|
import argparse
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
|
import openstack
|
||||||
|
from openstackclient.common import exceptions
|
||||||
from openstackclient.network import common
|
from openstackclient.network import common
|
||||||
from openstackclient.tests.unit import utils
|
from openstackclient.tests.unit import utils
|
||||||
|
|
||||||
@ -172,3 +174,15 @@ class TestNetworkAndComputeShowOne(TestNetworkAndCompute):
|
|||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestNetworkAndComputeShowOne, self).setUp()
|
super(TestNetworkAndComputeShowOne, self).setUp()
|
||||||
self.cmd = FakeNetworkAndComputeShowOne(self.app, self.namespace)
|
self.cmd = FakeNetworkAndComputeShowOne(self.app, self.namespace)
|
||||||
|
|
||||||
|
def test_take_action_with_http_exception(self):
|
||||||
|
with mock.patch.object(self.cmd, 'take_action_network') as m_action:
|
||||||
|
m_action.side_effect = openstack.exceptions.HttpException("bar")
|
||||||
|
self.assertRaisesRegex(exceptions.CommandError, "bar",
|
||||||
|
self.cmd.take_action, mock.Mock())
|
||||||
|
|
||||||
|
self.app.client_manager.network_endpoint_enabled = False
|
||||||
|
with mock.patch.object(self.cmd, 'take_action_compute') as m_action:
|
||||||
|
m_action.side_effect = openstack.exceptions.HttpException("bar")
|
||||||
|
self.assertRaisesRegex(exceptions.CommandError, "bar",
|
||||||
|
self.cmd.take_action, mock.Mock())
|
||||||
|
Loading…
Reference in New Issue
Block a user