blob: 0055486368ded4a52613d7ea778f260dcffe77fa [file] [log] [blame]
/**
* 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()
docker.image('elek/ozone-build').inside("--privileged") {
stage('Checkout') {
checkout scm
//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"]]]
}
stage('Clean') {
status = sh returnStatus: true, script: 'mvn clean -P hdds -am -pl :hadoop-ozone-dist '
}
stageRunner('Author', "author", {})
stageRunner('Licence', "rat", {
archiveArtifacts 'target/rat-aggregated.txt'
}, 'artifact/target/rat-aggregated.txt/*view*/')
stageRunner('Build', "build", {})
stageRunner('Findbugs', "findbugs", {
archiveArtifacts 'target/findbugs-all.txt'
}, 'artifact/target/findbugs-all.txt/*view*/')
stageRunner('Checkstyle', "checkstyle", {
checkstyle canComputeNew: false, canRunOnFailed: true, defaultEncoding: '', healthy: '', pattern: '**/checkstyle-errors.xml', unHealthy: ''
}, 'checkstyleResult')
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/')
}
}
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
}
}
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
}
}
def prStatusStart(name) {
githubStatus(name,
"PENDING",
name + " is started")
}
def prStatusResult(responseCode, name, url = '') {
status = "ERROR"
desc = "failed"
if (responseCode == 0) {
status = "SUCCESS"
desc = "passed"
}
message = name + " check is " + desc
if (url) {
githubStatus(name,
status,
message,
env.BUILD_URL + url)
} else {
githubStatus(name,
status,
message)
}
if (responseCode != 0) {
throw new RuntimeException(message)
}
}