diff options
Diffstat (limited to 'iceci/decorator/exception_decor.py')
-rw-r--r-- | iceci/decorator/exception_decor.py | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/iceci/decorator/exception_decor.py b/iceci/decorator/exception_decor.py new file mode 100644 index 0000000..467f2ce --- /dev/null +++ b/iceci/decorator/exception_decor.py @@ -0,0 +1,70 @@ + +# ============LICENSE_START========================================== +# org.onap.vvp/test-engine +# =================================================================== +# Copyright © 2017 AT&T Intellectual Property. All rights reserved. +# =================================================================== +# +# Unless otherwise specified, all software contained herein is licensed +# under the Apache License, Version 2.0 (the “License”); +# you may not use this software 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. +# +# +# +# Unless otherwise specified, all documentation contained herein is licensed +# under the Creative Commons License, Attribution 4.0 Intl. (the “License”); +# you may not use this documentation except in compliance with the License. +# You may obtain a copy of the License at +# +# https://creativecommons.org/licenses/by/4.0/ +# +# Unless required by applicable law or agreed to in writing, documentation +# 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. +# +# ============LICENSE_END============================================ +# +# ECOMP is a trademark and service mark of AT&T Intellectual Property. +import logging +import traceback + +from services.logging_service import LoggingServiceFactory +from services.session import session + + +logger = LoggingServiceFactory.get_logger() + + +def exception(): + """ + A decorator that wraps the passed in function and logs + exceptions should one occur + + @param logger: The logging object + """ + + def decorator(func): + + def wrapper(*args, **kwargs): + try: + return func(*args, **kwargs) + except: + err = "There was an exception in %s" % func.__name__ + logger.error(err) + session.errorCounter += 1 + session.errorList = traceback.format_exc() + raise + + return wrapper + return decorator |