Merge "build-blocker: Refactor to increase code quality"

This commit is contained in:
Zuul 2018-08-21 06:48:30 +00:00 committed by Gerrit Code Review
commit 8ab1c56b09
5 changed files with 34 additions and 10 deletions

View File

@ -557,16 +557,24 @@ def build_blocker(registry, xml_parent, data):
:arg bool use-build-blocker: Enable or disable build blocker (default true) :arg bool use-build-blocker: Enable or disable build blocker (default true)
:arg list blocking-jobs: One regular expression per line to select :arg list blocking-jobs: One regular expression per line to select
blocking jobs by their names. (required) blocking jobs by their names (required)
:arg str block-level: block build globally ('GLOBAL') or per node ('NODE') :arg str block-level: block build globally ('GLOBAL') or per node ('NODE')
(default 'GLOBAL') (default 'GLOBAL')
:arg str queue-scanning: scan build queue for all builds ('ALL') or only :arg str queue-scanning: scan build queue for all builds ('ALL') or only
buildable builds ('BUILDABLE') (default 'DISABLED')) buildable builds ('BUILDABLE') (default 'DISABLED')
Example: Example:
Minimal Example:
.. literalinclude:: .. literalinclude::
/../../tests/properties/fixtures/build-blocker01.yaml /../../tests/properties/fixtures/build-blocker-minimal.yaml
:language: yaml
Full Example:
.. literalinclude::
/../../tests/properties/fixtures/build-blocker-full.yaml
:language: yaml :language: yaml
""" """
blocker = XML.SubElement(xml_parent, blocker = XML.SubElement(xml_parent,
@ -578,14 +586,16 @@ def build_blocker(registry, xml_parent, data):
raise JenkinsJobsException('blocking-jobs list must not be empty') raise JenkinsJobsException('blocking-jobs list must not be empty')
jobs = '' jobs = ''
for value in data['blocking-jobs']: for setting, value in data.items():
jobs = jobs + value + '\n' if setting == 'blocking-jobs':
jobs = '\n'.join(value)
block_level_types = ['GLOBAL', 'NODE']
queue_scan_types = ['DISABLED', 'ALL', 'BUILDABLE']
mapping = [ mapping = [
('use-build-blocker', 'useBuildBlocker', True), ('use-build-blocker', 'useBuildBlocker', True),
('', 'blockingJobs', jobs), ('', 'blockingJobs', jobs),
('blocking-level', 'blockLevel', 'GLOBAL', ('GLOBAL', 'NODE')), ('blocking-level', 'blockLevel', 'GLOBAL', block_level_types),
('queue-scanning', 'scanQueueFor', 'DISABLED', ('queue-scanning', 'scanQueueFor', 'DISABLED', queue_scan_types),
('DISABLED', 'ALL', 'BUILDABLE')),
] ]
helpers.convert_mapping_to_xml(blocker, data, mapping, fail_required=True) helpers.convert_mapping_to_xml(blocker, data, mapping, fail_required=True)

View File

@ -4,8 +4,7 @@
<hudson.plugins.buildblocker.BuildBlockerProperty> <hudson.plugins.buildblocker.BuildBlockerProperty>
<useBuildBlocker>true</useBuildBlocker> <useBuildBlocker>true</useBuildBlocker>
<blockingJobs>.*-deploy <blockingJobs>.*-deploy
^maintenance.* ^maintenance.*</blockingJobs>
</blockingJobs>
<blockLevel>GLOBAL</blockLevel> <blockLevel>GLOBAL</blockLevel>
<scanQueueFor>BUILDABLE</scanQueueFor> <scanQueueFor>BUILDABLE</scanQueueFor>
</hudson.plugins.buildblocker.BuildBlockerProperty> </hudson.plugins.buildblocker.BuildBlockerProperty>

View File

@ -0,0 +1,11 @@
<?xml version="1.0" encoding="utf-8"?>
<project>
<properties>
<hudson.plugins.buildblocker.BuildBlockerProperty>
<useBuildBlocker>true</useBuildBlocker>
<blockingJobs>.*-deploy</blockingJobs>
<blockLevel>GLOBAL</blockLevel>
<scanQueueFor>DISABLED</scanQueueFor>
</hudson.plugins.buildblocker.BuildBlockerProperty>
</properties>
</project>

View File

@ -0,0 +1,4 @@
properties:
- build-blocker:
blocking-jobs:
- ".*-deploy"