Skip to content
Snippets Groups Projects
Commit 1d4bc678 authored by Benoit Lavenier's avatar Benoit Lavenier
Browse files

[fix] Release: push force

parent 74002957
No related branches found
No related tags found
No related merge requests found
#!/bin/bash
# Get to the root project
if [[ "_" == "_${PROJECT_DIR}" ]]; then
SCRIPT_DIR=$(dirname $0)
PROJECT_DIR=$(cd ${SCRIPT_DIR}/.. && pwd)
export PROJECT_DIR
fi;
cd ${PROJECT_DIR}
# Preparing the environment
. ${PROJECT_DIR}/scripts/env-global.sh
if [[ $? -ne 0 ]]; then
exit 1
fi
# Commit android project
cd ${PROJECT_DIR}/platforms/android || exit 1
git reset HEAD
git add -A
git commit -m "v$1"
git tag -f -a "v$1" -m "Release v$1"
# Push the tag
git push -f origin "v$1"
# Push the master branch
git push -f origin
if [[ $? -ne 0 ]]; then
echo "ERROR: cannot push platform/android project ! Continue anyway..."
fi
...@@ -15,18 +15,48 @@ if [[ $? -ne 0 ]]; then ...@@ -15,18 +15,48 @@ if [[ $? -ne 0 ]]; then
exit 1 exit 1
fi fi
if [[ -d "${PROJECT_DIR}/dist/desktop" ]]; then ### Control that the script is run on `dev` branch
branch=$(git rev-parse --abbrev-ref HEAD)
if [[ ! "$branch" = "master" ]];
then
echo ">> This script must be run under \`master\` branch"
exit 1
fi
### Get version to release
current=$(grep -P "version\": \"\d+.\d+.\d+(\w*)" package.json | grep -m 1 -oP "\d+.\d+.\d+(\w*)")
if [[ "_$current" == "_" ]]; then
echo "Unable to read the current version in 'package.json'. Please check version format is: x.y.z (x and y should be an integer)."
exit 1;
fi
### Check submodule exists
if [[ ! -d "${PROJECT_DIR}/dist/desktop" ]]; then
echo "ERROR: dist/desktop not found -> Make sure git submodule has been init!"
exit 1
fi;
### Sign extension
case "$1" in
pre|rel)
echo "Building v$current desktop artifacts..."
;;
*)
echo "No task given"
echo "Usage:"
echo " > $0 pre|rel"
exit 1
;;
esac
cd "${PROJECT_DIR}/dist/desktop" cd "${PROJECT_DIR}/dist/desktop"
# Fetch last updates # Fetch last updates
git fetch origin && git merge origin/master || exit 1 git fetch origin && git merge origin/master || exit 1
# Build desktop assets # Build desktop assets
./release.sh $1 ./release.sh $current
if [[ $? -ne 0 ]]; then if [[ $? -ne 0 ]]; then
exit 1 exit 1
fi fi
else
echo "ERROR: dist/desktop not found -> Make sure git submodule has been init!"
exit 1
fi;
...@@ -38,6 +38,7 @@ else ...@@ -38,6 +38,7 @@ else
exit 1 exit 1
fi fi
### check arguments
case "$1" in case "$1" in
del) del)
result=$(curl -i "$REPO_API_URL/releases/tags/v$current") result=$(curl -i "$REPO_API_URL/releases/tags/v$current")
...@@ -46,16 +47,29 @@ case "$1" in ...@@ -46,16 +47,29 @@ case "$1" in
echo "Deleting existing release..." echo "Deleting existing release..."
curl -H 'Authorization: token $GITHUB_TOKEN' -XDELETE $release_url curl -H 'Authorization: token $GITHUB_TOKEN' -XDELETE $release_url
fi fi
exit 0;
;; ;;
pre|rel) pre)
if [[ "_$2" != "_" ]]; then
if [[ $1 = "pre" ]]; then
prerelease="true" prerelease="true"
else echo "Creating new pre-release v$current..."
;;
rel)
prerelease="false" prerelease="false"
fi echo "Creating new release v$current..."
;;
*)
echo "No task given, or wrong arguments"
echo "Usage:"
echo " > $0 del|pre|rel <release_description>"
echo "With:"
echo " - del: delete existing release"
echo " - pre: use for pre-release"
echo " - rel: for full release"
exit 1
;;
esac
description=$(echo $2) description=$(echo $2)
if [[ "_$description" = "_" ]]; then if [[ "_$description" = "_" ]]; then
...@@ -76,13 +90,10 @@ case "$1" in ...@@ -76,13 +90,10 @@ case "$1" in
echo "Release not exists yet on github." echo "Release not exists yet on github."
fi fi
echo "Creating new release..." ### Create the release
echo " - tag: v$current"
echo " - description: $description"
result=$(curl -H ''"$GITHUT_AUTH"'' -s $REPO_API_URL/releases -d '{"tag_name": "v'"$current"'","target_commitish": "master","name": "'"$current"'","body": "'"$description"'","draft": false,"prerelease": '"$prerelease"'}') result=$(curl -H ''"$GITHUT_AUTH"'' -s $REPO_API_URL/releases -d '{"tag_name": "v'"$current"'","target_commitish": "master","name": "'"$current"'","body": "'"$description"'","draft": false,"prerelease": '"$prerelease"'}')
#echo "DEBUG - $result" #echo "DEBUG - $result"
upload_url=$(echo "$result" | grep -P "\"upload_url\": \"[^\"]+" | grep -oP "https://[A-Za-z0-9/.-]+") upload_url=$(echo "$result" | grep -P "\"upload_url\": \"[^\"]+" | grep -oP "https://[A-Za-z0-9/.-]+")
if [[ "_$upload_url" = "_" ]]; then if [[ "_$upload_url" = "_" ]]; then
echo "Failed to create new release for repo $REPO." echo "Failed to create new release for repo $REPO."
echo "Server response:" echo "Server response:"
...@@ -90,9 +101,8 @@ case "$1" in ...@@ -90,9 +101,8 @@ case "$1" in
exit 1 exit 1
fi fi
### Sending files ### Send files
echo "Uploading artifacts to ${upload_url} ..." echo "Uploading artifacts to ${upload_url} ..."
dirname=$(pwd)
# Upload web file # Upload web file
WEB_BASENAME="${PROJECT_NAME}-v$current-web.zip" WEB_BASENAME="${PROJECT_NAME}-v$current-web.zip"
...@@ -138,25 +148,5 @@ case "$1" in ...@@ -138,25 +148,5 @@ case "$1" in
echo "${APK_FILE_SHA256}" >> ${SHA_FILE} echo "${APK_FILE_SHA256}" >> ${SHA_FILE}
result=$(curl -s -H ''"$GITHUT_AUTH"'' -H 'Content-Type: text/plain' -T "${SHA_FILE}" "${upload_url}?name=${SHA_BASENAME}") result=$(curl -s -H ''"$GITHUT_AUTH"'' -H 'Content-Type: text/plain' -T "${SHA_FILE}" "${upload_url}?name=${SHA_BASENAME}")
echo "-----------------------------------------" ### Success message
echo "Successfully uploading files !" echo "Successfully uploaded files to: ${REPO_PUBLIC_URL}/releases/tag/v${current}"
echo " -> Release url: ${REPO_PUBLIC_URL}/releases/tag/v${current}"
exit 0
else
echo "Wrong arguments"
echo "Usage:"
echo " > $0 del|pre|rel <release_description>"
echo "With:"
echo " - del: delete existing release"
echo " - pre: use for pre-release"
echo " - rel: for full release"
exit 1
fi
;;
*)
echo "No task given"
echo "Usage:"
echo " > $0 del|pre|rel <release_description>"
exit 1
;;
esac
...@@ -144,9 +144,9 @@ fi ...@@ -144,9 +144,9 @@ fi
git commit -m "v$2" git commit -m "v$2"
git tag -f -a "v$2" -m "${description}" git tag -f -a "v$2" -m "${description}"
# Push the tag # Push the tag
git push origin "v$2" git push -f origin "v$2"
# Push the master branch # Push the master branch
git push origin git push -f origin
if [[ $? -ne 0 ]]; then if [[ $? -ne 0 ]]; then
exit 1 exit 1
fi fi
...@@ -161,7 +161,7 @@ echo "----------------------------------" ...@@ -161,7 +161,7 @@ echo "----------------------------------"
#fi #fi
echo "----------------------------------" echo "----------------------------------"
echo "- Uploading artifacts to Gihub ..." echo "- Uploading artifacts to Github ..."
echo "----------------------------------" echo "----------------------------------"
# Pause (wait propagation to from git.duniter.org to github) # Pause (wait propagation to from git.duniter.org to github)
echo " Waiting 40s, for propagation to github..." && sleep 40s echo " Waiting 40s, for propagation to github..." && sleep 40s
...@@ -173,7 +173,7 @@ fi ...@@ -173,7 +173,7 @@ fi
echo "----------------------------------" echo "----------------------------------"
echo "- Building desktop artifacts..." echo "- Building desktop artifacts..."
echo "----------------------------------" echo "----------------------------------"
. ${PROJECT_DIR}/scripts/release-desktop.sh $2 ''"$description"'' . ${PROJECT_DIR}/scripts/release-desktop.sh $1 ''"$description"''
if [[ $? -ne 0 ]]; then if [[ $? -ne 0 ]]; then
exit 1 exit 1
fi fi
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment