workflow: Comment build size on all PRs
This works by uploading the data from the main workflow with low permissions as an artifact, then downloading the data in a workflow with higher permissions to post the comment. Third party actions are fixed at a commit, in case they get compromised. Also set the build-firmware VM to ubuntu-22.04, which was missed when updating workflow deps earlier.
This commit is contained in:
parent
9b2e1b3250
commit
012c3d25f3
40
.github/workflows/main.yml
vendored
40
.github/workflows/main.yml
vendored
|
@ -15,7 +15,7 @@ on:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-firmware:
|
build-firmware:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-22.04
|
||||||
container:
|
container:
|
||||||
image: infinitime/infinitime-build
|
image: infinitime/infinitime-build
|
||||||
outputs:
|
outputs:
|
||||||
|
@ -147,6 +147,7 @@ jobs:
|
||||||
|
|
||||||
compare-build-size:
|
compare-build-size:
|
||||||
if: github.event_name == 'pull_request'
|
if: github.event_name == 'pull_request'
|
||||||
|
name: 'Compare build size'
|
||||||
needs: [build-firmware, get-base-ref-size]
|
needs: [build-firmware, get-base-ref-size]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
|
@ -181,28 +182,19 @@ jobs:
|
||||||
echo "data_diff=$DATA_SIZE_DIFF" >> $GITHUB_OUTPUT
|
echo "data_diff=$DATA_SIZE_DIFF" >> $GITHUB_OUTPUT
|
||||||
echo "bss_diff=$BSS_SIZE_DIFF" >> $GITHUB_OUTPUT
|
echo "bss_diff=$BSS_SIZE_DIFF" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Find Comment
|
- name: Write comment information to files
|
||||||
# Due to a security concern, comments can only be created in the context of branches in the repo.
|
run: |
|
||||||
# PRs from forks can't get the comment.
|
tee comment << EOF
|
||||||
if: github.event.pull_request.head.repo.full_name == github.repository
|
Build size and comparison to ${{ github.base_ref }}:
|
||||||
uses: peter-evans/find-comment@v2
|
| Section | Size | Difference |
|
||||||
id: build-size-comment
|
| ------- | ---- | ---------- |
|
||||||
with:
|
| text | ${{ needs.build-firmware.outputs.text_size }}B | ${{ steps.output-sizes-diff.outputs.text_diff }}B |
|
||||||
issue-number: ${{ github.event.pull_request.number }}
|
| data | ${{ needs.build-firmware.outputs.data_size }}B | ${{ steps.output-sizes-diff.outputs.data_diff }}B |
|
||||||
comment-author: 'github-actions[bot]'
|
| bss | ${{ needs.build-firmware.outputs.bss_size }}B | ${{ steps.output-sizes-diff.outputs.bss_diff }}B |
|
||||||
body-includes: Build size and comparison to
|
EOF
|
||||||
|
|
||||||
- name: Create or update comment
|
- name: Upload comment
|
||||||
if: github.event.pull_request.head.repo.full_name == github.repository
|
uses: actions/upload-artifact@v3
|
||||||
uses: peter-evans/create-or-update-comment@v2
|
|
||||||
with:
|
with:
|
||||||
comment-id: ${{ steps.build-size-comment.outputs.comment-id }}
|
name: comment
|
||||||
issue-number: ${{ github.event.pull_request.number }}
|
path: comment
|
||||||
body: |
|
|
||||||
Build size and comparison to ${{ github.base_ref }}:
|
|
||||||
| Section | Size | Difference |
|
|
||||||
| ------- | ---- | ---------- |
|
|
||||||
| text | ${{ needs.build-firmware.outputs.text_size }}B | ${{ steps.output-sizes-diff.outputs.text_diff }}B |
|
|
||||||
| data | ${{ needs.build-firmware.outputs.data_size }}B | ${{ steps.output-sizes-diff.outputs.data_diff }}B |
|
|
||||||
| bss | ${{ needs.build-firmware.outputs.bss_size }}B | ${{ steps.output-sizes-diff.outputs.bss_diff }}B |
|
|
||||||
edit-mode: replace
|
|
||||||
|
|
49
.github/workflows/pr-comment.yml
vendored
Normal file
49
.github/workflows/pr-comment.yml
vendored
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
# THIS WORKFLOW HAS WRITE PERMISSIONS TO THE REPO.
|
||||||
|
# MAKE SURE IT NEVER RUNS ANY CODE FROM THE FORK
|
||||||
|
|
||||||
|
name: PR comment
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request_target:
|
||||||
|
branches: [ develop ]
|
||||||
|
paths-ignore:
|
||||||
|
- 'doc/**'
|
||||||
|
- '**.md'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
comment:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Wait for builds to finish
|
||||||
|
id: wait-for-build
|
||||||
|
uses: fountainhead/action-wait-for-check@297be350cf8393728ea4d4b39435c7d7ae167c93
|
||||||
|
with:
|
||||||
|
checkName: 'Compare build size'
|
||||||
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
ref: ${{ github.head_ref }}
|
||||||
|
|
||||||
|
- if: steps.wait-for-build.outputs.conclusion != 'success'
|
||||||
|
run: exit 1
|
||||||
|
|
||||||
|
- name: Download artifact
|
||||||
|
uses: dawidd6/action-download-artifact@bd10f381a96414ce2b13a11bfa89902ba7cea07f
|
||||||
|
with:
|
||||||
|
workflow: main.yml
|
||||||
|
pr: ${{ github.event.pull_request.number }}
|
||||||
|
name: comment
|
||||||
|
|
||||||
|
- name: Find Comment
|
||||||
|
id: find-comment
|
||||||
|
uses: peter-evans/find-comment@81e2da3af01c92f83cb927cf3ace0e085617c556
|
||||||
|
with:
|
||||||
|
issue-number: ${{ github.event.pull_request.number }}
|
||||||
|
comment-author: 'github-actions[bot]'
|
||||||
|
body-includes: Build size and comparison to
|
||||||
|
|
||||||
|
- name: Create or update comment
|
||||||
|
uses: peter-evans/create-or-update-comment@5adcb0bb0f9fb3f95ef05400558bdb3f329ee808
|
||||||
|
with:
|
||||||
|
comment-id: ${{ steps.find-comment.outputs.comment-id }}
|
||||||
|
issue-number: ${{ github.event.pull_request.number }}
|
||||||
|
body-file: comment
|
||||||
|
edit-mode: replace
|
Loading…
Reference in New Issue
Block a user