blob: 45cd60977c2560e2be2d5b10e95dfee366ed354b [file] [log] [blame]
Matthew Treinish7a518772015-07-01 12:46:41 -04001# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may
4# not use this file except in compliance with the License. You may obtain
5# a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations
13# under the License.
14
15import abc
Marc Koderer25319f62015-07-15 11:28:38 +020016import logging
Matthew Treinish7a518772015-07-01 12:46:41 -040017
18import six
19import stevedore
20from tempest_lib.common.utils import misc
21
22
Marc Koderer25319f62015-07-15 11:28:38 +020023LOG = logging.getLogger(__name__)
24
25
Matthew Treinish7a518772015-07-01 12:46:41 -040026@six.add_metaclass(abc.ABCMeta)
27class TempestPlugin(object):
28 """A TempestPlugin class provides the basic hooks for an external
29 plugin to provide tempest the necessary information to run the plugin.
30 """
31
32 @abc.abstractmethod
33 def load_tests(self):
34 """Method to return the information necessary to load the tests in the
35 plugin.
36
37 :return: a tuple with the first value being the test_dir and the second
38 being the top_level
39 :rtype: tuple
40 """
41 return
42
Matthew Treinisha966d0f2015-07-01 17:37:31 -040043 @abc.abstractmethod
44 def register_opts(self, conf):
45 """Method to add additional configuration options to tempest. This
46 method will be run for the plugin during the register_opts() function
47 in tempest.config
48
49 :param ConfigOpts conf: The conf object that can be used to register
50 additional options on.
51 """
52 return
53
Matthew Treinish7a518772015-07-01 12:46:41 -040054
55@misc.singleton
56class TempestTestPluginManager(object):
57 """Tempest test plugin manager class
58
59 This class is used to manage the lifecycle of external tempest test
60 plugins. It provides functions for getting set
61 """
62 def __init__(self):
63 self.ext_plugins = stevedore.ExtensionManager(
Marc Koderer191419c2015-07-14 14:30:45 +020064 'tempest.test_plugins', invoke_on_load=True,
Marc Koderer25319f62015-07-15 11:28:38 +020065 propagate_map_exceptions=True,
66 on_load_failure_callback=self.failure_hook)
67
68 @staticmethod
69 def failure_hook(_, ep, err):
70 LOG.error('Could not load %r: %s', ep.name, err)
71 raise err
Matthew Treinish7a518772015-07-01 12:46:41 -040072
73 def get_plugin_load_tests_tuple(self):
74 load_tests_dict = {}
75 for plug in self.ext_plugins:
76 load_tests_dict[plug.name] = plug.obj.load_tests()
77 return load_tests_dict
Matthew Treinisha966d0f2015-07-01 17:37:31 -040078
79 def register_plugin_opts(self, conf):
80 for plug in self.ext_plugins:
81 plug.obj.register_opts(conf)