From f2f76af7317b7c95a4dbda47784593d9b86c7c4f Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Sun, 2 Oct 2022 12:05:29 +0300 Subject: add Jenkinsfile --- Jenkinsfile | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 Jenkinsfile diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 00000000..dd8f6fb3 --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,54 @@ +pipeline { + agent any + + environment { + deploy_key = "srv.tt-rss.org" + deploy_host = "tt-rss.fakecake.org" + } + + stages { + stage('build') { + steps { + withCredentials([string(credentialsId: 'fdroid.jks', variable: 'FDROID_PASSWORD')]) { + sh("bash ./gradlew assembleFdroid " + + "-PFDROID_STORE_FILE=/var/jenkins_home/android-jks/fdroid.jks " + + "-PFDROID_STORE_PASSWORD=$FDROID_PASSWORD " + + "-PFDROID_KEY_ALIAS=fdroid " + + "-PFDROID_KEY_PASSWORD=$FDROID_PASSWORD") + } + } + } + stage('archive') { + steps { + archiveArtifacts '**/*.apk' + } + } + stage('deploy') { + when { + branch 'master' + } + steps { + sshagent(credentials: ["${deploy_key}"]) { + script { + def files = findFiles(glob: '**/*.apk') + + for (String file : files) { + sh("scp -oStrictHostKeyChecking=no ${file} ${deploy_host}:fdroid/repo/") + } + + sh("ssh -oStrictHostKeyChecking=no ${deploy_host} sudo /usr/local/sbin/fdroid-update-repo") + } + } + } + } + } + post { + failure { + mail body: "Project: ${env.JOB_NAME}
Build Number: ${env.BUILD_NUMBER}
build URL: ${env.BUILD_URL}", + charset: 'UTF-8', from: 'jenkins@fakecake.org', + mimeType: 'text/html', + subject: "Build failed: ${env.JOB_NAME}", + to: "fox@fakecake.org"; + } + } +} -- cgit v1.2.3