Use fastlane for diawi, Slack & GitHub comments
Signed-off-by: Igor Mandrigin <i@mandrigin.ru>
This commit is contained in:
parent
edd87192d0
commit
c99fd733e6
|
@ -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'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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'
|
||||||
|
|
Loading…
Reference in New Issue