Use fastlane for diawi, Slack & GitHub comments

Signed-off-by: Igor Mandrigin <i@mandrigin.ru>
This commit is contained in:
Igor Mandrigin 2018-08-14 10:42:57 +02:00
parent edd87192d0
commit c99fd733e6
No known key found for this signature in database
GPG Key ID: 4A0EDDE26E66BC8B
6 changed files with 135 additions and 86 deletions

65
ci/Jenkinsfile vendored
View File

@ -53,7 +53,6 @@ timeout(90) {
sh 'mvn -f modules/react-native-status/ios/RCTStatus dependency:unpack' sh 'mvn -f modules/react-native-status/ios/RCTStatus dependency:unpack'
sh 'cd ios && pod install && cd ..' sh 'cd ios && pod install && cd ..'
} }
stage('Code style checks') { stage('Code style checks') {
sh 'lein cljfmt check' sh 'lein cljfmt check'
} }
@ -72,16 +71,12 @@ timeout(90) {
} }
stage('Deploy (Android)') { stage('Deploy (Android)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')] ) { withCredentials([
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/release/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
def hash = 'null' string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
for (int r = 0; r < 6 && hash == 'null'; r++) { string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
sh 'sleep 10' ]) {
hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() sh 'fastlane android upload_diawi'
}
apkUrl = 'https://i.diawi.com/' + hash
sh ('echo ARTIFACT Android: ' + apkUrl)
} }
} }
@ -101,28 +96,12 @@ timeout(90) {
} }
stage('Deploy (iOS)') { stage('Deploy (iOS)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) { withCredentials([
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status-adhoc/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
def hash = 'null' string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
for (int r = 0; r < 6 && hash == 'null'; r++) { string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
sh 'sleep 10' ]) {
hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() sh 'fastlane ios upload_diawi'
}
ipaUrl = 'https://i.diawi.com/' + hash
sh ('echo ARTIFACT iOS: ' + ipaUrl)
}
}
stage('Slack/GH Notifications') {
def c = (testPassed ? 'good' : 'warning' )
slackSend color: c, message: ('Branch: ' + BRANCH_NAME + '\nAndroid: ' + apkUrl + '\niOS: ' + ipaUrl);
withCredentials([string(credentialsId: 'GIT_HUB_TOKEN', variable: 'githubToken')]) {
def commentMsg = ("branch " + BRANCH_NAME + ":\\napk uploaded to " + apkUrl + "\\nipa uploaded to " + ipaUrl)
def ghOutput = sh(returnStdout: true, script: "curl -u status-im:" + githubToken + " -H 'Content-Type: application/json' --data '{\"body\": \"" + commentMsg + "\"}' https://api.github.com/repos/status-im/status-react/issues/" + CHANGE_ID + "/comments")
println("Result of github comment curl: " + ghOutput);
} }
} }
@ -132,18 +111,22 @@ timeout(90) {
} }
stage('Upload apk for e2e tests') { stage('Upload apk for e2e tests') {
if (env.CHANGE_ID != null){ if (env.CHANGE_ID != null) {
withCredentials([string(credentialsId: 'SAUCE_ACCESS_KEY', variable: 'key'), string(credentialsId: 'SAUCE_USERNAME', variable: 'username')]){
withCredentials([
string(credentialsId: 'SAUCE_ACCESS_KEY', variable: 'key'),
string(credentialsId: 'SAUCE_USERNAME', variable: 'username')
]) {
def apk_name = env.CHANGE_ID + '.apk' def apk_name = env.CHANGE_ID + '.apk'
sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk') sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk')
} }
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/release/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
sh 'sleep 10'
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim()
apkUrl = 'https://i.diawi.com/' + hash
sh ('echo ARTIFACT Android for e2e tests: ' + apkUrl) withCredentials([
string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
]) {
sh 'fastlane android upload_diawi'
} }
} }
} }

View File

@ -123,13 +123,12 @@ timeout(90) {
} }
stage('Deploy diawi (iOS)') { stage('Deploy diawi (iOS)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) { withCredentials([
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status-adhoc/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
sh 'sleep 10' string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
ipaUrl = 'https://i.diawi.com/' + hash ]) {
sh 'fastlane ios upload_diawi'
sh ('echo ARTIFACT iOS: ' + ipaUrl)
} }
} }
} catch (e) { } catch (e) {
@ -156,13 +155,13 @@ timeout(90) {
apk_name = 'im.status.ethereum-e2e-' + shortCommit + '.apk' apk_name = 'im.status.ethereum-e2e-' + shortCommit + '.apk'
sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk') sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk')
} }
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/release/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
sh 'sleep 10'
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim()
testApkUrl = 'https://i.diawi.com/' + hash
sh ('echo ARTIFACT Android for e2e tests: ' + testApkUrl) withCredentials([
string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
]) {
sh 'fastlane android upload_diawi'
} }
} }

View File

@ -74,13 +74,12 @@ timeout(90) {
sh 'cd android && ./gradlew react-native-android:installArchives && ./gradlew assembleRelease' sh 'cd android && ./gradlew react-native-android:installArchives && ./gradlew assembleRelease'
} }
stage('Deploy (Android)') { stage('Deploy (Android)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) { withCredentials([
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/release/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
sh 'sleep 10' string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
apkUrl = 'https://i.diawi.com/' + hash ]) {
sh 'fastlane android upload_diawi'
sh ('echo ARTIFACT Android: ' + apkUrl)
} }
} }
@ -100,13 +99,12 @@ timeout(90) {
} }
} }
stage('Deploy (iOS)') { stage('Deploy (iOS)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) { withCredentials([
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status-adhoc/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
sh 'sleep 10' string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
ipaUrl = 'https://i.diawi.com/' + hash ]) {
sh 'fastlane ios upload_diawi'
sh ('echo ARTIFACT iOS: ' + ipaUrl)
} }
} }

View File

@ -108,13 +108,13 @@ timeout(90) {
} }
stage('Deploy (iOS)') { stage('Deploy (iOS)') {
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status-adhoc/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
sh 'sleep 10'
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim()
ipaUrl = 'https://i.diawi.com/' + hash
sh ('echo ARTIFACT iOS: ' + ipaUrl) withCredentials([
string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
]) {
sh 'fastlane ios upload_diawi'
} }
} }
@ -137,12 +137,13 @@ timeout(90) {
apk_name = 'release-e2e-' + shortCommit + '.apk' apk_name = 'release-e2e-' + shortCommit + '.apk'
sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk') sh('curl -u ' + username+ ':' + key + ' -X POST -H "Content-Type: application/octet-stream" https://saucelabs.com/rest/v1/storage/' + username + '/' + apk_name + '?overwrite=true --data-binary @android/app/build/outputs/apk/release/app-release.apk')
} }
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/release/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim() withCredentials([
sh 'sleep 10' string(credentialsId: 'diawi-token', variable: 'DIAWI_TOKEN'),
def hash = sh(returnStdout: true, script: "curl -vvv 'https://upload.diawi.com/status?token="+token+"&job="+job+"'|jq -r '.hash'").trim() string(credentialsId: 'GIT_HUB_TOKEN', variable: 'GITHUB_TOKEN'),
testApkUrl = 'https://i.diawi.com/' + hash string(credentialsId: 'SLACK_JENKINS_WEBHOOK', variable: 'SLACK_URL')
sh ('echo ARTIFACT Android for e2e tests: ' + testApkUrl) ]) {
sh 'fastlane android upload_diawi'
} }
} }

View File

@ -42,6 +42,47 @@ def build_ios_adhoc
end end
def notify_about_new_build(source, url)
msg = "Branch: " + ENV["BRANCH_NAME"] + ", "
if source.end_with? ".ipa"
msg = msg + "iOS build uploaded to diawi: " + url
else
msg = msg + "Android build uploaded to diawi: " + url
end
slack(
message: msg,
slack_url: ENV["SLACK_URL"]
)
github_api(
server_url: "https://api.github.com",
api_token: ENV["GITHUB_TOKEN"],
http_method: "POST",
path: "/repos/status-im/status-react/issues/" + ENV["CHANGE_ID"] + "/comments",
body: {
"body": msg
}
)
end
def upload_to_diawi_and_notify(source)
diawi(
token: ENV["DIAWI_TOKEN"],
file: source
)
notify_about_new_build(
source,
lane_context[SharedValues::UPLOADED_FILE_LINK_TO_DIAWI]
)
end
platform :ios do platform :ios do
desc "`fastlane ios adhoc` - ad-hoc lane for iOS." desc "`fastlane ios adhoc` - ad-hoc lane for iOS."
desc "This lane is used PRs, Releases, etc." desc "This lane is used PRs, Releases, etc."
@ -122,6 +163,19 @@ platform :ios do
lane :clean do lane :clean do
clean_testflight_testers clean_testflight_testers
end end
desc "`fastlane ios upload-diawi` - upload .ipa to diawi"
desc "also notifies in a GitHub comments and in Slack #jenkins channel"
desc "expects to have an .ipa prepared: `status-adhoc/StatusIm.ipa`"
desc "expects to have a diawi token as DIAWI_TOKEN env variable"
desc "expects to have a github token as GITHUB_TOKEN env variable"
desc "expects to have a slack webhook URL as SLACK_URL env variable"
desc "will fails if file isn't there"
lane :upload_diawi do
upload_to_diawi_and_notify(
"status-adhoc/StatusIm.ipa"
)
end
end end
@ -153,4 +207,17 @@ platform :android do
slack_url: ENV["SLACK_URL"] slack_url: ENV["SLACK_URL"]
) )
end end
desc "`fastlane android upload-diawi` - upload .ipa to diawi"
desc "also notifies in a GitHub comments and in Slack #jenkins channel"
desc "expects to have an .apk prepared: `android/app/build/outputs/apk/release/app-release.apk`"
desc "expects to have a diawi token as DIAWI_TOKEN env variable"
desc "expects to have a github token as GITHUB_TOKEN env variable"
desc "expects to have a slack webhook URL as SLACK_URL env variable"
desc "will fails if file isn't there"
lane :upload_diawi do
upload_to_diawi_and_notify(
"android/app/build/outputs/apk/release/app-release.apk"
)
end
end end

View File

@ -3,3 +3,4 @@
# Ensure this file is checked in to source control! # Ensure this file is checked in to source control!
gem 'fastlane-plugin-clean_testflight_testers' gem 'fastlane-plugin-clean_testflight_testers'
gem 'fastlane-plugin-diawi'