diff options
author | Zuul <zuul@review.opendev.org> | 2019-11-04 19:56:37 +0000 |
---|---|---|
committer | Gerrit Code Review <review@openstack.org> | 2019-11-04 19:56:37 +0000 |
commit | a830f19e2a5ef4e08517e08c0293580a71ad2eb3 (patch) | |
tree | 14f3d909258dc58194d842cf9e80f3ac4d7928d7 /tests/base.py | |
parent | 5325b04af1cb194463aee03f528780f75d0f33d2 (diff) | |
parent | 587740ec757e46bc971110582e2e9f3f134b26b3 (diff) | |
download | python-jenkins-job-builder-a830f19e2a5ef4e08517e08c0293580a71ad2eb3.tar.gz python-jenkins-job-builder-a830f19e2a5ef4e08517e08c0293580a71ad2eb3.tar.xz python-jenkins-job-builder-a830f19e2a5ef4e08517e08c0293580a71ad2eb3.zip |
Merge "Support nested views"
Diffstat (limited to 'tests/base.py')
-rw-r--r-- | tests/base.py | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/tests/base.py b/tests/base.py index 660a3af7..f828c773 100644 --- a/tests/base.py +++ b/tests/base.py @@ -18,10 +18,12 @@ # under the License. import doctest +import configparser import io import json import logging import os +import pkg_resources import re import xml.etree.ElementTree as XML @@ -45,6 +47,7 @@ from jenkins_jobs.modules import project_multibranch from jenkins_jobs.modules import project_multijob from jenkins_jobs.modules import view_all from jenkins_jobs.modules import view_list +from jenkins_jobs.modules import view_nested from jenkins_jobs.modules import view_pipeline from jenkins_jobs.parser import YamlParser from jenkins_jobs.registry import ModuleRegistry @@ -169,7 +172,8 @@ class BaseScenariosTestCase(testscenarios.TestWithScenarios, BaseTestCase): scenarios = [] fixtures_path = None - def test_yaml_snippet(self): + @mock.patch("pkg_resources.iter_entry_points") + def test_yaml_snippet(self, mock): if not self.in_filename: return @@ -187,6 +191,24 @@ class BaseScenariosTestCase(testscenarios.TestWithScenarios, BaseTestCase): self.addDetail("plugins-info", text_content(str(plugins_info))) parser = YamlParser(jjb_config) + e = pkg_resources.EntryPoint.parse + d = pkg_resources.Distribution() + config = configparser.ConfigParser() + config.read(os.path.dirname(__file__) + "/../setup.cfg") + groups = {} + for key in config["entry_points"]: + groups[key] = list() + for line in config["entry_points"][key].split("\n"): + if "" == line.strip(): + continue + groups[key].append(e(line, dist=d)) + + def mock_iter_entry_points(group, name=None): + return ( + entry for entry in groups[group] if name is None or name == entry.name + ) + + mock.side_effect = mock_iter_entry_points registry = ModuleRegistry(jjb_config, plugins_info) registry.set_parser_data(parser.data) @@ -213,11 +235,13 @@ class BaseScenariosTestCase(testscenarios.TestWithScenarios, BaseTestCase): if "view-type" in yaml_content: if yaml_content["view-type"] == "all": - project = view_all.All(None) + project = view_all.All(registry) elif yaml_content["view-type"] == "list": - project = view_list.List(None) + project = view_list.List(registry) + elif yaml_content["view-type"] == "nested": + project = view_nested.Nested(registry) elif yaml_content["view-type"] == "pipeline": - project = view_pipeline.Pipeline(None) + project = view_pipeline.Pipeline(registry) else: raise InvalidAttributeError("view-type", yaml_content["view-type"]) |