| /** |
| * 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) |
| } |
| } |