Stop double-reporting extra_data in exceptions
We append extra_data to the args we send to Exception, but we also append extra_data to the str output. Thing is - Exception already does that with all the args - so we wind up with something like: shade.exc.OpenStackCloudException: ("Image creation failed: <type 'exceptions.OSError'>", Munch({u'status': u'failure'...)) (Extra: Munch({u'status': u'failure'...) Also - the Munch output isn't terribly useful in the exception, so go ahead and dict-ify it if we've passed a munch to extra_data. Change-Id: Ie3271093fba0ac6f074e1cfd4e6a79455dc82be4
This commit is contained in:
parent
916ba38123
commit
485a4c171b
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
import munch
|
||||||
from requests import exceptions as _rex
|
from requests import exceptions as _rex
|
||||||
|
|
||||||
from shade import _log
|
from shade import _log
|
||||||
@ -26,7 +27,9 @@ class OpenStackCloudException(Exception):
|
|||||||
def __init__(self, message, extra_data=None, **kwargs):
|
def __init__(self, message, extra_data=None, **kwargs):
|
||||||
args = [message]
|
args = [message]
|
||||||
if extra_data:
|
if extra_data:
|
||||||
args.append(extra_data)
|
if isinstance(extra_data, munch.Munch):
|
||||||
|
extra_data = extra_data.toDict()
|
||||||
|
args.append("Extra: {0}".format(str(extra_data)))
|
||||||
super(OpenStackCloudException, self).__init__(*args, **kwargs)
|
super(OpenStackCloudException, self).__init__(*args, **kwargs)
|
||||||
self.extra_data = extra_data
|
self.extra_data = extra_data
|
||||||
self.inner_exception = sys.exc_info()
|
self.inner_exception = sys.exc_info()
|
||||||
@ -40,8 +43,6 @@ class OpenStackCloudException(Exception):
|
|||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
message = Exception.__str__(self)
|
message = Exception.__str__(self)
|
||||||
if self.extra_data is not None:
|
|
||||||
message = "%s (Extra: %s)" % (message, self.extra_data)
|
|
||||||
if (self.inner_exception and self.inner_exception[1]
|
if (self.inner_exception and self.inner_exception[1]
|
||||||
and not self.orig_message.endswith(
|
and not self.orig_message.endswith(
|
||||||
str(self.inner_exception[1]))):
|
str(self.inner_exception[1]))):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user