#!/usr/bin/python # # Copyright 2016 ZTE Corporation # # 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 os import sys import time import argparse import functest.core.TestCasesBase as base import functest.utils.functest_constants as ft_constants import functest.utils.functest_logger as ft_logger import functest.utils.functest_utils as ft_utils class Parser(base.TestCasesBase): def __init__(self): super(Parser, self).__init__() self.project_name = "parser" self.case_name = "parser-basics" self.logger = ft_logger.Logger("parser").getLogger() self.log_file = os.path.join( ft_constants.FUNCTEST_RESULTS_DIR, "parser.log") def run(self, **kwargs): cmd = 'cd %s/tests && ./functest_run.sh' % ft_constants.PARSER_REPO_DIR self.start_time = time.time() ret = ft_utils.execute_command(cmd, info=True, output_file=self.log_file) self.stop_time = time.time() self.criteria, details = ft_utils.check_test_result(self.project_name, ret, self.start_time, self.stop_time) ft_utils.logger_test_results(self.project_name, self.case_name, self.criteria, details) return ret @staticmethod def get_conf(parameter): return ft_utils.get_functest_config(parameter) if __name__ == '__main__': args_parser = argparse.ArgumentParser() args_parser.add_argument("-r", "--report", help="Create json result file", action="store_true") args = vars(args_parser.parse_args()) parser = Parser() try: result = parser.run(**args) if result != base.TestCasesBase.EX_OK: sys.exit(result) if args['report']: sys.exit(parser.push_to_db()) except Exception: sys.exit(base.TestCasesBase.EX_RUN_ERROR)