blob: 21bf5afcb129a170ed83c6e6ed2beebce042fb51 [file] [log] [blame]
// Copyright 2017-present Open Networking Foundation
//
// Licensed 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.
def app = '${app}'
def version = '${version}'
def nextVersion = '${nextVersion}'
def branch = '${branch}'
def changeVersion(def newVersion) {
// TODO any other versions we need to account for?
sh 'mvn versions:set -DnewVersion=' + newVersion + ' versions:commit'
}
node ('master') {
stage ('Checkout code') {
cleanWs()
git branch: branch, url: 'ssh://jenkins@gerrit.opencord.org:29418/' + app
sh 'gitdir=$(git rev-parse --git-dir); scp -p -P 29418 jenkins@gerrit.opencord.org:hooks/commit-msg ${gitdir}/hooks/'
}
stage ('Move to release version') {
changeVersion(version)
sh 'git add -A && git commit -m "Release version ' + version + '"'
}
// This step is basically to test that everything still builds once the version has
// been bumped up before we start pushing things publicly
stage ('Build and Test') {
// TODO can we do this with clean .m2?
sh 'mvn clean install'
sh 'mvn javadoc:javadoc'
}
stage ('Push to Gerrit') {
sh 'git push origin HEAD:refs/for/' + branch
}
stage ('Wait for merge') {
timeout(time: 1, unit: 'HOURS') {
metadata = input id: 'release-build',
message: 'Go to Gerrit and merge the release patch',
submitter: 'jono,dbainbri'
}
}
stage ('Release to Maven Central') {
sh 'mvn -Prelease clean deploy'
}
stage ('Wait for release on Sonatype') {
timeout(time: 1, unit: 'HOURS') {
metadata = input id: 'release-build',
message: 'Go to Sonatype and release the artifacts',
submitter: 'jono,dbainbri'
}
}
stage ('Tag the release') {
sh 'git tag -a ' + version + ' -m "Tagging version ' + version + '"'
sh 'git push origin ' + version
}
stage ('Move to next SNAPSHOT version') {
def snapshot = nextVersion + '-SNAPSHOT'
changeVersion(snapshot)
sh 'git add -A && git commit -m "Starting snapshot ' + snapshot + '"'
sh 'git push origin HEAD:refs/for/' + branch
}
stage ('Finish') {
sh 'echo "Released new app. Go to Gerrit and merge snapshot version bump"'
}
}