This is an automated email from the ASF dual-hosted git repository. ikamga pushed a commit to branch develop in repository https://gitbox.apache.org/repos/asf/fineract-cn-template.git
commit ae271bbce46d30afdfb8a1537193d3df944d7b19 Author: Juhan Aasaru <[email protected]> AuthorDate: Thu Apr 25 14:23:38 2019 +0300 FINCN-148 build with travis-ci.com and upload artifacts to Artifactory --- .travis.yml | 30 +++++++++++++++++++ README.md | 7 ++++- api/build.gradle | 3 +- build.gradle | 8 +++++ component-test/build.gradle | 4 ++- service/build.gradle | 5 ++-- shared.gradle | 18 ++++++++++++ travis.sh | 71 +++++++++++++++++++++++++++++++++++++++++++++ 8 files changed, 141 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..2a53f56 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,30 @@ +# +# 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. +# +language: java +sudo: false +jdk: +- openjdk8 +install: true +script: "./travis.sh" +env: + global: + - BUILD_SNAPSHOTS_BRANCH=develop + - ARTIFACTORY_URL=https://mifos.jfrog.io/mifos + - ARTIFACTORY_USER=travis-ci + - secure: "WO+UUvMOFTGl93jGbGPLj60fJq8+Gqei9Jx4j9t2OAuz1fTgVwa11VL4Zf51lgbXmy3YoxIn+hoXOdEDTfmMyGW5Y0cG5YbqUve/WII1nJJo5dc7hPf3z4HmsxHYfTRedk4ZnhFH8FDrjPzls4K+VVJuF7X92aUfZbVSuL97gbNXjvhftdWbko6xn+ZLw4HZwQfGDpCRwbqEq7WH2e900lL49QnBM7majONr/nf6mVuyomZvDJaRTDPLh9VXlwJ6hQ1WsajYbH6dCd3CgbAceKb9R7nF0dxMpxPVu3piz9zL9NXXNWqwIifJeJX5U9HT6i7ze5JnzUbBCD9iV0jGj1HGoYTKqKd78Z1K8uOdZxykAspA2Doz2ABQHctPJLNlkkWqagyrMNJmRlJMGVluOpStOIyw7d5GMelmzl16nZfdO0uz+zL56oJtke+G+Ur+ZEiZiHOLweM1/rO/60QxG31qZWsRH [...] diff --git a/README.md b/README.md index 0c955ed..65b1413 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# Apache Fineract CN Template +# Apache Fineract CN Template [](https://travis-ci.com/apache/fineract-cn-template) This project provides a template layout for all Apache Fineract CN services. @@ -43,6 +43,11 @@ Apache Fineract CN is an application framework for digital financial services, a 15. Happy coding! ; o) +16. For Travis-ci.com continuous integration server to start uploading artifacts to Artifactory + you need to put into .travis.yml a password that is encrypted with public key of https://travis-ci.com/apache/fineract-cn-newRepositoryNameInGithub +See [project wiki](https://cwiki.apache.org/confluence/display/FINERACT/Fineract+CN+Project+Structure). + + ## Versioning The version numbers follow the [Semantic Versioning](http://semver.org/) scheme. diff --git a/api/build.gradle b/api/build.gradle index 5b9924a..a11f487 100644 --- a/api/build.gradle +++ b/api/build.gradle @@ -28,6 +28,7 @@ buildscript { plugins { id "com.github.hierynomus.license" version "0.13.1" id("org.nosphere.apache.rat") version "0.3.1" + id "com.jfrog.artifactory" version "4.9.5" } apply from: '../shared.gradle' @@ -51,7 +52,7 @@ publishing { from components.java groupId project.group artifactId project.name - version project.version + version project.findProperty('externalVersion') ?: project.version } } } diff --git a/build.gradle b/build.gradle index 848847a..eeb68fb 100644 --- a/build.gradle +++ b/build.gradle @@ -39,6 +39,14 @@ task publishToMavenLocal { dependsOn publishComponentTestToMavenLocal } +task artifactoryPublish { + group 'all' + dependsOn publishToMavenLocal + dependsOn gradle.includedBuild('api').task(':artifactoryPublish') + dependsOn gradle.includedBuild('service').task(':artifactoryPublish') + dependsOn gradle.includedBuild('component-test').task(':artifactoryPublish') +} + task prepareForTest { group 'all' dependsOn publishToMavenLocal diff --git a/component-test/build.gradle b/component-test/build.gradle index 8611ca8..2e2e1eb 100644 --- a/component-test/build.gradle +++ b/component-test/build.gradle @@ -32,6 +32,7 @@ buildscript { plugins { id "com.github.hierynomus.license" version "0.13.1" id("org.nosphere.apache.rat") version "0.3.1" + id "com.jfrog.artifactory" version "4.9.5" } apply from: '../shared.gradle' @@ -49,8 +50,9 @@ dependencies { publishing { publications { - mavenJava(MavenPublication) { + componentTest(MavenPublication) { from components.java + version project.findProperty('externalVersion') ?: project.version } } } diff --git a/service/build.gradle b/service/build.gradle index 23acde2..2b90588 100644 --- a/service/build.gradle +++ b/service/build.gradle @@ -32,6 +32,7 @@ buildscript { plugins { id "com.github.hierynomus.license" version "0.13.1" id("org.nosphere.apache.rat") version "0.3.1" + id "com.jfrog.artifactory" version "4.9.5" } apply from: '../shared.gradle' @@ -68,14 +69,14 @@ publishing { from components.java groupId project.group artifactId project.name - version project.version + version project.findProperty('externalVersion') ?: project.version } bootService(MavenPublication) { // "boot" jar artifact ("$buildDir/libs/$project.name-$version-boot.jar") groupId project.group artifactId ("$project.name-boot") - version project.version + version project.findProperty('externalVersion') ?: project.version } } } diff --git a/shared.gradle b/shared.gradle index 31ee3aa..372caf0 100644 --- a/shared.gradle +++ b/shared.gradle @@ -43,6 +43,7 @@ tasks.withType(JavaCompile) { repositories { jcenter() mavenLocal() + maven { url 'https://mifos.jfrog.io/mifos/libs-snapshot/' } } dependencyManagement { @@ -73,6 +74,23 @@ jar { duplicatesStrategy = DuplicatesStrategy.EXCLUDE } +artifactory { + contextUrl = System.getenv("ARTIFACTORY_URL") + publish { + repository { + repoKey = project.findProperty('artifactoryRepoKey') + username = System.getenv("ARTIFACTORY_USER") + password = System.getenv("ARTIFACTORY_PASSWORD") + } + + defaults { + publications ('api', 'componentTest', 'service', 'bootService') + } + } +} +artifactoryPublish.dependsOn('clean','publishToMavenLocal') + + license { header rootProject.file('../HEADER') strictCheck true diff --git a/travis.sh b/travis.sh new file mode 100755 index 0000000..03a75ee --- /dev/null +++ b/travis.sh @@ -0,0 +1,71 @@ +#!/usr/bin/env bash +# +# 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. +# + +# Documentation: https://cwiki.apache.org/confluence/display/FINERACT/Fineract-CN+Artifactory + +#Exit immediately if a command exits with a non-zero status. +set -e +EXIT_STATUS=0 + +# Builds and Publishes a SNAPSHOT +function build_snapshot() { + echo -e "Building and publishing a snapshot out of branch [$TRAVIS_BRANCH]" + ./gradlew -PartifactoryRepoKey=libs-snapshot-local -DbuildInfo.build.number=${TRAVIS_COMMIT::7} artifactoryPublish --stacktrace || EXIT_STATUS=$? +} + +# Builds a Pull Request +function build_pullrequest() { + echo -e "Building pull request #$TRAVIS_PULL_REQUEST of branch [$TRAVIS_BRANCH]. Won't publish anything to Artifactory." + ./gradlew publishToMavenLocal rat || EXIT_STATUS=$? +} + +# For other branches we need to add branch name as prefix +function build_otherbranch() { + echo -e "Building a snapshot out of branch [$TRAVIS_BRANCH] and publishing it with prefix '${TRAVIS_BRANCH}-SNAPSHOT'" + ./gradlew -PartifactoryRepoKey=libs-snapshot-local -DbuildInfo.build.number=${TRAVIS_COMMIT::7} -PexternalVersion=${TRAVIS_BRANCH}-SNAPSHOT artifactoryPublish --stacktrace || EXIT_STATUS=$? +} + +# Builds and Publishes a Tag +function build_tag() { + echo -e "Building tag [$TRAVIS_TAG] and publishing it as a release" + ./gradlew -PartifactoryRepoKey=libs-release-local -PexternalVersion=$TRAVIS_TAG artifactoryPublish --stacktrace || EXIT_STATUS=$? + +} + +echo -e "TRAVIS_BRANCH=$TRAVIS_BRANCH" +echo -e "TRAVIS_TAG=$TRAVIS_TAG" +echo -e "TRAVIS_COMMIT=${TRAVIS_COMMIT::7}" +echo -e "TRAVIS_PULL_REQUEST=$TRAVIS_PULL_REQUEST" + +# Build Logic +if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then + build_pullrequest +elif [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$TRAVIS_BRANCH" != "$BUILD_SNAPSHOTS_BRANCH" ] && [ "$TRAVIS_TAG" == "" ] ; then + build_otherbranch +elif [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$TRAVIS_BRANCH" == "$BUILD_SNAPSHOTS_BRANCH" ] && [ "$TRAVIS_TAG" == "" ] ; then + build_snapshot +elif [ "$TRAVIS_PULL_REQUEST" == "false" ] && [ "$TRAVIS_TAG" != "" ]; then + build_tag +else + echo -e "WARN: Unexpected env variable values => Branch [$TRAVIS_BRANCH], Tag [$TRAVIS_TAG], Pull Request [#$TRAVIS_PULL_REQUEST]" + ./gradlew clean build +fi + +exit ${EXIT_STATUS}
