diff options
author | Jose Lausuch <jose.lausuch@ericsson.com> | 2016-10-18 13:58:53 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@opnfv.org> | 2016-10-18 13:58:54 +0000 |
commit | 8015f7e1b4da654b88ab52f7226e311a19dbbc4f (patch) | |
tree | 93a6818a917c3fa81ea00e1db582559422c6945a /core/TestCasesBase.py | |
parent | 873250561e60238db973d64f0d3bb61cb844d4a6 (diff) | |
parent | ed47f47c4e08fb45dcdf6addee0eb6272dc13628 (diff) |
Merge "Add a parent class for test cases."
Diffstat (limited to 'core/TestCasesBase.py')
-rw-r--r-- | core/TestCasesBase.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/core/TestCasesBase.py b/core/TestCasesBase.py new file mode 100644 index 00000000..8e68fa68 --- /dev/null +++ b/core/TestCasesBase.py @@ -0,0 +1,46 @@ +#!/usr/bin/env python + +import os + +import functest.utils.functest_logger as ft_logger +import functest.utils.functest_utils as ft_utils + + +class TestCasesBase(object): + + EX_OK = os.EX_OK + EX_RUN_ERROR = os.EX_SOFTWARE + EX_PUSH_TO_DB_ERROR = os.EX_SOFTWARE - 1 + + logger = ft_logger.Logger(__name__).getLogger() + + project = "functest" + + def __init__(self): + self.details = {} + self.case_name = "" + self.criteria = "" + self.start_time = "" + self.stop_time = "" + + def run(self, **kwargs): + self.logger.error("Run must be implemented") + return TestCasesBase.EX_RUN_ERROR + + def push_to_db(self): + try: + assert self.case_name + assert self.criteria + assert self.start_time + assert self.stop_time + if ft_utils.push_results_to_db( + TestCasesBase.project, self.case_name, self.start_time, + self.stop_time, self.criteria, self.details): + self.logger.info("The results were successfully pushed to DB") + return TestCasesBase.EX_OK + else: + self.logger.error("The results cannot be pushed to DB") + return TestCasesBase.EX_PUSH_TO_DB_ERROR + except Exception: + self.logger.exception("The results cannot be pushed to DB") + return TestCasesBase.EX_PUSH_TO_DB_ERROR |