mirror of https://github.com/apache/poi.git
Add Jenkins DSL for JDK 9, Maven, regenerate-javadoc, API-Check, Gradle, no-scratchpad and old-xerces
Adjust script and refactor to reuse more stuff Add a workaround for properties git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1772263 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
2429573d75
commit
295197bd49
|
@ -1,16 +1,12 @@
|
||||||
// You can use http://job-dsl.herokuapp.com/ to validate the code before checkin
|
// You can use http://job-dsl.herokuapp.com/ to validate the code before checkin
|
||||||
//
|
//
|
||||||
|
|
||||||
// Missing configs:
|
// POI-JDK-IBM: This config was not enabled in Jenkins ever because we did not find the JDK on any of the slaves, we can check this again later
|
||||||
//
|
|
||||||
// POI-JDK-IBM: Disabled, did not find the JDK on any of the slaves, need to check this again later
|
|
||||||
|
|
||||||
/* Missing configs:
|
def triggerSundays = '''
|
||||||
Erfolgreich 20% Build planen für POI-API-Check
|
# only run this once per week on Sundays
|
||||||
Erfolgreich 100% Build planen für POI-Gradle
|
H H * * 0
|
||||||
Erfolgreich 100% Build planen für POI-Maven
|
'''
|
||||||
Erfolgreich 100% Build planen für POI-regenerate-javadoc
|
|
||||||
*/
|
|
||||||
|
|
||||||
def poijobs = [
|
def poijobs = [
|
||||||
[
|
[
|
||||||
|
@ -27,40 +23,55 @@ def poijobs = [
|
||||||
jdks: ["OpenJDK"],
|
jdks: ["OpenJDK"],
|
||||||
trigger: 'H */12 * * *'
|
trigger: 'H */12 * * *'
|
||||||
],
|
],
|
||||||
/* Properties do not work?!
|
|
||||||
[
|
[
|
||||||
name: 'POI-DSL-1.9',
|
name: 'POI-DSL-1.9',
|
||||||
jdks: ["1.9"],
|
jdks: ["1.9"],
|
||||||
trigger: '# only run this once per week on Sundays\n' +
|
trigger: triggerSundays,
|
||||||
'H H * * 0',
|
properties: ['-Dmaxpermsize=-Dthis.is.a.dummy=true', '-Djava9addmods=-addmods', '-Djava9addmodsvalue=java.xml.bind', '-Djava.locale.providers=JRE,CLDR'],
|
||||||
properties: 'maxpermsize=-Dthis.is.a.dummy=true\n' +
|
|
||||||
'java9addmods=-addmods\n' +
|
|
||||||
'java9addmodsvalue=java.xml.bind\n' +
|
|
||||||
'java.locale.providers=JRE,CLDR',
|
|
||||||
email: 'centic@apache.org'
|
email: 'centic@apache.org'
|
||||||
],*/
|
],
|
||||||
/* Properties do not work?!
|
|
||||||
[
|
[
|
||||||
name: 'POI-DSL-old-Xerces',
|
name: 'POI-DSL-old-Xerces',
|
||||||
jdks: ["1.9"],
|
jdks: ["1.9"],
|
||||||
trigger: '# only run this once per week on Sundays\n' +
|
trigger: triggerSundays,
|
||||||
'H H * * 0',
|
|
||||||
shell: 'mkdir -p compile-lib && test -f compile-lib/xercesImpl-2.6.1.jar || wget -O compile-lib/xercesImpl-2.6.1.jar http://repo1.maven.org/maven2/xerces/xercesImpl/2.6.1/xercesImpl-2.6.1.jar\n',
|
shell: 'mkdir -p compile-lib && test -f compile-lib/xercesImpl-2.6.1.jar || wget -O compile-lib/xercesImpl-2.6.1.jar http://repo1.maven.org/maven2/xerces/xercesImpl/2.6.1/xercesImpl-2.6.1.jar\n',
|
||||||
properties: '# this triggers using Xerces as XML Parser and previously showed some exception that can occur\n' +
|
// the property triggers using Xerces as XML Parser and previously showed some exception that can occur
|
||||||
'additionaljar=compile-lib/xercesImpl-2.6.1.jar'
|
properties: ['-Dadditionaljar=compile-lib/xercesImpl-2.6.1.jar']
|
||||||
],*/
|
],
|
||||||
/* Not finished yet
|
[
|
||||||
|
name: 'POI-DSL-Maven',
|
||||||
|
trigger: 'H */4 * * *',
|
||||||
|
maven: true
|
||||||
|
],
|
||||||
|
[
|
||||||
|
name: 'POI-DSL-regenerate-javadoc',
|
||||||
|
trigger: triggerSundays,
|
||||||
|
javadoc: true
|
||||||
|
],
|
||||||
|
[
|
||||||
|
name: 'POI-DSL-API-Check',
|
||||||
|
trigger: '@daily',
|
||||||
|
apicheck: true
|
||||||
|
],
|
||||||
|
[
|
||||||
|
name: 'POI-DSL-Gradle',
|
||||||
|
jdks: ["1.7"],
|
||||||
|
trigger: triggerSundays,
|
||||||
|
email: 'centic@apache.org',
|
||||||
|
gradle: true
|
||||||
|
],
|
||||||
[
|
[
|
||||||
name: 'POI-DSL-no-scratchpad',
|
name: 'POI-DSL-no-scratchpad',
|
||||||
trigger: '# only run this once per week on Sundays\n' +
|
trigger: triggerSundays,
|
||||||
'H H * * 0',
|
noScratchpad: true
|
||||||
],*/
|
],
|
||||||
]
|
]
|
||||||
|
|
||||||
def svnBase = "https://svn.apache.org/repos/asf/poi/trunk"
|
def svnBase = "https://svn.apache.org/repos/asf/poi/trunk"
|
||||||
def defaultJdks = ["1.6"]
|
def defaultJdks = ["1.6"]
|
||||||
def defaultTrigger = 'H/15 * * * *'
|
def defaultTrigger = 'H/15 * * * *'
|
||||||
def defaultEmail = 'dev@poi.apache.org'
|
def defaultEmail = 'dev@poi.apache.org'
|
||||||
|
def defaultAnt = 'Ant (latest)'
|
||||||
|
|
||||||
def jdkMapping = [
|
def jdkMapping = [
|
||||||
"1.6": "JDK 1.6 (latest)",
|
"1.6": "JDK 1.6 (latest)",
|
||||||
|
@ -81,21 +92,23 @@ poijobs.each { poijob ->
|
||||||
// for now we create the jobs in disabled state so they do not run for now
|
// for now we create the jobs in disabled state so they do not run for now
|
||||||
disabled()
|
disabled()
|
||||||
|
|
||||||
description('<img src="http://poi.apache.org/resources/images/project-logo.jpg" />\n' +
|
description('''
|
||||||
'<p>\n' +
|
<img src="http://poi.apache.org/resources/images/project-logo.jpg" />
|
||||||
'Apache POI - the Java API for Microsoft Documents\n' +
|
<p>
|
||||||
'</p>\n' +
|
Apache POI - the Java API for Microsoft Documents
|
||||||
'<p>\n' +
|
</p>
|
||||||
' <b>This is an automatically generated Job Config, do not edit it here!\n' +
|
<p>
|
||||||
' Instead change the Jenkins Job DSL at <a href="http://svn.apache.org/repos/asf/poi/trunk/jenkins">http://svn.apache.org/repos/asf/poi/trunk/jenkins</a>,\n' +
|
<b>This is an automatically generated Job Config, do not edit it here!
|
||||||
' see <a href="https://github.com/jenkinsci/job-dsl-plugin/wiki">https://github.com/jenkinsci/job-dsl-plugin/wiki</a>\n' +
|
Instead change the Jenkins Job DSL at <a href="http://svn.apache.org/repos/asf/poi/trunk/jenkins">http://svn.apache.org/repos/asf/poi/trunk/jenkins</a>,
|
||||||
' for more details about the DSL.</b>\n' +
|
see <a href="https://github.com/jenkinsci/job-dsl-plugin/wiki">https://github.com/jenkinsci/job-dsl-plugin/wiki</a>
|
||||||
'</p>\n' +
|
for more details about the DSL.</b>
|
||||||
'<p>\n' +
|
</p>
|
||||||
' <b><a href="lastSuccessfulBuild/findbugsResult/" target="_blank">Findbugs report of latest build</a></b> -\n' +
|
<p>
|
||||||
' <b><a href="https://analysis.apache.org/dashboard/index/221489" target="_blank">Sonar reports</a></b> -\n' +
|
<b><a href="lastSuccessfulBuild/findbugsResult/" target="_blank">Findbugs report of latest build</a></b> -
|
||||||
' <b><a href="lastSuccessfulBuild/artifact/build/coverage/index.html" target="_blank">Coverage of latest build</a></b>\n' +
|
<b><a href="https://analysis.apache.org/dashboard/index/221489" target="_blank">Sonar reports</a></b> -
|
||||||
'</p>\n')
|
<b><a href="lastSuccessfulBuild/artifact/build/coverage/index.html" target="_blank">Coverage of latest build</a></b>
|
||||||
|
</p>
|
||||||
|
''')
|
||||||
logRotator {
|
logRotator {
|
||||||
numToKeep(5)
|
numToKeep(5)
|
||||||
artifactNumToKeep(1)
|
artifactNumToKeep(1)
|
||||||
|
@ -121,8 +134,8 @@ poijobs.each { poijob ->
|
||||||
triggers {
|
triggers {
|
||||||
scm(trigger)
|
scm(trigger)
|
||||||
}
|
}
|
||||||
steps {
|
|
||||||
shell('# show which files are currently modified in the working copy\n' +
|
def shellcmds = '# show which files are currently modified in the working copy\n' +
|
||||||
'svn status\n' +
|
'svn status\n' +
|
||||||
'\n' +
|
'\n' +
|
||||||
'echo $JAVA_HOME\n' +
|
'echo $JAVA_HOME\n' +
|
||||||
|
@ -130,17 +143,106 @@ poijobs.each { poijob ->
|
||||||
'\n' +
|
'\n' +
|
||||||
(poijob.shell ?: '') + '\n' +
|
(poijob.shell ?: '') + '\n' +
|
||||||
'# ignore any error message\n' +
|
'# ignore any error message\n' +
|
||||||
'exit 0\n')
|
'exit 0\n'
|
||||||
|
|
||||||
|
// Create steps and publishers depending on the type of Job that is selected
|
||||||
|
if(poijob.maven) {
|
||||||
|
steps {
|
||||||
|
shell(shellcmds)
|
||||||
|
maven {
|
||||||
|
goals('clean')
|
||||||
|
rootPOM('sonar/pom.xml')
|
||||||
|
localRepository(LocalRepositoryLocation.LOCAL_TO_WORKSPACE)
|
||||||
|
mavenInstallation('maven-3.2.1')
|
||||||
|
}
|
||||||
|
/* Currently not done, let's see if it is still necessary:
|
||||||
|
# Maven-Download fails for strange reasons, try to workaround...
|
||||||
|
mkdir -p sonar/ooxml-schema-security/target/schemas && wget -O sonar/ooxml-schema-security/target/schemas/xmldsig-core-schema.xsd http://www.w3.org/TR/2002/REC-xmldsig-core-20020212/xmldsig-core-schema.xsd
|
||||||
|
*/
|
||||||
|
maven {
|
||||||
|
goals('package')
|
||||||
|
rootPOM('sonar/pom.xml')
|
||||||
|
mavenOpts('-Xmx2g')
|
||||||
|
mavenOpts('-Xms256m')
|
||||||
|
mavenOpts('-XX:MaxPermSize=512m')
|
||||||
|
mavenOpts('-XX:-OmitStackTraceInFastThrow')
|
||||||
|
localRepository(LocalRepositoryLocation.LOCAL_TO_WORKSPACE)
|
||||||
|
mavenInstallation('maven-3.2.1')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
publishers {
|
||||||
|
configure { project ->
|
||||||
|
project / publishers << 'hudson.plugins.cigame.GamePublisher' {}
|
||||||
|
}
|
||||||
|
mailer(email, false, false)
|
||||||
|
}
|
||||||
|
} else if (poijob.javadoc) {
|
||||||
|
steps {
|
||||||
|
shell(shellcmds)
|
||||||
ant {
|
ant {
|
||||||
targets(['clean', 'jenkins'])
|
targets(['clean', 'javadocs'] + (poijob.properties ?: []))
|
||||||
prop('coverage.enabled', true)
|
prop('coverage.enabled', true)
|
||||||
|
// Properties did not work, so I had to use targets instead
|
||||||
//properties(poijob.properties ?: '')
|
//properties(poijob.properties ?: '')
|
||||||
antInstallation('Ant (latest)')
|
antInstallation(defaultAnt)
|
||||||
|
}
|
||||||
|
shell('zip -r build/javadocs.zip build/tmp/site/build/site/apidocs')
|
||||||
|
}
|
||||||
|
publishers {
|
||||||
|
configure { project ->
|
||||||
|
project / publishers << 'hudson.plugins.cigame.GamePublisher' {}
|
||||||
|
}
|
||||||
|
mailer(email, false, false)
|
||||||
|
}
|
||||||
|
} else if (poijob.apicheck) {
|
||||||
|
steps {
|
||||||
|
shell(shellcmds)
|
||||||
|
gradle {
|
||||||
|
tasks('japicmp')
|
||||||
|
useWrapper(false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
publishers {
|
||||||
|
archiveArtifacts('build/*/build/reports/japi.html')
|
||||||
|
configure { project ->
|
||||||
|
project / publishers << 'hudson.plugins.cigame.GamePublisher' {}
|
||||||
|
}
|
||||||
|
mailer(email, false, false)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
steps {
|
||||||
|
shell(shellcmds)
|
||||||
|
// For Jobs that should still have the default set of publishers we can configure different steps here
|
||||||
|
if(poijob.gradle) {
|
||||||
|
gradle {
|
||||||
|
tasks('check')
|
||||||
|
useWrapper(false)
|
||||||
|
}
|
||||||
|
} else if (poijob.noScratchpad) {
|
||||||
|
ant {
|
||||||
|
targets(['clean', 'compile-all'] + (poijob.properties ?: []))
|
||||||
|
prop('coverage.enabled', true)
|
||||||
|
antInstallation(defaultAnt)
|
||||||
}
|
}
|
||||||
ant {
|
ant {
|
||||||
buildFile('src/integrationtest/build.xml')
|
targets(['-Dscratchpad.ignore=true', 'jacocotask', 'test-main', 'test-ooxml', 'test-excelant', 'test-ooxml-lite', 'testcoveragereport'] + (poijob.properties ?: []))
|
||||||
|
antInstallation(defaultAnt)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ant {
|
||||||
|
targets(['clean', 'jenkins'] + (poijob.properties ?: []))
|
||||||
|
prop('coverage.enabled', true)
|
||||||
|
// Properties did not work, so I had to use targets instead
|
||||||
//properties(poijob.properties ?: '')
|
//properties(poijob.properties ?: '')
|
||||||
antInstallation('Ant (latest)')
|
antInstallation(defaultAnt)
|
||||||
|
}
|
||||||
|
ant {
|
||||||
|
targets(['run'] + (poijob.properties ?: []))
|
||||||
|
buildFile('src/integrationtest/build.xml')
|
||||||
|
// Properties did not work, so I had to use targets instead
|
||||||
|
//properties(poijob.properties ?: '')
|
||||||
|
antInstallation(defaultAnt)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
publishers {
|
publishers {
|
||||||
|
@ -149,11 +251,11 @@ poijobs.each { poijob ->
|
||||||
thresholdLimit('low')
|
thresholdLimit('low')
|
||||||
defaultEncoding('UTF-8')
|
defaultEncoding('UTF-8')
|
||||||
}
|
}
|
||||||
archiveArtifacts('build/dist/*.tar.gz,build/findbugs.html,build/coverage/**,build/integration-test-results/**,ooxml-lib/**')
|
archiveArtifacts('build/dist/*.tar.gz,build/findbugs.html,build/coverage/**,build/integration-test-results/**,ooxml-lib/**,build/*/build/libs/*.jar')
|
||||||
warnings(['Java Compiler (javac)', 'JavaDoc Tool'], null) {
|
warnings(['Java Compiler (javac)', 'JavaDoc Tool'], null) {
|
||||||
resolveRelativePaths()
|
resolveRelativePaths()
|
||||||
}
|
}
|
||||||
archiveJunit('build/ooxml-test-results/*.xml,build/scratchpad-test-results/*.xml,build/test-results/*.xml,build/excelant-test-results/*.xml,build/integration-test-results/*.xml') {
|
archiveJunit('build/ooxml-test-results/*.xml,build/scratchpad-test-results/*.xml,build/test-results/*.xml,build/excelant-test-results/*.xml,build/integration-test-results/*.xml,build/*/build/test-results/TEST-*.xml') {
|
||||||
testDataPublishers {
|
testDataPublishers {
|
||||||
publishTestStabilityData()
|
publishTestStabilityData()
|
||||||
}
|
}
|
||||||
|
@ -167,7 +269,8 @@ poijobs.each { poijob ->
|
||||||
configure { project ->
|
configure { project ->
|
||||||
project / publishers << 'hudson.plugins.cigame.GamePublisher' {}
|
project / publishers << 'hudson.plugins.cigame.GamePublisher' {}
|
||||||
}
|
}
|
||||||
mailer('dev@poi.apache.org', false, false)
|
mailer(email, false, false)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue