Create Base class for Mistral Exceptions and Errors
Moved common logic in mistral/exceptions from MistralError and MistralExceptions to MistralFailureBase Change-Id: I79dc7b91c00a296a2c6d9c3b589ea3fa4fc7db48
This commit is contained in:
parent
ec66e1d945
commit
6a672572bc
@ -15,27 +15,18 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
|
||||||
# TODO(rakhmerov): Can we make one parent for errors and exceptions?
|
class MistralFailuresBase(Exception):
|
||||||
|
"""Base class for mistral errors and exceptions"""
|
||||||
|
|
||||||
class MistralError(Exception):
|
message = "An unknow failure occured"
|
||||||
"""Mistral specific error.
|
|
||||||
|
|
||||||
Reserved for situations that can't be automatically handled. When it occurs
|
|
||||||
it signals that there is a major environmental problem like invalid startup
|
|
||||||
configuration or implementation problem (e.g. some code doesn't take care
|
|
||||||
of certain corner cases). From architectural perspective it's pointless to
|
|
||||||
try to handle this type of problems except doing some finalization work
|
|
||||||
like transaction rollback, deleting temporary files etc.
|
|
||||||
"""
|
|
||||||
|
|
||||||
message = "An unknown error occurred"
|
|
||||||
http_code = 500
|
http_code = 500
|
||||||
|
|
||||||
def __init__(self, message=None):
|
def __init__(self, message=None):
|
||||||
if message is not None:
|
if message is not None:
|
||||||
self.message = message
|
self.message = message
|
||||||
|
|
||||||
super(MistralError, self).__init__(
|
super(MistralFailuresBase, self).__init__(
|
||||||
'%d: %s' % (self.http_code, self.message))
|
'%d: %s' % (self.http_code, self.message))
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -50,7 +41,21 @@ class MistralError(Exception):
|
|||||||
return self.message
|
return self.message
|
||||||
|
|
||||||
|
|
||||||
class MistralException(Exception):
|
class MistralError(MistralFailuresBase):
|
||||||
|
"""Mistral specific error.
|
||||||
|
|
||||||
|
Reserved for situations that can't be automatically handled. When it occurs
|
||||||
|
it signals that there is a major environmental problem like invalid startup
|
||||||
|
configuration or implementation problem (e.g. some code doesn't take care
|
||||||
|
of certain corner cases). From architectural perspective it's pointless to
|
||||||
|
try to handle this type of problems except doing some finalization work
|
||||||
|
like transaction rollback, deleting temporary files etc.
|
||||||
|
"""
|
||||||
|
|
||||||
|
message = "An unknown error occurred"
|
||||||
|
|
||||||
|
|
||||||
|
class MistralException(MistralFailuresBase):
|
||||||
"""Mistral specific exception.
|
"""Mistral specific exception.
|
||||||
|
|
||||||
Reserved for situations that are not critical for program continuation.
|
Reserved for situations that are not critical for program continuation.
|
||||||
@ -66,25 +71,6 @@ class MistralException(Exception):
|
|||||||
'http_code' properties.
|
'http_code' properties.
|
||||||
"""
|
"""
|
||||||
message = "An unknown exception occurred"
|
message = "An unknown exception occurred"
|
||||||
http_code = 500
|
|
||||||
|
|
||||||
def __init__(self, message=None):
|
|
||||||
if message is not None:
|
|
||||||
self.message = message
|
|
||||||
|
|
||||||
super(MistralException, self).__init__(
|
|
||||||
'%d: %s' % (self.http_code, self.message))
|
|
||||||
|
|
||||||
@property
|
|
||||||
def code(self):
|
|
||||||
"""This is here for webob to read.
|
|
||||||
|
|
||||||
https://github.com/Pylons/webob/blob/master/webob/exc.py
|
|
||||||
"""
|
|
||||||
return self.http_code
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
return self.message
|
|
||||||
|
|
||||||
|
|
||||||
# Database errors.
|
# Database errors.
|
||||||
|
Loading…
Reference in New Issue
Block a user