MOBILE-4286 github: Split prepare into release and merge script
parent
7f7f547d4d
commit
ad801dd9f6
|
@ -1,144 +1,6 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
function check_success_exit {
|
source "./scripts/functions.sh"
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
print_error "$1"
|
|
||||||
exit 1
|
|
||||||
elif [ "$#" -gt 1 ]; then
|
|
||||||
print_ok "$2"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_success {
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
print_error "$1"
|
|
||||||
elif [ "$#" -gt 1 ]; then
|
|
||||||
print_ok "$2"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function print_success {
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
print_message "$1"
|
|
||||||
$3=0
|
|
||||||
else
|
|
||||||
print_ok "$2"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function print_error {
|
|
||||||
[[ -n "$TERM" ]] && tput setaf 1
|
|
||||||
echo " ERROR: $1"
|
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
|
||||||
}
|
|
||||||
|
|
||||||
function print_ok {
|
|
||||||
[[ -n "$TERM" ]] && tput setaf 2
|
|
||||||
echo " OK: $1"
|
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
|
||||||
echo
|
|
||||||
}
|
|
||||||
|
|
||||||
function print_message {
|
|
||||||
[[ -n "$TERM" ]] && tput setaf 3
|
|
||||||
echo "-------- $1"
|
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
|
||||||
echo
|
|
||||||
}
|
|
||||||
|
|
||||||
function print_title {
|
|
||||||
stepnumber=$(($stepnumber + 1))
|
|
||||||
echo
|
|
||||||
[[ -n "$TERM" ]] && tput setaf 5
|
|
||||||
echo "$stepnumber $1"
|
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
|
||||||
[[ -n "$TERM" ]] && tput setaf 5
|
|
||||||
echo '=================='
|
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
|
||||||
}
|
|
||||||
|
|
||||||
function telegram_notify {
|
|
||||||
if [ ! -z $TELEGRAM_APIKEY ] && [ ! -z $TELEGRAM_CHATID ] ; then
|
|
||||||
set_branch_and_repo
|
|
||||||
|
|
||||||
MESSAGE="$1%0ABranch: *$REFNAME* on $REPO%0ACommit: $COMMIT%0AJob: $JOB ($RUN_NUMBER) [Complete log here]($JOB_URL)"
|
|
||||||
URL="https://api.telegram.org/bot$TELEGRAM_APIKEY/sendMessage"
|
|
||||||
|
|
||||||
curl -s -X POST $URL -d chat_id=$TELEGRAM_CHATID -d text="$MESSAGE"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function notify_on_error_exit {
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
print_error "$1"
|
|
||||||
telegram_notify "$1"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function set_branch_and_repo {
|
|
||||||
if [ ! -z $REPO ]; then
|
|
||||||
# Already filled.
|
|
||||||
return;
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z $TRAVIS_OS_NAME ]; then
|
|
||||||
#Run on github
|
|
||||||
if [ "$RUNNER_OS" == 'macOS' ]; then
|
|
||||||
export OS_NAME='osx'
|
|
||||||
elif [ "$RUNNER_OS" == 'Linux' ]; then
|
|
||||||
export OS_NAME='linux'
|
|
||||||
elif [ "$RUNNER_OS" == 'Windows' ]; then
|
|
||||||
export OS_NAME='windows'
|
|
||||||
fi
|
|
||||||
export REFNAME=$GITHUB_REF_NAME
|
|
||||||
export REFTYPE=$GITHUB_REF_TYPE
|
|
||||||
export REPO=$GITHUB_REPOSITORY
|
|
||||||
export COMMIT=$GITHUB_SHA
|
|
||||||
export JOB=$GITHUB_JOB
|
|
||||||
export JOB_URL=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID
|
|
||||||
export RUN_NUMBER=$GITHUB_RUN_NUMBER
|
|
||||||
export CI_TYPE='github'
|
|
||||||
else
|
|
||||||
# Run on Travis
|
|
||||||
export OS_NAME=$TRAVIS_OS_NAME
|
|
||||||
if [ -z "$TRAVIS_TAG" ]; then
|
|
||||||
export REFTYPE='branch'
|
|
||||||
export REFNAME=$TRAVIS_BRANCH
|
|
||||||
else
|
|
||||||
export REFTYPE='tag'
|
|
||||||
export REFNAME=$TRAVIS_TAG
|
|
||||||
fi
|
|
||||||
export REPO=$TRAVIS_REPO_SLUG
|
|
||||||
export COMMIT=$TRAVIS_COMMIT
|
|
||||||
export JOB=$TRAVIS_JOB_NAME
|
|
||||||
export JOB_URL=$TRAVIS_JOB_WEB_URL
|
|
||||||
export RUN_NUMBER=$TRAVIS_BUILD_NUMBER
|
|
||||||
export CI_TYPE='travis'
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z $REFNAME ]; then
|
|
||||||
print_error "Empty branch/tag, cancelling..."
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z $REPO ]; then
|
|
||||||
print_error "Empty repo, cancelling..."
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
print_title "Build info:"
|
|
||||||
echo "OS_NAME: $OS_NAME"
|
|
||||||
echo "REFNAME: $REFNAME"
|
|
||||||
echo "REFTYPE: $REFTYPE"
|
|
||||||
echo "REPO: $REPO"
|
|
||||||
echo "COMMIT: $COMMIT"
|
|
||||||
echo "JOB: $JOB"
|
|
||||||
echo "JOB_URL: $JOB_URL"
|
|
||||||
echo "RUN_NUMBER: $RUN_NUMBER"
|
|
||||||
echo "CI_TYPE: $CI_TYPE"
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_behat_plugin_changes_diff {
|
function get_behat_plugin_changes_diff {
|
||||||
# Grab hashes from app repository
|
# Grab hashes from app repository
|
||||||
|
|
|
@ -6,17 +6,17 @@ if [ -z $GIT_TOKEN ] || [ $GITHUB_REPOSITORY != 'moodlemobile/moodleapp' ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
print_title "Run prepare scripts"
|
print_title "Run merge scripts"
|
||||||
git clone --depth 1 --single-branch --branch ionic5 https://$GIT_TOKEN@github.com/moodlemobile/apps-scripts.git ../scripts
|
git clone --depth 1 --single-branch --branch ionic5 https://$GIT_TOKEN@github.com/moodlemobile/apps-scripts.git ../scripts
|
||||||
cp ../scripts/*.sh scripts/
|
cp ../scripts/*.sh scripts/
|
||||||
|
|
||||||
if [ ! -f scripts/prepare.sh ]; then
|
if [ ! -f scripts/merge.sh ]; then
|
||||||
print_error "Prepare file not found"
|
print_error "Merge file not found"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
print_title 'Prepare Build'
|
print_title 'Merge!'
|
||||||
./scripts/prepare.sh
|
./scripts/merge.sh
|
||||||
|
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
exit 1
|
exit 1
|
|
@ -0,0 +1,23 @@
|
||||||
|
#!/bin/bash
|
||||||
|
source "./.github/scripts/functions.sh"
|
||||||
|
|
||||||
|
if [ -z $GIT_TOKEN ] ; then
|
||||||
|
print_error "Env vars not correctly defined"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_title "Run release scripts"
|
||||||
|
git clone --depth 1 --single-branch --branch ionic5 https://$GIT_TOKEN@github.com/moodlemobile/apps-scripts.git ../scripts
|
||||||
|
cp ../scripts/*.sh scripts/
|
||||||
|
|
||||||
|
if [ ! -f scripts/release.sh ]; then
|
||||||
|
print_error "Release file not found"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_title 'Create release tags'
|
||||||
|
./scripts/release.sh
|
||||||
|
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
exit 1
|
||||||
|
fi
|
|
@ -2,7 +2,7 @@ name: Prepare
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [ main, freemium-main, v*.x, freemium-v*.x ]
|
branches: [ main, v*.x ]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
prepare:
|
prepare:
|
||||||
|
@ -17,4 +17,4 @@ jobs:
|
||||||
- name: Prepare builds
|
- name: Prepare builds
|
||||||
env:
|
env:
|
||||||
GIT_TOKEN: ${{ secrets.GIT_TOKEN }}
|
GIT_TOKEN: ${{ secrets.GIT_TOKEN }}
|
||||||
run: ./.github/scripts/prepare.sh
|
run: ./.github/scripts/merge.sh
|
|
@ -0,0 +1,18 @@
|
||||||
|
name: Prepare
|
||||||
|
|
||||||
|
on: workflow_dispatch
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
prepare:
|
||||||
|
if: github.repository == 'moodlehq/moodleapp'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
persist-credentials: false
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: Create release tags
|
||||||
|
env:
|
||||||
|
GIT_TOKEN: ${{ secrets.GIT_TOKEN }}
|
||||||
|
run: ./.github/scripts/release.sh
|
|
@ -27,34 +27,34 @@ function print_success {
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_error {
|
function print_error {
|
||||||
[[ -n "$TERM" ]] && tput setaf 1
|
[[ -t 1 ]] && tput setaf 1
|
||||||
echo " ERROR: $1"
|
echo " ERROR: $1"
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
[[ -t 1 ]] && tput sgr0
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_ok {
|
function print_ok {
|
||||||
[[ -n "$TERM" ]] && tput setaf 2
|
[[ -t 1 ]] && tput setaf 2
|
||||||
echo " OK: $1"
|
echo " OK: $1"
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
[[ -t 1 ]] && tput sgr0
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_message {
|
function print_message {
|
||||||
[[ -n "$TERM" ]] && tput setaf 3
|
[[ -t 1 ]] && tput setaf 3
|
||||||
echo "-------- $1"
|
echo "-------- $1"
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
[[ -t 1 ]] && tput sgr0
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_title {
|
function print_title {
|
||||||
stepnumber=$(($stepnumber + 1))
|
stepnumber=$(($stepnumber + 1))
|
||||||
echo
|
echo
|
||||||
[[ -n "$TERM" ]] && tput setaf 5
|
[[ -t 1 ]] && tput setaf 5
|
||||||
echo "$stepnumber $1"
|
echo "$stepnumber $1"
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
[[ -t 1 ]] && tput sgr0
|
||||||
[[ -n "$TERM" ]] && tput setaf 5
|
[[ -t 1 ]] && tput setaf 5
|
||||||
echo '=================='
|
echo '=================='
|
||||||
[[ -n "$TERM" ]] && tput sgr0
|
[[ -t 1 ]] && tput sgr0
|
||||||
}
|
}
|
||||||
|
|
||||||
function telegram_notify {
|
function telegram_notify {
|
||||||
|
|
Loading…
Reference in New Issue