Merge branch 'dev' into aaronjamt/issue-444

This commit is contained in:
Aaron Tulino (Aaronjamt)
2025-09-15 17:34:02 -07:00
3 changed files with 32 additions and 23 deletions

View File

@@ -33,7 +33,7 @@ if __name__ == "__main__":
change = (
"Force Push"
if event["forced"] and not count
else f"{count} New Commit{'' if count == 1 else 's'}"
else f"{count} New Commit{'' if count == 1 else 's'}{' (Force Push)' if event['forced'] else ''}"
)
desc = f"[**{change}**]({event['compare']}) | [{branch}]({event['repository']['html_url']}/tree/{branch})\n"
for i, commit in enumerate(event["commits"]):
@@ -49,7 +49,7 @@ if __name__ == "__main__":
desc = desc.rsplit("\n", 1)[0] + f"\n+ {count - i} more commits"
break
url = event["compare"]
color = 16723712 if event["forced"] else 11761899
color = 11761899
case "release":
webhook = "RELEASE_WEBHOOK"

View File

@@ -85,19 +85,22 @@ jobs:
if ${{ github.ref_name == 'dev' }} ; then
SHOULD_DEVBUILD=${{ !contains(github.event.head_commit.message, '--nobuild') }}
SHOULD_UPLOAD=$SHOULD_DEVBUILD
SHOULD_DEPLOY=$SHOULD_DEVBUILD
elif ${{ startsWith(github.ref, 'refs/tags/') }} ; then
SHOULD_UPLOAD=true
fi
elif ${{ !!github.event.pull_request }} ; then
SHOULD_PRCOMMENT=${{ matrix.target == env.DEFAULT_TARGET }}
SHOULD_UPLOAD=true
SHOULD_PRBUILD=${{ matrix.target == env.DEFAULT_TARGET }}
SHOULD_UPLOAD=$SHOULD_PRBUILD
SHOULD_DEPLOY=$SHOULD_PRBUILD
else
echo "What?"
exit 1
fi
echo "SHOULD_DEVBUILD=$SHOULD_DEVBUILD" >> $GITHUB_ENV
echo "SHOULD_PRCOMMENT=$SHOULD_PRCOMMENT" >> $GITHUB_ENV
echo "SHOULD_PRBUILD=$SHOULD_PRBUILD" >> $GITHUB_ENV
echo "SHOULD_UPLOAD=$SHOULD_UPLOAD" >> $GITHUB_ENV
echo "SHOULD_DEPLOY=$SHOULD_DEPLOY" >> $GITHUB_ENV
- name: "Build the firmware and apps"
id: build-fw
@@ -150,7 +153,7 @@ jobs:
"${{ secrets.INDEXER_URL }}"/firmware/uploadfiles
- name: "Force deploy website to refresh devbuilds"
if: ${{ env.SHOULD_DEVBUILD == 'true' }}
if: ${{ env.SHOULD_DEPLOY == 'true' }}
uses: Codex-/return-dispatch@v2
id: force-deploy
with:
@@ -163,7 +166,7 @@ jobs:
workflow_job_steps_retry_seconds: 5
- name: "Calculate DFU sizes"
if: ${{ env.SHOULD_PRCOMMENT == 'true' }}
if: ${{ env.SHOULD_PRBUILD == 'true' }}
run: |
curl -L "${{ secrets.INDEXER_URL }}"/firmware/development/f7/full_dfu -o dev.dfu
dfu_size_new=$(du --apparent-size -B 1 artifacts/flipper-z-${TARGET}-full-*.dfu | cut -f1)
@@ -186,7 +189,7 @@ jobs:
echo "FLASH_USABLE=$FLASH_USABLE" >> $GITHUB_ENV
- name: "Find previous comment"
if: ${{ env.SHOULD_PRCOMMENT == 'true' }}
if: ${{ env.SHOULD_PRBUILD == 'true' }}
uses: peter-evans/find-comment@v3
id: find-comment
with:
@@ -194,22 +197,8 @@ jobs:
comment-author: "github-actions[bot]"
body-includes: "Compiled ${{ matrix.target }} firmware for commit"
- name: "Create or update comment"
if: ${{ env.SHOULD_PRCOMMENT == 'true' }}
uses: peter-evans/create-or-update-comment@v4
with:
comment-id: ${{ steps.find-comment.outputs.comment-id }}
issue-number: ${{ github.event.pull_request.number }}
body: |
**Compiled ${{ matrix.target }} firmware for commit `${{steps.names.outputs.commit_sha}}`:**
- [☁️ Flipper Lab/App](https://lab.flipper.net/?url=${{secrets.INDEXER_URL}}/builds/firmware/${{steps.names.outputs.branch_name}}/flipper-z-${{steps.names.outputs.default_target}}-update-${{steps.names.outputs.suffix}}.tgz&channel=mntm-${{steps.names.outputs.branch_name}}&version=${{steps.names.outputs.commit_sha}})
- [📦 qFlipper Package](${{secrets.INDEXER_URL}}/builds/firmware/${{steps.names.outputs.branch_name}}/flipper-z-${{steps.names.outputs.default_target}}-update-${{steps.names.outputs.suffix}}.tgz)
- DFU Size: `${{ env.DFU_SIZE }}` (`${{ env.DFU_DIFF }}` from dev)
- Free Flash: `${{ env.FLASH_FREE }}` (`${{ env.FLASH_USABLE }}` usable)
edit-mode: replace
- name: "Wait for deploy (Run ID ${{ steps.force-deploy.outputs.run_id }})"
if: ${{ env.SHOULD_DEVBUILD == 'true' }}
if: ${{ env.SHOULD_DEPLOY == 'true' }}
uses: Codex-/await-remote-run@v1
with:
token: ${{ github.token }}
@@ -219,6 +208,21 @@ jobs:
run_timeout_seconds: 300
poll_interval_ms: 5000
- name: "Create or update comment"
if: ${{ env.SHOULD_PRBUILD == 'true' }}
uses: peter-evans/create-or-update-comment@v4
with:
comment-id: ${{ steps.find-comment.outputs.comment-id }}
issue-number: ${{ github.event.pull_request.number }}
body: |
**Compiled ${{ matrix.target }} firmware for commit `${{steps.names.outputs.commit_sha}}`:**
- [🖥️ Web Updater](https://momentum-fw.dev/update?branch=${{steps.names.outputs.branch_name_urlencoded}})
- [☁️ Flipper Lab/App](https://lab.flipper.net/?url=${{secrets.INDEXER_URL}}/builds/firmware/${{steps.names.outputs.branch_name}}/flipper-z-${{steps.names.outputs.default_target}}-update-${{steps.names.outputs.suffix}}.tgz&channel=mntm-${{steps.names.outputs.branch_name}}&version=${{steps.names.outputs.commit_sha}})
- [📦 qFlipper Package](${{secrets.INDEXER_URL}}/builds/firmware/${{steps.names.outputs.branch_name}}/flipper-z-${{steps.names.outputs.default_target}}-update-${{steps.names.outputs.suffix}}.tgz)
- DFU Size: `${{ env.DFU_SIZE }}` (`${{ env.DFU_DIFF }}` from dev)
- Free Flash: `${{ env.FLASH_FREE }}` (`${{ env.FLASH_USABLE }}` usable)
edit-mode: replace
- name: "Send devbuild webhook"
env:
INDEXER_URL: ${{ secrets.INDEXER_URL }}

View File

@@ -9,6 +9,7 @@ import re
import shlex
import ssl
import string
import urllib.parse
import urllib.request
@@ -63,6 +64,7 @@ def get_details(event, args):
ref = event["ref"]
data["commit_sha"] = data["commit_hash"][:8]
data["branch_name"] = re.sub("refs/\w+/", "", ref)
data["branch_name_urlencoded"] = urllib.parse.quote_plus(data["branch_name"])
data["suffix"] = (
"mntm-"
+ data["branch_name"].removeprefix("mntm-").replace("/", "-")
@@ -94,6 +96,9 @@ def add_envs(data, gh_env_file, gh_out_file, args):
add_env("DIST_SUFFIX", data["suffix"], gh_env_file)
add_env("WORKFLOW_BRANCH_OR_TAG", data["branch_name"], gh_env_file)
add_set_output_var("branch_name", data["branch_name"], gh_out_file)
add_set_output_var(
"branch_name_urlencoded", data["branch_name_urlencoded"], gh_out_file
)
add_set_output_var("commit_sha", data["commit_sha"], gh_out_file)
add_set_output_var("default_target", os.getenv("DEFAULT_TARGET"), gh_out_file)
add_set_output_var("suffix", data["suffix"], gh_out_file)