Add FindBugs support to Publishers

FindBugs can also be configured as a publisher in non-Maven job types.
This work is a follow up to previous work from:

    https://review.openstack.org/#/c/153911/

- Adds support for configuring findbugs from a publisher context
- Move FindBugs specific options into a findbugs_settings() helper
  function

Change-Id: I1bead8b8ade4288243180c19435da9bb51b2a0df
Signed-off-by: Thanh Ha <thanh.ha@linuxfoundation.org>
This commit is contained in:
Thanh Ha 2015-03-16 22:00:11 -04:00
parent 0aa95b4891
commit bce1eead19
No known key found for this signature in database
GPG Key ID: B0CB27E00DA095AA
6 changed files with 165 additions and 12 deletions

View File

@ -137,3 +137,17 @@ def config_file_provider_settings(xml_parent, data):
else:
XML.SubElement(xml_parent, 'globalSettings',
{'class': settings['default-global-settings']})
def findbugs_settings(xml_parent, data):
# General Options
rank_priority = str(data.get('rank-priority', False)).lower()
XML.SubElement(xml_parent, 'isRankActivated').text = rank_priority
include_files = data.get('include-files', '')
XML.SubElement(xml_parent, 'includePattern').text = include_files
exclude_files = data.get('exclude-files', '')
XML.SubElement(xml_parent, 'excludePattern').text = exclude_files
use_previous_build = str(data.get('use-previous-build-as-reference',
False)).lower()
XML.SubElement(xml_parent,
'usePreviousBuildAsReference').text = use_previous_build

View File

@ -30,6 +30,7 @@ import xml.etree.ElementTree as XML
import jenkins_jobs.modules.base
from jenkins_jobs.modules import hudson_model
from jenkins_jobs.modules.helpers import build_trends_publisher
from jenkins_jobs.modules.helpers import findbugs_settings
from jenkins_jobs.errors import JenkinsJobsException
import logging
import pkg_resources
@ -1060,6 +1061,77 @@ def violations(parser, xml_parent, data):
XML.SubElement(config, 'encoding').text = 'default'
def findbugs(parser, xml_parent, data):
"""yaml: findbugs
FindBugs reporting for builds
Requires the Jenkins :jenkins-wiki:`FindBugs Plugin
<FindBugs+Plugin>`.
:arg str pattern: specifies the generated raw FindBugs XML report files,
such as \*\*/findbugs.xml or \*\*/findbugsXml.xml.
(Optional)
:arg bool rank-priority: Use rank as priority (default: false)
:arg str include-files: Comma separated list of files to include.
(Optional)
:arg str exclude-files: Comma separated list of files to exclude.
(Optional)
:arg bool can-run-on-failed: Weather or not to run plug-in on failed builds
(default: false)
:arg bool should-detect-modules: Determines if Ant or Maven modules should
be detected for all files that contain
warnings. (default: false)
:arg int healthy: Sunny threshold (optional)
:arg int unhealthy: Stormy threshold (optional)
:arg str health-threshold: Threshold priority for health status
('low', 'normal' or 'high', defaulted to 'low')
:arg bool dont-compute-new: If set to false, computes new warnings based on
the reference build (default true)
:arg bool use-delta-values: Use delta for new warnings. (Default: false)
:arg bool use-previous-build-as-reference: If set then the number of new
warnings will always be calculated based on the previous build. Otherwise
the reference build. (Default: false)
:arg bool use-stable-build-as-reference: The number of new warnings will be
calculated based on the last stable build, allowing reverts of unstable
builds where the number of warnings was decreased. (default false)
:arg dict thresholds:
:thresholds:
* **unstable** (`dict`)
:unstable: * **total-all** (`int`)
* **total-high** (`int`)
* **total-normal** (`int`)
* **total-low** (`int`)
* **new-all** (`int`)
* **new-high** (`int`)
* **new-normal** (`int`)
* **new-low** (`int`)
* **failed** (`dict`)
:failed: * **total-all** (`int`)
* **total-high** (`int`)
* **total-normal** (`int`)
* **total-low** (`int`)
* **new-all** (`int`)
* **new-high** (`int`)
* **new-normal** (`int`)
* **new-low** (`int`)
Minimal Example:
.. literalinclude:: /../../tests/reporters/fixtures/findbugs-minimal.yaml
Full Example:
.. literalinclude:: /../../tests/publishers/fixtures/findbugs01.yaml
"""
findbugs = XML.SubElement(xml_parent,
'hudson.plugins.findbugs.FindBugsPublisher')
findbugs.set('plugin', 'findbugs')
findbugs_settings(findbugs, data)
build_trends_publisher('[FINDBUGS] ', findbugs, data)
def checkstyle(parser, xml_parent, data):
"""yaml: checkstyle
Publish trend reports with Checkstyle.

View File

@ -35,6 +35,7 @@ Example::
import xml.etree.ElementTree as XML
import jenkins_jobs.modules.base
from jenkins_jobs.modules.helpers import build_trends_publisher
from jenkins_jobs.modules.helpers import findbugs_settings
from jenkins_jobs.errors import JenkinsJobsException
@ -132,18 +133,7 @@ def findbugs(parser, xml_parent, data):
'hudson.plugins.findbugs.FindBugsReporter')
findbugs.set('plugin', 'findbugs')
# General Options
rank_priority = str(data.get('rank-priority', False)).lower()
XML.SubElement(findbugs, 'isRankActivated').text = rank_priority
include_files = data.get('include-files', '')
XML.SubElement(findbugs, 'includePattern').text = include_files
exclude_files = data.get('exclude-files', '')
XML.SubElement(findbugs, 'excludePattern').text = exclude_files
use_previous_build = str(data.get('use-previous-build-as-reference',
False)).lower()
XML.SubElement(findbugs,
'usePreviousBuildAsReference').text = use_previous_build
findbugs_settings(findbugs, data)
build_trends_publisher('[FINDBUGS] ', findbugs, data)

View File

@ -142,6 +142,7 @@ jenkins_jobs.publishers =
email-ext=jenkins_jobs.modules.publishers:email_ext
email=jenkins_jobs.modules.publishers:email
emotional-jenkins=jenkins_jobs.modules.publishers:emotional_jenkins
findbugs=jenkins_jobs.modules.publishers:findbugs
fingerprint=jenkins_jobs.modules.publishers:fingerprint
fitnesse=jenkins_jobs.modules.publishers:fitnesse
ftp=jenkins_jobs.modules.publishers:ftp

View File

@ -0,0 +1,41 @@
<?xml version="1.0" encoding="utf-8"?>
<project>
<publishers>
<hudson.plugins.findbugs.FindBugsPublisher plugin="findbugs">
<isRankActivated>true</isRankActivated>
<includePattern>f,d,e,.*</includePattern>
<excludePattern>a,c,d,.*</excludePattern>
<usePreviousBuildAsReference>true</usePreviousBuildAsReference>
<healthy>80</healthy>
<unHealthy>10</unHealthy>
<thresholdLimit>high</thresholdLimit>
<pluginName>[FINDBUGS] </pluginName>
<defaultEncoding/>
<canRunOnFailed>true</canRunOnFailed>
<useStableBuildAsReference>true</useStableBuildAsReference>
<useDeltaValues>true</useDeltaValues>
<thresholds>
<unstableTotalAll>90</unstableTotalAll>
<unstableTotalHigh>80</unstableTotalHigh>
<unstableTotalNormal>50</unstableTotalNormal>
<unstableTotalLow>20</unstableTotalLow>
<unstableNewAll>95</unstableNewAll>
<unstableNewHigh>85</unstableNewHigh>
<unstableNewNormal>55</unstableNewNormal>
<unstableNewLow>25</unstableNewLow>
<failedTotalAll>80</failedTotalAll>
<failedTotalHigh>70</failedTotalHigh>
<failedTotalNormal>40</failedTotalNormal>
<failedTotalLow>10</failedTotalLow>
<failedNewAll>85</failedNewAll>
<failedNewHigh>75</failedNewHigh>
<failedNewNormal>45</failedNewNormal>
<failedNewLow>15</failedNewLow>
</thresholds>
<shouldDetectModules>true</shouldDetectModules>
<dontComputeNew>false</dontComputeNew>
<doNotResolveRelativePaths>false</doNotResolveRelativePaths>
<pattern>**/findbugs.xml</pattern>
</hudson.plugins.findbugs.FindBugsPublisher>
</publishers>
</project>

View File

@ -0,0 +1,35 @@
publishers:
- findbugs:
pattern: '**/findbugs.xml'
rank-priority: true
include-files: 'f,d,e,.*'
exclude-files: 'a,c,d,.*'
can-run-on-failed: true
should-detect-modules: true
healthy: 80
unhealthy: 10
use-delta-values: true
health-threshold: 'high'
thresholds:
unstable:
total-all: 90
total-high: 80
total-normal: 50
total-low: 20
new-all: 95
new-high: 85
new-normal: 55
new-low: 25
failed:
total-all: 80
total-high: 70
total-normal: 40
total-low: 10
new-all: 85
new-high: 75
new-normal: 45
new-low: 15
dont-compute-new: false
use-delta-values: true
use-previous-build-as-reference: true
use-stable-build-as-reference: true