opt: Optimize github actions workflow execution logic (1/2) #3
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI Build | |
on: | |
pull_request: | |
types: [opened, synchronize] | |
paths-ignore: | |
- ".github/**" | |
- "!.github/workflows/**" | |
- ".idea/" | |
- "doc/*" | |
- "*.md" | |
- "app/src/assets/**" | |
- ".github/workflows/crowdin.yml" | |
- "crowdin.yml" | |
push: | |
branches: [main] | |
paths-ignore: | |
- ".github/**" | |
- "!.github/workflows/**" | |
- ".idea/" | |
- "doc/*" | |
- "*.md" | |
- "app/src/assets/**" | |
- "crowdin.yml" | |
workflow_dispatch: | |
jobs: | |
build_canary_package: | |
if: github.event_name == 'push' && github.ref == 'refs/heads/main' | |
runs-on: ubuntu-latest | |
name: Build Canary Package | |
steps: | |
- name: Checkout Git Repository | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
submodules: true | |
- name: Set up JDK 21 | |
uses: actions/setup-java@v4 | |
with: | |
java-version: '21' | |
distribution: 'temurin' | |
cache: gradle | |
- name: Create Sign File | |
run: | | |
touch signing.properties | |
echo storePassword=${{ secrets.KEY_STORE_PASSWORD }} >> signing.properties | |
echo keyAlias=${{ secrets.ALIAS }} >> signing.properties | |
echo keyPassword='${{ secrets.KEY_STORE_PASSWORD }}' >> signing.properties | |
echo storeFile=../key.jks >> signing.properties | |
echo ${{ secrets.SIGNING_KEY }} | base64 --decode > key.jks | |
- name: Build with Gradle (Canary) | |
shell: bash | |
run: ./gradlew assembleCanary | |
- name: Find APKs | |
run: | | |
echo "APK_FILE_CANARY=$(find app/build/outputs/apk/canary -name '*.apk')" >> $GITHUB_ENV | |
- name: Show APKs SHA256 | |
if: success() | |
run: | | |
echo "### Build Success" >> $GITHUB_STEP_SUMMARY | |
echo "|Artifact|SHA256|" >> $GITHUB_STEP_SUMMARY | |
echo "|:--------:|:----------|" >> $GITHUB_STEP_SUMMARY | |
canary=$(sha256sum "${{ env.APK_FILE_CANARY }}") | |
echo "SHA256=$canary" >> $GITHUB_ENV | |
echo "|Canary|$canary" >> $GITHUB_STEP_SUMMARY | |
build_debug_package: | |
if: github.event_name == 'pull_request' | |
runs-on: ubuntu-latest | |
name: Build Debug Package | |
steps: | |
- name: Checkout Git Repository | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
submodules: true | |
- name: Set up JDK 21 | |
uses: actions/setup-java@v4 | |
with: | |
java-version: '21' | |
distribution: 'temurin' | |
cache: gradle | |
- name: Build with Gradle (Debug) | |
shell: bash | |
run: ./gradlew assembleDebug | |
- name: Find APKs | |
run: | | |
echo "APK_FILE_DEBUG=$(find app/build/outputs/apk/debug -name '*.apk')" >> $GITHUB_ENV | |
- name: Show APKs SHA256 | |
if: success() | |
run: | | |
echo "### Build Success" >> $GITHUB_STEP_SUMMARY | |
echo "|Artifact|SHA256|" >> $GITHUB_STEP_SUMMARY | |
echo "|:--------:|:----------|" >> $GITHUB_STEP_SUMMARY | |
debug=$(sha256sum "${{ env.APK_FILE_DEBUG }}") | |
echo "SHA256=$debug" >> $GITHUB_ENV | |
echo "|Debug|$debug" >> $GITHUB_STEP_SUMMARY | |
push_to_canary_channel: | |
if: github.event_name == 'push' && github.ref == 'refs/heads/main' && ${{ github.ref == 'refs/heads/main' && github.ref_type != 'tag' && contains(github.event.head_commit.message, '[skip post]') == false && contains(github.event.head_commit.message, 's#') == false }} | |
runs-on: ubuntu-latest | |
name: Push to Canary Channel | |
needs: build_canary_package | |
steps: | |
- name: Checkout Git Repository | |
uses: actions/checkout@v4 | |
- name: Upload Canary APK | |
uses: actions/upload-artifact@v4 | |
with: | |
name: HyperCeiler Canary | |
path: ${{ env.APK_FILE_CANARY }} | |
- name: Post to Canary Channel | |
env: | |
CHANNEL_ID: ${{ secrets.CHANNEL_ID }} | |
BOT_TOKEN: ${{ secrets.BOT_TOKEN }} | |
CANARY: ${{ env.APK_FILE_CANARY }} | |
COMMIT_MESSAGE: |+ | |
New push to GitHub | |
``` | |
${{ github.event.head_commit.message }} | |
```by `${{ github.event.head_commit.author.name }}` | |
See commit detail [here](${{ github.event.head_commit.url }}) | |
run: | | |
ESCAPED=$(python3 -c 'import json,os,urllib.parse; print(urllib.parse.quote(json.dumps(os.environ["COMMIT_MESSAGE"])))') | |
cd ${{ github.workspace }} | |
curl -v "https://api.telegram.org/bot${BOT_TOKEN}/sendMediaGroup?chat_id=${CHANNEL_ID}&media=%5B%7B%22type%22:%22document%22,%20%22media%22:%22attach://canary%22,%22parse_mode%22:%22MarkdownV2%22,%22caption%22:${ESCAPED}%7D%5D" -F canary="@${CANARY}" | |
push_to_debug_group: | |
if: github.event_name == 'pull_request' | |
runs-on: ubuntu-latest | |
name: Push to Debug Group | |
needs: build_debug_package | |
steps: | |
- name: Checkout Git Repository | |
uses: actions/checkout@v4 | |
- name: Post to Debug Group | |
shell: bash | |
env: | |
GROUP_DEBUG_ID: ${{ secrets.GROUP_DEBUG_ID }} | |
BOT_TOKEN: ${{ secrets.BOT_TOKEN }} | |
DEBUG: ${{ env.APK_FILE_DEBUG }} | |
COMMIT_MESSAGE: |+ | |
New push to GitHub | |
by `${{ github.triggering_actor }}` | |
run: | | |
ESCAPED=$(python3 -c 'import json,os,urllib.parse; print(urllib.parse.quote(json.dumps(os.environ["COMMIT_MESSAGE"])))') | |
cd ${{ github.workspace }} | |
curl -v "https://api.telegram.org/bot${BOT_TOKEN}/sendMediaGroup?chat_id=${GROUP_DEBUG_ID}&media=%5B%7B%22type%22:%22document%22,%20%22media%22:%22attach://debug%22,%22parse_mode%22:%22MarkdownV2%22,%22caption%22:${ESCAPED}%7D%5D" -F debug="@${DEBUG}" |