2019-01-08 21:53:37 +01:00
|
|
|
/**
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
|
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
node("ubuntu") {
|
|
|
|
docker.image('elek/ozone-build').pull()
|
2019-02-14 23:33:25 -08:00
|
|
|
docker.image('elek/ozone-build').inside("--privileged") {
|
2019-01-08 21:53:37 +01:00
|
|
|
|
|
|
|
stage('Checkout') {
|
|
|
|
checkout scm
|
2019-02-14 23:33:25 -08:00
|
|
|
//use this for external Jenkinsfile builds
|
|
|
|
//checkout poll: false, scm: [$class: 'GitSCM', branches: [[name: env.branch]], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'github-token', url: "https://github.com/${organization}/${repository}.git"]]]
|
|
|
|
|
2019-01-08 21:53:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
stage('Clean') {
|
2019-02-14 23:33:25 -08:00
|
|
|
status = sh returnStatus: true, script: 'mvn clean -P hdds -am -pl :hadoop-ozone-dist '
|
2019-01-08 21:53:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
stageRunner('Author', "author", {})
|
|
|
|
|
|
|
|
stageRunner('Licence', "rat", {
|
|
|
|
archiveArtifacts 'target/rat-aggregated.txt'
|
|
|
|
}, 'artifact/target/rat-aggregated.txt/*view*/')
|
|
|
|
|
2019-02-14 23:33:25 -08:00
|
|
|
stageRunner('Build', "build", {})
|
2019-01-08 21:53:37 +01:00
|
|
|
|
|
|
|
stageRunner('Findbugs', "findbugs", {
|
|
|
|
archiveArtifacts 'target/findbugs-all.txt'
|
|
|
|
|
|
|
|
}, 'artifact/target/findbugs-all.txt/*view*/')
|
|
|
|
|
|
|
|
stageRunner('Checkstyle', "checkstyle", {
|
2019-02-14 23:33:25 -08:00
|
|
|
checkstyle canComputeNew: false, canRunOnFailed: true, defaultEncoding: '', healthy: '', pattern: '**/checkstyle-errors.xml', unHealthy: ''
|
2019-01-08 21:53:37 +01:00
|
|
|
}, 'checkstyleResult')
|
|
|
|
|
2019-02-14 23:33:25 -08:00
|
|
|
stageRunner('Acceptance', "acceptance", {
|
|
|
|
archiveArtifacts 'hadoop-ozone/dist/target/ozone-0.4.0-SNAPSHOT/smoketest/result/**'
|
|
|
|
})
|
|
|
|
|
|
|
|
stageRunner('Unit test', "unit", {
|
|
|
|
junit '**/target/surefire-reports/*.xml'
|
|
|
|
}, 'testReport/')
|
|
|
|
|
2019-01-08 21:53:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
def stageRunner(name, type, processResult, url = '') {
|
|
|
|
try {
|
|
|
|
stage(name) {
|
|
|
|
prStatusStart(type)
|
|
|
|
status = sh returnStatus: true, script: 'hadoop-ozone/dev-support/checks/' + type + '.sh'
|
|
|
|
processResult()
|
|
|
|
prStatusResult(status, type, url)
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
} catch (RuntimeException ex) {
|
|
|
|
currentBuild.result = "FAILED"
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-14 23:33:25 -08:00
|
|
|
def githubStatus(name, status, description, url='') {
|
|
|
|
commitId = sh(returnStdout: true, script: 'git rev-parse HEAD')
|
|
|
|
context = 'ci/ozone/' + name
|
|
|
|
if (url) {
|
|
|
|
githubNotify account: 'apache', context: context, credentialsId: 'github-pr-ozone', description: description, repo: 'hadoop', sha: commitId, status: status, targetUrl: url
|
|
|
|
} else {
|
|
|
|
githubNotify account: 'apache', context: context, credentialsId: 'github-pr-ozone', description: description, repo: 'hadoop', sha: commitId, status: status
|
|
|
|
}
|
|
|
|
}
|
2019-01-08 21:53:37 +01:00
|
|
|
def prStatusStart(name) {
|
2019-02-14 23:33:25 -08:00
|
|
|
githubStatus(name,
|
|
|
|
"PENDING",
|
|
|
|
name + " is started")
|
|
|
|
|
|
|
|
|
2019-01-08 21:53:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
def prStatusResult(responseCode, name, url = '') {
|
2019-02-14 23:33:25 -08:00
|
|
|
status = "ERROR"
|
2019-01-08 21:53:37 +01:00
|
|
|
desc = "failed"
|
|
|
|
if (responseCode == 0) {
|
2019-02-14 23:33:25 -08:00
|
|
|
status = "SUCCESS"
|
2019-01-08 21:53:37 +01:00
|
|
|
desc = "passed"
|
|
|
|
}
|
2019-02-14 23:33:25 -08:00
|
|
|
message = name + " check is " + desc
|
2019-01-08 21:53:37 +01:00
|
|
|
if (url) {
|
2019-02-14 23:33:25 -08:00
|
|
|
githubStatus(name,
|
|
|
|
status,
|
|
|
|
message,
|
|
|
|
env.BUILD_URL + url)
|
2019-01-08 21:53:37 +01:00
|
|
|
} else {
|
2019-02-14 23:33:25 -08:00
|
|
|
githubStatus(name,
|
|
|
|
status,
|
|
|
|
message)
|
2019-01-08 21:53:37 +01:00
|
|
|
}
|
2019-02-14 23:33:25 -08:00
|
|
|
|
2019-01-08 21:53:37 +01:00
|
|
|
if (responseCode != 0) {
|
|
|
|
throw new RuntimeException(message)
|
|
|
|
}
|
|
|
|
}
|