Fix uno-choice parameter macro processing

Jinja2 formatter wasn't applied in case of macro parameter
without arguments, due to `ModuleRegistry.dispatch`
couldn't find the parameter definition in the registry.

On other hand, project properties weren't applied for
uno-choice parameter macro with arguments, so it makes
impossible to use these parameters with macros.

Change-Id: Idaff9307dff30567a80b917f6e5ac0717100c349
This commit is contained in:
Artem Nikitin 2022-02-08 11:13:46 +03:00
parent 1590466de9
commit 289b5c55ad
5 changed files with 136 additions and 28 deletions

View File

@ -1437,6 +1437,19 @@ class Parameters(jenkins_jobs.modules.base.Base):
component_type = "parameter"
component_list_type = "parameters"
@staticmethod
def _extend_uno_choice_param_data(param, param_type, data):
"""Pass job name to the uno-choice plugin"""
if param_type in (
"active-choices",
"active-choices-reactive",
"dynamic-reference",
):
# Extend uno-choice plugin parameter data with mandatory properties:
# `project-name` and `project-full-name`
param[param_type]["_project-name"] = data["name"].split("/")[-1]
param[param_type]["_project-full-name"] = data["name"]
def gen_xml(self, xml_parent, data):
properties = xml_parent.find("properties")
if properties is None:
@ -1459,36 +1472,20 @@ class Parameters(jenkins_jobs.modules.base.Base):
if pdefs is None:
pdefs = XML.SubElement(pdefp, "parameterDefinitions")
for param in parameters:
# Pass job name to the uno-choice plugin
if isinstance(param, dict):
param_type = next(iter(param))
if param_type in (
"active-choices",
"active-choices-reactive",
"dynamic-reference",
):
param[param_type]["_project-name"] = data["name"].split("/")[-1]
param[param_type]["_project-full-name"] = data["name"]
if not isinstance(param, dict):
# Macro parameter without arguments
param = {param: {}}
param_type = next(iter(param))
component = self.registry.parser_data.get("parameter", {}).get(
param_type
)
if component is None:
self._extend_uno_choice_param_data(param, param_type, data)
else:
# Process macro case.
# TODO: Find a way to do it more properly.
# It's possible has an issue with macro parameter chain,
# when a macro calls another macro with uno-choice plugin parameters.
component = self.registry.parser_data.get("parameter", {}).get(
param
)
for macro_param in component.get("parameters", []):
for macro_param_type in macro_param:
if macro_param_type in (
"active-choices",
"active-choices-reactive",
"dynamic-reference",
):
macro_param[macro_param_type]["_project-name"] = data[
"name"
].split("/")[-1]
macro_param[macro_param_type][
"_project-full-name"
] = data["name"]
self._extend_uno_choice_param_data(
macro_param, macro_param_type, data
)
self.registry.dispatch("parameter", pdefs, param)

View File

@ -0,0 +1,39 @@
<?xml version="1.0" encoding="utf-8"?>
<project>
<actions/>
<description>&lt;!-- Managed by Jenkins Job Builder --&gt;</description>
<keepDependencies>false</keepDependencies>
<blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
<blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
<concurrentBuild>false</concurrentBuild>
<canRoam>true</canRoam>
<properties>
<hudson.model.ParametersDefinitionProperty>
<parameterDefinitions>
<org.biouno.unochoice.ChoiceParameter>
<script class="org.biouno.unochoice.model.GroovyScript">
<secureFallbackScript>
<script/>
<sandbox>true</sandbox>
</secureFallbackScript>
<secureScript>
<script>return ['default_value']</script>
<sandbox>true</sandbox>
</secureScript>
</script>
<name>ACTIVE_CHOICES</name>
<description>Active choices.</description>
<choiceType>PT_SINGLE_SELECT</choiceType>
<filterable>false</filterable>
<filterLength>1</filterLength>
<projectName>my-job</projectName>
<projectFullName>my-job</projectFullName>
</org.biouno.unochoice.ChoiceParameter>
</parameterDefinitions>
</hudson.model.ParametersDefinitionProperty>
</properties>
<scm class="hudson.scm.NullSCM"/>
<builders/>
<publishers/>
<buildWrappers/>
</project>

View File

@ -0,0 +1,16 @@
- parameter:
name: p_ACTIVE_CHOICES
parameters:
- active-choices:
name: ACTIVE_CHOICES
description: >-
Active choices.
script:
groovy: !j2: |
return ['{{ default }}']
- job:
name: my-job
parameters:
- p_ACTIVE_CHOICES:
default: default_value

View File

@ -0,0 +1,40 @@
<?xml version="1.0" encoding="utf-8"?>
<project>
<actions/>
<description>&lt;!-- Managed by Jenkins Job Builder --&gt;</description>
<keepDependencies>false</keepDependencies>
<blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
<blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
<concurrentBuild>false</concurrentBuild>
<canRoam>true</canRoam>
<properties>
<hudson.model.ParametersDefinitionProperty>
<parameterDefinitions>
<org.biouno.unochoice.ChoiceParameter>
<script class="org.biouno.unochoice.model.GroovyScript">
<secureFallbackScript>
<script/>
<sandbox>true</sandbox>
</secureFallbackScript>
<secureScript>
<script>return ['default_value']
</script>
<sandbox>true</sandbox>
</secureScript>
</script>
<name>ACTIVE_CHOICES</name>
<description>Active choices.</description>
<choiceType>PT_SINGLE_SELECT</choiceType>
<filterable>false</filterable>
<filterLength>1</filterLength>
<projectName>my-job</projectName>
<projectFullName>my-job</projectFullName>
</org.biouno.unochoice.ChoiceParameter>
</parameterDefinitions>
</hudson.model.ParametersDefinitionProperty>
</properties>
<scm class="hudson.scm.NullSCM"/>
<builders/>
<publishers/>
<buildWrappers/>
</project>

View File

@ -0,0 +1,16 @@
- parameter:
name: p_ACTIVE_CHOICES
parameters:
- active-choices:
name: ACTIVE_CHOICES
description: >-
Active choices.
script:
groovy: |
return ['{default}']
- job:
name: my-job
parameters:
- p_ACTIVE_CHOICES:
default: default_value