Update Sonatype CLM for CI plugin
- Update to use convert_mapping_to_xml - Add username, password, and value options - Update documentation Change-Id: I76de5f0a9f5169e09764e418733e9046b046ea09 Signed-off-by: Kien Ha <kienha9922@gmail.com>
This commit is contained in:
parent
7d13236760
commit
704f28c748
@ -2577,53 +2577,78 @@ def sonatype_clm(parser, xml_parent, data):
|
||||
Requires the Jenkins :jenkins-wiki:`Sonatype CLM Plugin
|
||||
<Sonatype+CLM+%28formerly+Insight+for+CI%29>`.
|
||||
|
||||
:arg str value: Select CLM application from a list of available CLM
|
||||
applications or specify CLM Application ID (default: list)
|
||||
:arg str application-name: Determines the policy elements to associate
|
||||
with this build. (required)
|
||||
:arg str username: Username on the Sonatype CLM server. Leave empty to
|
||||
use the username configured at global level. (default: '')
|
||||
:arg str password: Password on the Sonatype CLM server. Leave empty to
|
||||
use the password configured at global level. (default: '')
|
||||
:arg bool fail-on-clm-server-failure: Controls the build outcome if there
|
||||
is a failure in communicating with the CLM server. (default false)
|
||||
is a failure in communicating with the CLM server. (default: False)
|
||||
:arg str stage: Controls the stage the policy evaluation will be run
|
||||
against on the CLM server. Valid stages: build, stage-release, release,
|
||||
operate. (default 'build')
|
||||
:arg str scan-targets: Pattern of files to include for scanning. (optional)
|
||||
:arg str module-excludes: Pattern of files to exclude. (optional)
|
||||
operate. (default: 'build')
|
||||
:arg str scan-targets: Pattern of files to include for scanning.
|
||||
(default: '')
|
||||
:arg str module-excludes: Pattern of files to exclude. (default: '')
|
||||
:arg str advanced-options: Options to be set on a case-by-case basis as
|
||||
advised by Sonatype Support. (optional)
|
||||
advised by Sonatype Support. (default: '')
|
||||
|
||||
Example:
|
||||
Minimal Example:
|
||||
|
||||
.. literalinclude:: /../../tests/builders/fixtures/sonatype-clm01.yaml
|
||||
.. literalinclude::
|
||||
/../../tests/builders/fixtures/sonatype-clm-minimal.yaml
|
||||
:language: yaml
|
||||
|
||||
Full Example:
|
||||
|
||||
.. literalinclude::
|
||||
/../../tests/builders/fixtures/sonatype-clm-complete.yaml
|
||||
:language: yaml
|
||||
"""
|
||||
clm = XML.SubElement(xml_parent,
|
||||
'com.sonatype.insight.ci.hudson.PreBuildScan')
|
||||
clm.set('plugin', 'sonatype-clm-ci')
|
||||
|
||||
if 'application-name' not in data:
|
||||
raise MissingAttributeError("application-name",
|
||||
"builders.sonatype-clm")
|
||||
XML.SubElement(clm, 'billOfMaterialsToken').text = str(
|
||||
data['application-name'])
|
||||
XML.SubElement(clm, 'failOnClmServerFailures').text = str(
|
||||
data.get('fail-on-clm-server-failure', False)).lower()
|
||||
|
||||
SUPPORTED_VALUES = ['list', 'manual']
|
||||
clm_value = data.get('value')
|
||||
if clm_value and clm_value not in SUPPORTED_VALUES:
|
||||
raise InvalidAttributeError('value',
|
||||
clm_value,
|
||||
SUPPORTED_VALUES)
|
||||
SUPPORTED_STAGES = ['build', 'stage-release', 'release', 'operate']
|
||||
stage = str(data.get('stage', 'build')).lower()
|
||||
if stage not in SUPPORTED_STAGES:
|
||||
raise InvalidAttributeError("stage",
|
||||
stage,
|
||||
"builders.sonatype-clm",
|
||||
clm_stage = data.get('stage')
|
||||
if clm_stage and clm_stage not in SUPPORTED_STAGES:
|
||||
raise InvalidAttributeError('stage',
|
||||
clm_stage,
|
||||
SUPPORTED_STAGES)
|
||||
XML.SubElement(clm, 'stageId').text = stage
|
||||
|
||||
# Path Configs
|
||||
path_config = XML.SubElement(clm,
|
||||
'pathConfig')
|
||||
XML.SubElement(path_config, 'scanTargets').text = str(
|
||||
data.get('scan-targets', '')).lower()
|
||||
XML.SubElement(path_config, 'moduleExcludes').text = str(
|
||||
data.get('module-excludes', '')).lower()
|
||||
XML.SubElement(path_config, 'scanProperties').text = str(
|
||||
data.get('advanced-options', '')).lower()
|
||||
application_select = XML.SubElement(clm,
|
||||
'applicationSelectType')
|
||||
application_mappings = [
|
||||
('value', 'value', 'list'),
|
||||
('application-name', 'applicationId', None),
|
||||
]
|
||||
convert_mapping_to_xml(
|
||||
application_select, data, application_mappings, fail_required=True)
|
||||
|
||||
path = XML.SubElement(clm, 'pathConfig')
|
||||
path_mappings = [
|
||||
('scan-targets', 'scanTargets', ''),
|
||||
('module-excludes', 'moduleExcludes', ''),
|
||||
('advanced-options', 'scanProperties', ''),
|
||||
]
|
||||
convert_mapping_to_xml(path, data, path_mappings, fail_required=True)
|
||||
|
||||
mappings = [
|
||||
('fail-on-clm-server-failure', 'failOnClmServerFailures', False),
|
||||
('stage', 'stageId', 'build'),
|
||||
('username', 'username', ''),
|
||||
('password', 'password', ''),
|
||||
]
|
||||
convert_mapping_to_xml(clm, data, mappings, fail_required=True)
|
||||
|
||||
|
||||
def beaker(parser, xml_parent, data):
|
||||
|
@ -2,14 +2,19 @@
|
||||
<project>
|
||||
<builders>
|
||||
<com.sonatype.insight.ci.hudson.PreBuildScan plugin="sonatype-clm-ci">
|
||||
<billOfMaterialsToken>jenkins-job-builder</billOfMaterialsToken>
|
||||
<failOnClmServerFailures>true</failOnClmServerFailures>
|
||||
<stageId>release</stageId>
|
||||
<applicationSelectType>
|
||||
<value>manual</value>
|
||||
<applicationId>jenkins-job-builder</applicationId>
|
||||
</applicationSelectType>
|
||||
<pathConfig>
|
||||
<scanTargets>**/*.jar</scanTargets>
|
||||
<moduleExcludes>**/my-module/target/**</moduleExcludes>
|
||||
<scanProperties>test</scanProperties>
|
||||
</pathConfig>
|
||||
<failOnClmServerFailures>true</failOnClmServerFailures>
|
||||
<stageId>build</stageId>
|
||||
<username>bar</username>
|
||||
<password>06XQY39LHGACt3r3kzSULg==</password>
|
||||
</com.sonatype.insight.ci.hudson.PreBuildScan>
|
||||
</builders>
|
||||
</project>
|
@ -1,8 +1,11 @@
|
||||
builders:
|
||||
- sonatype-clm:
|
||||
value: manual
|
||||
application-name: jenkins-job-builder
|
||||
fail-on-clm-server-failure: true
|
||||
stage: release
|
||||
stage: build
|
||||
scan-targets: '**/*.jar'
|
||||
module-excludes: '**/my-module/target/**'
|
||||
advanced-options: 'test'
|
||||
username: bar
|
||||
password: 06XQY39LHGACt3r3kzSULg==
|
20
tests/builders/fixtures/sonatype-clm-minimal.xml
Normal file
20
tests/builders/fixtures/sonatype-clm-minimal.xml
Normal file
@ -0,0 +1,20 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<project>
|
||||
<builders>
|
||||
<com.sonatype.insight.ci.hudson.PreBuildScan plugin="sonatype-clm-ci">
|
||||
<applicationSelectType>
|
||||
<value>list</value>
|
||||
<applicationId>jenkins-job-builder</applicationId>
|
||||
</applicationSelectType>
|
||||
<pathConfig>
|
||||
<scanTargets/>
|
||||
<moduleExcludes/>
|
||||
<scanProperties/>
|
||||
</pathConfig>
|
||||
<failOnClmServerFailures>false</failOnClmServerFailures>
|
||||
<stageId>build</stageId>
|
||||
<username/>
|
||||
<password/>
|
||||
</com.sonatype.insight.ci.hudson.PreBuildScan>
|
||||
</builders>
|
||||
</project>
|
3
tests/builders/fixtures/sonatype-clm-minimal.yaml
Normal file
3
tests/builders/fixtures/sonatype-clm-minimal.yaml
Normal file
@ -0,0 +1,3 @@
|
||||
builders:
|
||||
- sonatype-clm:
|
||||
application-name: jenkins-job-builder
|
Loading…
Reference in New Issue
Block a user