mirror of
https://github.com/status-im/status-react.git
synced 2025-01-10 02:56:07 +00:00
Run build script against the develop branch
This commit is contained in:
parent
ee2904efcc
commit
e83adf1b46
21
Jenkinsfile
vendored
21
Jenkinsfile
vendored
@ -1,6 +1,7 @@
|
|||||||
env.LANG="en_US.UTF-8"
|
env.LANG="en_US.UTF-8"
|
||||||
env.LANGUAGE="en_US.UTF-8"
|
env.LANGUAGE="en_US.UTF-8"
|
||||||
env.LC_ALL="en_US.UTF-8"
|
env.LC_ALL="en_US.UTF-8"
|
||||||
|
|
||||||
node ('macos1') {
|
node ('macos1') {
|
||||||
def apkUrl = ''
|
def apkUrl = ''
|
||||||
def ipaUrl = ''
|
def ipaUrl = ''
|
||||||
@ -13,10 +14,9 @@ node ('macos1') {
|
|||||||
|
|
||||||
stage('Git & Dependencies') {
|
stage('Git & Dependencies') {
|
||||||
slackSend color: 'good', message: BRANCH_NAME + ' build started. ' + env.BUILD_URL
|
slackSend color: 'good', message: BRANCH_NAME + ' build started. ' + env.BUILD_URL
|
||||||
|
|
||||||
git([url: 'https://github.com/status-im/status-react.git', branch: BRANCH_NAME])
|
git([url: 'https://github.com/status-im/status-react.git', branch: BRANCH_NAME])
|
||||||
// Checkout master because used for iOS Plist version information
|
|
||||||
sh 'git checkout -- .'
|
|
||||||
sh 'git checkout master'
|
|
||||||
sh 'git checkout ' + BRANCH_NAME
|
sh 'git checkout ' + BRANCH_NAME
|
||||||
sh 'rm -rf node_modules'
|
sh 'rm -rf node_modules'
|
||||||
sh 'cp .env.jenkins .env'
|
sh 'cp .env.jenkins .env'
|
||||||
@ -38,6 +38,7 @@ node ('macos1') {
|
|||||||
stage('Build (Android)') {
|
stage('Build (Android)') {
|
||||||
sh 'cd android && ./gradlew assembleRelease'
|
sh 'cd android && ./gradlew assembleRelease'
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Deploy (Android)') {
|
stage('Deploy (Android)') {
|
||||||
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
|
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/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
|
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@android/app/build/outputs/apk/app-release.apk -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
|
||||||
@ -49,22 +50,12 @@ node ('macos1') {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// try {
|
|
||||||
// stage('Test (Android)') {
|
|
||||||
// sauce('b9aded57-5cc1-4f6b-b5ea-42d989987852') {
|
|
||||||
// sh 'cd test/appium && mvn -DapkUrl=' + apkUrl + ' test'
|
|
||||||
// saucePublisher()
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// } catch(e) {
|
|
||||||
// testPassed = false
|
|
||||||
// }
|
|
||||||
|
|
||||||
// iOS
|
// iOS
|
||||||
stage('Build (iOS)') {
|
stage('Build (iOS)') {
|
||||||
sh 'export RCT_NO_LAUNCH_PACKAGER=true && xcodebuild -workspace ios/StatusIm.xcworkspace -scheme StatusIm -configuration release -archivePath status clean archive'
|
sh 'export RCT_NO_LAUNCH_PACKAGER=true && xcodebuild -workspace ios/StatusIm.xcworkspace -scheme StatusIm -configuration release -archivePath status clean archive'
|
||||||
sh 'xcodebuild -exportArchive -exportPath status -archivePath status.xcarchive -exportOptionsPlist ~/archive.plist'
|
sh 'xcodebuild -exportArchive -exportPath status -archivePath status.xcarchive -exportOptionsPlist ~/archive.plist'
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Deploy (iOS)') {
|
stage('Deploy (iOS)') {
|
||||||
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
|
withCredentials([string(credentialsId: 'diawi-token', variable: 'token')]) {
|
||||||
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
|
def job = sh(returnStdout: true, script: 'curl https://upload.diawi.com/ -F token='+token+' -F file=@status/StatusIm.ipa -F find_by_udid=0 -F wall_of_apps=0 | jq -r ".job"').trim()
|
||||||
@ -73,12 +64,12 @@ node ('macos1') {
|
|||||||
ipaUrl = 'https://i.diawi.com/' + hash
|
ipaUrl = 'https://i.diawi.com/' + hash
|
||||||
|
|
||||||
sh ('echo ARTIFACT iOS: ' + ipaUrl)
|
sh ('echo ARTIFACT iOS: ' + ipaUrl)
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Slack Notification') {
|
stage('Slack Notification') {
|
||||||
def c = (testPassed ? 'good' : 'warning' )
|
def c = (testPassed ? 'good' : 'warning' )
|
||||||
|
|
||||||
slackSend color: c, message: 'Branch: ' + BRANCH_NAME +
|
slackSend color: c, message: 'Branch: ' + BRANCH_NAME +
|
||||||
'\nAndroid: ' + apkUrl +
|
'\nAndroid: ' + apkUrl +
|
||||||
'\niOS: ' + ipaUrl
|
'\niOS: ' + ipaUrl
|
||||||
|
@ -18,9 +18,7 @@ node ('macos1'){
|
|||||||
slackSend color: 'good', message: 'Nightly build started. ' + env.BUILD_URL
|
slackSend color: 'good', message: 'Nightly build started. ' + env.BUILD_URL
|
||||||
git([url: 'https://github.com/status-im/status-react.git', branch: 'develop'])
|
git([url: 'https://github.com/status-im/status-react.git', branch: 'develop'])
|
||||||
// Checkout master because used for iOS Plist version information
|
// Checkout master because used for iOS Plist version information
|
||||||
sh 'git checkout -- .'
|
|
||||||
sh 'git fetch --tags'
|
sh 'git fetch --tags'
|
||||||
sh 'git checkout master'
|
|
||||||
sh 'git checkout ' + 'develop'
|
sh 'git checkout ' + 'develop'
|
||||||
sh 'rm -rf node_modules'
|
sh 'rm -rf node_modules'
|
||||||
sh 'cp .env.jenkins .env'
|
sh 'cp .env.jenkins .env'
|
||||||
|
@ -1869,7 +1869,7 @@
|
|||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "#!/bin/bash\n\n# This script automatically sets the version and short version string of\n# an Xcode project from the Git repository containing the project.\n#\n# To use this script in Xcode, add the script's path to a \"Run Script\" build\n# phase for your application target.\n\nset -o errexit\nset -o nounset\n\n# First, check for git in $PATH\nhash git 2>/dev/null || { echo >&2 \"Git required, not installed. Aborting build number update script.\"; exit 0; }\n\n# Alternatively, we could use Xcode's copy of the Git binary,\n# but old Xcodes don't have this.\n#GIT=$(xcrun -find git)\n\n# Run Script build phases that operate on product files of the target that defines them should use the value of this build setting [TARGET_BUILD_DIR]. But Run Script build phases that operate on product files of other targets should use ?BUILT_PRODUCTS_DIR? instead.\nINFO_PLIST=\"${TARGET_BUILD_DIR}/${INFOPLIST_PATH}\"\n\n# Build version (closest-tag-or-branch \"-\" commits-since-tag \"-\" short-hash dirty-flag)\nBUILD_VERSION=$(git describe --tags --always --dirty=+)\n\n# Use the latest tag for short version (expected tag format \"vn[.n[.n]]\")\n# or if there are no tags, we make up version 0.0.<commit count>\nLATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null) || LATEST_TAG=\"HEAD\"\nif [ $LATEST_TAG = \"HEAD\" ]\nthen COMMIT_COUNT=$(git rev-list --count HEAD)\n LATEST_TAG=\"0.0.$COMMIT_COUNT\"\n COMMIT_COUNT_SINCE_TAG=0\nelse\n COMMIT_COUNT_SINCE_TAG=$(git rev-list --count ${LATEST_TAG}..)\n LATEST_TAG=${LATEST_TAG##v} # Remove the \"v\" from the front of the tag\nfi\nif [ $COMMIT_COUNT_SINCE_TAG = 0 ]; then\n SHORT_VERSION=\"$LATEST_TAG\"\nelse\n # increment final digit of tag and append \"d\" + commit-count-since-tag\n # e.g. commit after 1.0 is 1.1d1, commit after 1.0.0 is 1.0.1d1\n # this is the bit that requires /bin/bash\n OLD_IFS=$IFS\n IFS=\".\"\n VERSION_PARTS=($LATEST_TAG)\n LAST_PART=$((${#VERSION_PARTS[@]}-1))\n VERSION_PARTS[$LAST_PART]=$((${VERSION_PARTS[${LAST_PART}]}+1))\n SHORT_VERSION=\"${VERSION_PARTS[*]}d${COMMIT_COUNT_SINCE_TAG}\"\n IFS=$OLD_IFS\nfi\n \n# Bundle version (commits-on-master[-until-branch \".\" commits-on-branch])\n# Assumes that two release branches will not diverge from the same commit on master.\nif [ $(git rev-parse --abbrev-ref HEAD) = \"master\" ]; then\n MASTER_COMMIT_COUNT=$(git rev-list --count HEAD)\n BRANCH_COMMIT_COUNT=0\n BUNDLE_VERSION=\"$MASTER_COMMIT_COUNT\"\nelse\n MASTER_COMMIT_COUNT=$(git rev-list --count $(git rev-list master.. | tail -n 1)^)\n BRANCH_COMMIT_COUNT=$(git rev-list --count master..)\n if [ $BRANCH_COMMIT_COUNT = 0 ]\n then BUNDLE_VERSION=\"$MASTER_COMMIT_COUNT\"\n else BUNDLE_VERSION=\"${MASTER_COMMIT_COUNT}.${BRANCH_COMMIT_COUNT}\"\n fi\nfi\n \n# For debugging:\necho \"BUILD VERSION: $BUILD_VERSION\"\necho \"LATEST_TAG: $LATEST_TAG\"\necho \"COMMIT_COUNT_SINCE_TAG: $COMMIT_COUNT_SINCE_TAG\"\necho \"SHORT VERSION: $SHORT_VERSION\"\necho \"MASTER_COMMIT_COUNT: $MASTER_COMMIT_COUNT\"\necho \"BRANCH_COMMIT_COUNT: $BRANCH_COMMIT_COUNT\"\necho \"BUNDLE_VERSION: $BUNDLE_VERSION\"\n \n/usr/libexec/PlistBuddy -c \"Add :CFBundleBuildVersion string $BUILD_VERSION\" \"$INFO_PLIST\" 2>/dev/null || /usr/libexec/PlistBuddy -c \"Set :CFBundleBuildVersion $BUILD_VERSION\" \"$INFO_PLIST\"\n/usr/libexec/PlistBuddy -c \"Set :CFBundleShortVersionString $SHORT_VERSION\" \"$INFO_PLIST\"\n/usr/libexec/PlistBuddy -c \"Set :CFBundleVersion $BUNDLE_VERSION\" \"$INFO_PLIST\"";
|
shellScript = "#!/bin/bash\n\nsource \"${PROJECT_DIR}/scripts/set_xcode_version.sh\"";
|
||||||
};
|
};
|
||||||
E883D1F9B22B8292CC879292 /* [CP] Copy Pods Resources */ = {
|
E883D1F9B22B8292CC879292 /* [CP] Copy Pods Resources */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
79
ios/scripts/set_xcode_version.sh
Executable file
79
ios/scripts/set_xcode_version.sh
Executable file
@ -0,0 +1,79 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# This script automatically sets the version and short version string of
|
||||||
|
# an Xcode project from the Git repository containing the project.
|
||||||
|
#
|
||||||
|
# To use this script in Xcode, add the script's path to a "Run Script" build
|
||||||
|
# phase for your application target.
|
||||||
|
|
||||||
|
MAIN_GIT_BRANCH="develop" # status-react uses develop instead of master as the main dev tree
|
||||||
|
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
|
||||||
|
# First, check for git in $PATH
|
||||||
|
hash git 2>/dev/null || { echo >&2 "Git required, not installed. Aborting build number update script."; exit 0; }
|
||||||
|
|
||||||
|
# Alternatively, we could use Xcode's copy of the Git binary,
|
||||||
|
# but old Xcodes don't have this.
|
||||||
|
#GIT=$(xcrun -find git)
|
||||||
|
|
||||||
|
# Run Script build phases that operate on product files of the target that defines them should use the value of this build setting [TARGET_BUILD_DIR]. But Run Script build phases that operate on product files of other targets should use ?BUILT_PRODUCTS_DIR? instead.
|
||||||
|
INFO_PLIST="${TARGET_BUILD_DIR}/${INFOPLIST_PATH}"
|
||||||
|
|
||||||
|
# Build version (closest-tag-or-branch "-" commits-since-tag "-" short-hash dirty-flag)
|
||||||
|
BUILD_VERSION=$(git describe --tags --always --dirty=+)
|
||||||
|
|
||||||
|
# Use the latest tag for short version (expected tag format "vn[.n[.n]]")
|
||||||
|
# or if there are no tags, we make up version 0.0.<commit count>
|
||||||
|
LATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null) || LATEST_TAG="HEAD"
|
||||||
|
if [ $LATEST_TAG = "HEAD" ]
|
||||||
|
then COMMIT_COUNT=$(git rev-list --count HEAD)
|
||||||
|
LATEST_TAG="0.0.$COMMIT_COUNT"
|
||||||
|
COMMIT_COUNT_SINCE_TAG=0
|
||||||
|
else
|
||||||
|
COMMIT_COUNT_SINCE_TAG=$(git rev-list --count ${LATEST_TAG}..)
|
||||||
|
LATEST_TAG=${LATEST_TAG##v} # Remove the "v" from the front of the tag
|
||||||
|
fi
|
||||||
|
if [ $COMMIT_COUNT_SINCE_TAG = 0 ]; then
|
||||||
|
SHORT_VERSION="$LATEST_TAG"
|
||||||
|
else
|
||||||
|
# increment final digit of tag and append "d" + commit-count-since-tag
|
||||||
|
# e.g. commit after 1.0 is 1.1d1, commit after 1.0.0 is 1.0.1d1
|
||||||
|
# this is the bit that requires /bin/bash
|
||||||
|
OLD_IFS=$IFS
|
||||||
|
IFS="."
|
||||||
|
VERSION_PARTS=($LATEST_TAG)
|
||||||
|
LAST_PART=$((${#VERSION_PARTS[@]}-1))
|
||||||
|
VERSION_PARTS[$LAST_PART]=$((${VERSION_PARTS[${LAST_PART}]}+1))
|
||||||
|
SHORT_VERSION="${VERSION_PARTS[*]}d${COMMIT_COUNT_SINCE_TAG}"
|
||||||
|
IFS=$OLD_IFS
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Bundle version (commits-on-master[-until-branch "." commits-on-branch])
|
||||||
|
# Assumes that two release branches will not diverge from the same commit on master.
|
||||||
|
if [ $(git rev-parse --abbrev-ref HEAD) = "$MAIN_GIT_BRANCH" ]; then
|
||||||
|
MASTER_COMMIT_COUNT=$(git rev-list --count HEAD)
|
||||||
|
BRANCH_COMMIT_COUNT=0
|
||||||
|
BUNDLE_VERSION="$MASTER_COMMIT_COUNT"
|
||||||
|
else
|
||||||
|
MASTER_COMMIT_COUNT=$(git rev-list --count $(git rev-list ${MAIN_GIT_BRANCH}.. | tail -n 1)^)
|
||||||
|
BRANCH_COMMIT_COUNT=$(git rev-list --count ${MAIN_GIT_BRANCH}..)
|
||||||
|
if [ $BRANCH_COMMIT_COUNT = 0 ]
|
||||||
|
then BUNDLE_VERSION="$MASTER_COMMIT_COUNT"
|
||||||
|
else BUNDLE_VERSION="${MASTER_COMMIT_COUNT}.${BRANCH_COMMIT_COUNT}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For debugging:
|
||||||
|
echo "BUILD VERSION: $BUILD_VERSION"
|
||||||
|
echo "LATEST_TAG: $LATEST_TAG"
|
||||||
|
echo "COMMIT_COUNT_SINCE_TAG: $COMMIT_COUNT_SINCE_TAG"
|
||||||
|
echo "SHORT VERSION: $SHORT_VERSION"
|
||||||
|
echo "MASTER_COMMIT_COUNT: $MASTER_COMMIT_COUNT"
|
||||||
|
echo "BRANCH_COMMIT_COUNT: $BRANCH_COMMIT_COUNT"
|
||||||
|
echo "BUNDLE_VERSION: $BUNDLE_VERSION"
|
||||||
|
|
||||||
|
/usr/libexec/PlistBuddy -c "Add :CFBundleBuildVersion string $BUILD_VERSION" "$INFO_PLIST" 2>/dev/null || /usr/libexec/PlistBuddy -c "Set :CFBundleBuildVersion $BUILD_VERSION" "$INFO_PLIST"
|
||||||
|
/usr/libexec/PlistBuddy -c "Set :CFBundleShortVersionString $SHORT_VERSION" "$INFO_PLIST"
|
||||||
|
/usr/libexec/PlistBuddy -c "Set :CFBundleVersion $BUNDLE_VERSION" "$INFO_PLIST"
|
Loading…
x
Reference in New Issue
Block a user