conditional_publisher: add support for Matrix Aggregation
Change-Id: Ic206b3a29c918b63e5b5db47b6629721eab14bd5 Signed-off-by: Evgeni Golov <evgeni@golov.de> Signed-off-by: Thanh Ha <thanh.ha@linuxfoundation.org>
This commit is contained in:
parent
e55b3d408c
commit
73e67f1a12
@ -5608,6 +5608,12 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
:arg str condition-kind: Condition kind that must be verified before the
|
||||
action is executed. Valid values and their additional attributes are
|
||||
described in the conditions_ table.
|
||||
:arg bool condition-aggregation: If true Matrix Aggregation will be
|
||||
enabled. (default false)
|
||||
:arg str condition-aggregation-kind: Condition Aggregation kind that
|
||||
must be verified before the
|
||||
action is executed. Valid values and their additional attributes are
|
||||
described in the conditions_ table.
|
||||
:arg str on-evaluation-failure: What should be the outcome of the build
|
||||
if the evaluation of the condition fails. Possible values are `fail`,
|
||||
`mark-unstable`, `run-and-mark-unstable`, `run` and `dont-run`.
|
||||
@ -5674,8 +5680,8 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
<../../tests/publishers/fixtures/conditional-publisher002.yaml>`
|
||||
|
||||
"""
|
||||
def publish_condition(cdata):
|
||||
kind = cdata['condition-kind']
|
||||
def publish_condition_tag(cdata, prefix, condition_tag):
|
||||
kind = cdata['%s-kind' % prefix]
|
||||
ctag = XML.SubElement(cond_publisher, condition_tag)
|
||||
class_pkg = 'org.jenkins_ci.plugins.run_condition'
|
||||
|
||||
@ -5688,12 +5694,13 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
elif kind == "boolean-expression":
|
||||
ctag.set('class',
|
||||
class_pkg + '.core.BooleanCondition')
|
||||
XML.SubElement(ctag, "token").text = cdata['condition-expression']
|
||||
XML.SubElement(ctag,
|
||||
"token").text = cdata['%s-expression' % prefix]
|
||||
elif kind == "current-status":
|
||||
ctag.set('class',
|
||||
class_pkg + '.core.StatusCondition')
|
||||
wr = XML.SubElement(ctag, 'worstResult')
|
||||
wr_name = cdata['condition-worst']
|
||||
wr_name = cdata['%s-worst' % prefix]
|
||||
if wr_name not in hudson_model.THRESHOLDS:
|
||||
raise JenkinsJobsException(
|
||||
"threshold must be one of %s" %
|
||||
@ -5706,7 +5713,7 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
str(wr_threshold['complete']).lower()
|
||||
|
||||
br = XML.SubElement(ctag, 'bestResult')
|
||||
br_name = cdata['condition-best']
|
||||
br_name = cdata['%s-best' % prefix]
|
||||
if br_name not in hudson_model.THRESHOLDS:
|
||||
raise JenkinsJobsException(
|
||||
"threshold must be one of %s" %
|
||||
@ -5720,22 +5727,23 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
elif kind == "shell":
|
||||
ctag.set('class',
|
||||
class_pkg + '.contributed.ShellCondition')
|
||||
XML.SubElement(ctag, "command").text = cdata['condition-command']
|
||||
XML.SubElement(ctag, "command").text = cdata['%s-command' % prefix]
|
||||
elif kind == "windows-shell":
|
||||
ctag.set('class',
|
||||
class_pkg + '.contributed.BatchFileCondition')
|
||||
XML.SubElement(ctag, "command").text = cdata['condition-command']
|
||||
XML.SubElement(ctag, "command").text = cdata['%s-command' % prefix]
|
||||
elif kind == "regexp":
|
||||
ctag.set('class',
|
||||
class_pkg + '.core.ExpressionCondition')
|
||||
XML.SubElement(ctag,
|
||||
"expression").text = cdata['condition-expression']
|
||||
XML.SubElement(ctag, "label").text = cdata['condition-searchtext']
|
||||
"expression").text = cdata['%s-expression' % prefix]
|
||||
XML.SubElement(ctag,
|
||||
"label").text = cdata['%s-searchtext' % prefix]
|
||||
elif kind == "file-exists":
|
||||
ctag.set('class',
|
||||
class_pkg + '.core.FileExistsCondition')
|
||||
XML.SubElement(ctag, "file").text = cdata['condition-filename']
|
||||
basedir = cdata.get('condition-basedir', 'workspace')
|
||||
XML.SubElement(ctag, "file").text = cdata['%s-filename' % prefix]
|
||||
basedir = cdata.get('%s-basedir', 'workspace')
|
||||
basedir_tag = XML.SubElement(ctag, "baseDir")
|
||||
if "workspace" == basedir:
|
||||
basedir_tag.set('class',
|
||||
@ -5749,8 +5757,15 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
class_pkg + '.common.'
|
||||
'BaseDirectory$JenkinsHome')
|
||||
else:
|
||||
raise JenkinsJobsException('%s is not a valid condition-kind '
|
||||
'value.' % kind)
|
||||
raise JenkinsJobsException('%s is not a valid %s-kind '
|
||||
'value.' % (kind, prefix))
|
||||
|
||||
def publish_condition(cdata):
|
||||
return publish_condition_tag(cdata, 'condition', condition_tag)
|
||||
|
||||
def publish_aggregation_condition(cdata):
|
||||
return publish_condition_tag(cdata, 'condition-aggregation',
|
||||
aggregation_condition_tag)
|
||||
|
||||
def publish_action(parent, action):
|
||||
for edited_node in create_publishers(registry, action):
|
||||
@ -5767,6 +5782,7 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
root_tag = XML.SubElement(xml_parent, flex_publisher_tag)
|
||||
publishers_tag = XML.SubElement(root_tag, "publishers")
|
||||
condition_tag = "condition"
|
||||
aggregation_condition_tag = "aggregationCondition"
|
||||
|
||||
evaluation_classes_pkg = 'org.jenkins_ci.plugins.run_condition'
|
||||
evaluation_classes = {
|
||||
@ -5779,9 +5795,24 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
'dont-run': evaluation_classes_pkg + '.BuildStepRunner$DontRun',
|
||||
}
|
||||
|
||||
plugin_info = registry.get_plugin_info("Flexible Publish Plugin")
|
||||
# Note: Assume latest version of plugin is preferred config format
|
||||
version = pkg_resources.parse_version(
|
||||
plugin_info.get('version', str(sys.maxsize)))
|
||||
|
||||
# Support for MatrixAggregator was added in v0.11
|
||||
# See JENKINS-14494
|
||||
has_matrix_aggregator = version >= pkg_resources.parse_version("0.11")
|
||||
|
||||
for cond_action in data:
|
||||
cond_publisher = XML.SubElement(publishers_tag, cond_publisher_tag)
|
||||
publish_condition(cond_action)
|
||||
condition_aggregation = cond_action.get('condition-aggregation', False)
|
||||
if condition_aggregation and has_matrix_aggregator:
|
||||
publish_aggregation_condition(cond_action)
|
||||
elif condition_aggregation:
|
||||
raise JenkinsJobsException("Matrix Aggregation is not supported "
|
||||
"in your plugin version.")
|
||||
evaluation_flag = cond_action.get('on-evaluation-failure', 'fail')
|
||||
if evaluation_flag not in evaluation_classes.keys():
|
||||
raise JenkinsJobsException('on-evaluation-failure value '
|
||||
@ -5797,11 +5828,6 @@ def conditional_publisher(registry, xml_parent, data):
|
||||
|
||||
action_parent = cond_publisher
|
||||
|
||||
plugin_info = registry.get_plugin_info("Flexible Publish Plugin")
|
||||
# Note: Assume latest version of plugin is preferred config format
|
||||
version = pkg_resources.parse_version(
|
||||
plugin_info.get('version', str(sys.maxsize)))
|
||||
|
||||
# XML tag changed from publisher to publisherList in v0.13
|
||||
# check the plugin version to determine further operations
|
||||
use_publisher_list = version >= pkg_resources.parse_version("0.13")
|
||||
|
@ -0,0 +1,3 @@
|
||||
- longName: 'Flexible Publish Plugin'
|
||||
shortName: 'flexible-publish'
|
||||
version: "0.13"
|
25
tests/publishers/fixtures/conditional-publisher005.xml
Normal file
25
tests/publishers/fixtures/conditional-publisher005.xml
Normal file
@ -0,0 +1,25 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<project>
|
||||
<publishers>
|
||||
<org.jenkins__ci.plugins.flexible__publish.FlexiblePublisher>
|
||||
<publishers>
|
||||
<org.jenkins__ci.plugins.flexible__publish.ConditionalPublisher>
|
||||
<condition class="org.jenkins_ci.plugins.run_condition.core.NeverRun"/>
|
||||
<aggregationCondition class="org.jenkins_ci.plugins.run_condition.core.AlwaysRun"/>
|
||||
<runner class="org.jenkins_ci.plugins.run_condition.BuildStepRunner$Fail"/>
|
||||
<publisherList>
|
||||
<hudson.tasks.ArtifactArchiver>
|
||||
<artifacts>**/**</artifacts>
|
||||
<allowEmptyArchive>true</allowEmptyArchive>
|
||||
<onlyIfSuccessful>false</onlyIfSuccessful>
|
||||
<fingerprint>false</fingerprint>
|
||||
<defaultExcludes>true</defaultExcludes>
|
||||
<caseSensitive>true</caseSensitive>
|
||||
<latestOnly>false</latestOnly>
|
||||
</hudson.tasks.ArtifactArchiver>
|
||||
</publisherList>
|
||||
</org.jenkins__ci.plugins.flexible__publish.ConditionalPublisher>
|
||||
</publishers>
|
||||
</org.jenkins__ci.plugins.flexible__publish.FlexiblePublisher>
|
||||
</publishers>
|
||||
</project>
|
10
tests/publishers/fixtures/conditional-publisher005.yaml
Normal file
10
tests/publishers/fixtures/conditional-publisher005.yaml
Normal file
@ -0,0 +1,10 @@
|
||||
publishers:
|
||||
- conditional-publisher:
|
||||
- condition-kind: never
|
||||
condition-aggregation: True
|
||||
condition-aggregation-kind: always
|
||||
action:
|
||||
- archive:
|
||||
artifacts: '**/**'
|
||||
allow-empty: 'true'
|
||||
|
Loading…
x
Reference in New Issue
Block a user