| # Copyright 2012 OpenStack Foundation |
| # All Rights Reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| # not use this file except in compliance with the License. You may obtain |
| # a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations |
| # under the License. |
| |
| import testtools |
| |
| |
| class TempestException(Exception): |
| """ |
| Base Tempest Exception |
| |
| To correctly use this class, inherit from it and define |
| a 'message' property. That message will get printf'd |
| with the keyword arguments provided to the constructor. |
| """ |
| message = "An unknown exception occurred" |
| |
| def __init__(self, *args, **kwargs): |
| super(TempestException, self).__init__() |
| try: |
| self._error_string = self.message % kwargs |
| except Exception: |
| # at least get the core message out if something happened |
| self._error_string = self.message |
| if len(args) > 0: |
| # If there is a non-kwarg parameter, assume it's the error |
| # message or reason description and tack it on to the end |
| # of the exception message |
| # Convert all arguments into their string representations... |
| args = ["%s" % arg for arg in args] |
| self._error_string = (self._error_string + |
| "\nDetails: %s" % '\n'.join(args)) |
| |
| def __str__(self): |
| return self._error_string |
| |
| |
| class RestClientException(TempestException, |
| testtools.TestCase.failureException): |
| pass |
| |
| |
| class RFCViolation(RestClientException): |
| message = "RFC Violation" |