Skip to content

Commit

Permalink
Add Discord webhook at end of each CI run. (qmk#20355)
Browse files Browse the repository at this point in the history
  • Loading branch information
tzarc authored Apr 7, 2023
1 parent 4ba3fdf commit 2e766a9
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 3 deletions.
12 changes: 10 additions & 2 deletions .github/workflows/ci_builds.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,11 @@ on:

jobs:
ci_builds:
if: github.repository == 'qmk/qmk_firmware'
name: "CI Build"
runs-on: self-hosted
timeout-minutes: 1380

if: github.repository == 'qmk/qmk_firmware'

strategy:
fail-fast: false
matrix:
Expand Down Expand Up @@ -58,3 +57,12 @@ jobs:
*.hex
*.uf2
.build/failed.*
- name: 'CI Discord Notification'
if: always()
working-directory: util/ci/
env:
DISCORD_WEBHOOK: ${{ secrets.CI_DISCORD_WEBHOOK }}
run: |
python3 -m pip install -r requirements.txt
python3 ./discord-results.py --branch ${{ matrix.branch }} --keymap ${{ matrix.keymap }} --url ${{ env.GITHUB_SERVER_URL }}/${{ env.GITHUB_REPOSITORY }}/actions/runs/${{ env.GITHUB_RUN_ID }}
2 changes: 1 addition & 1 deletion lib/python/qmk/cli/format/python.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
from qmk.path import normpath

py_file_suffixes = ('py',)
py_dirs = ['lib/python']
py_dirs = ['lib/python', 'util/ci']


def yapf_run(files):
Expand Down
49 changes: 49 additions & 0 deletions util/ci/discord-results.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
#!/usr/bin/env python3

import argparse
import os
import re
import sys
from pathlib import Path
from discord_webhook import DiscordWebhook, DiscordEmbed

parser = argparse.ArgumentParser(prog='discord-results.py', description='Sends a Discord webhook notification at the end of a CI run.')
parser.add_argument('-b', '--branch')
parser.add_argument('-k', '--keymap')
parser.add_argument('-u', '--url')
args = parser.parse_args()

qmk_dir = Path(__file__).resolve().parents[2].resolve()

keyboard_re = re.compile(r'CI Metadata: KEYBOARD=(.*)$', re.MULTILINE)
keymap_re = re.compile(r'CI Metadata: KEYMAP=(.*)$', re.MULTILINE)

successful_builds = sum([len(list(qmk_dir.glob(f'*.{extension}'))) for extension in ['uf2', 'bin', 'hex']])
failures = list(sorted([f.resolve() for f in (qmk_dir / '.build/').glob('failed.log.*')]))
failed_builds = []
for f in failures:
with open(f) as fh:
data = fh.read()
kb = keyboard_re.search(data).group(1)
km = keymap_re.search(data).group(1)
failed_builds.append(f'{kb}:{km}')

webhook = DiscordWebhook(url=os.getenv('DISCORD_WEBHOOK'), username="QMK GitHub CI")
if len(failed_builds) > 0:
failstr = ''
for f in failed_builds:
if len(failstr) >= 1800:
failstr += '<<snip>>'
break
failstr += f'{f}\n'

embed = DiscordEmbed(title=f':infinity: CI Build Failure ({args.branch}, {args.keymap})', description=f'**{successful_builds}** builds succeeded, **{len(failed_builds)}** builds failed:```{failstr}```', color='ff9999')
else:
embed = DiscordEmbed(title=f':infinity: CI Build Success ({args.branch}, {args.keymap})', description=f'**{successful_builds}** builds succeeded.', color='99ff99')

embed.add_embed_field(name='Build Target', value=f'[**{args.branch}**](https://github.com/qmk/qmk_firmware/tree/{args.branch}) / **{args.keymap}** keymap')
embed.add_embed_field(name='Workflow Run', value=f'[**Link**]({args.url})')
embed.set_timestamp()

webhook.add_embed(embed)
webhook.execute()
1 change: 1 addition & 0 deletions util/ci/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
discord-webhook

0 comments on commit 2e766a9

Please sign in to comment.