| # Copyright 2017 AT&T Corporation. |
| # 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 logging |
| import os |
| |
| from oslo_concurrency import lockutils |
| |
| from tempest import config |
| from tempest.test_discover import plugins |
| |
| from patrole_tempest_plugin import config as project_config |
| |
| RBACLOG = logging.getLogger('rbac_reporting') |
| |
| |
| class PatroleTempestPlugin(plugins.TempestPlugin): |
| |
| def load_tests(self): |
| base_path = os.path.split(os.path.dirname( |
| os.path.abspath(__file__)))[0] |
| test_dir = "patrole_tempest_plugin/tests/api" |
| full_test_dir = os.path.join(base_path, test_dir) |
| return full_test_dir, base_path |
| |
| @lockutils.synchronized('_reset_log_file') |
| def _reset_log_file(self, logfile): |
| try: |
| os.remove(logfile) |
| except OSError: |
| pass |
| |
| def _configure_per_test_logging(self, conf): |
| # Separate log handler for rbac reporting |
| RBACLOG.setLevel(level=logging.INFO) |
| # Set up proper directory handling |
| report_abs_path = os.path.abspath(conf.patrole_log.report_log_path) |
| report_path = os.path.join( |
| report_abs_path, conf.patrole_log.report_log_name) |
| |
| # Remove the log file if it exists |
| self._reset_log_file(report_path) |
| |
| # Delay=True so that we don't end up creating an empty file if we |
| # never log to it. |
| rbac_report_handler = logging.FileHandler( |
| filename=report_path, delay=True, mode='a') |
| rbac_report_handler.setFormatter( |
| fmt=logging.Formatter(fmt='%(message)s')) |
| RBACLOG.addHandler(rbac_report_handler) |
| |
| def register_opts(self, conf): |
| # TODO(fmontei): Remove ``rbac_group`` in a future release as it is |
| # currently deprecated. |
| config.register_opt_group( |
| conf, |
| project_config.rbac_group, |
| project_config.PatroleGroup) |
| config.register_opt_group( |
| conf, |
| project_config.patrole_group, |
| project_config.PatroleGroup) |
| config.register_opt_group( |
| conf, |
| project_config.patrole_log_group, |
| project_config.PatroleLogGroup) |
| |
| if conf.patrole_log.enable_reporting: |
| self._configure_per_test_logging(conf) |
| |
| def get_opt_lists(self): |
| return [(project_config.patrole_group.name, |
| project_config.PatroleGroup)] |