Skip to content

Commit 2e766a9

Browse files
authored
Add Discord webhook at end of each CI run. (qmk#20355)
1 parent 4ba3fdf commit 2e766a9

File tree

4 files changed

+61
-3
lines changed

4 files changed

+61
-3
lines changed

.github/workflows/ci_builds.yml

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -10,12 +10,11 @@ on:
1010

1111
jobs:
1212
ci_builds:
13+
if: github.repository == 'qmk/qmk_firmware'
1314
name: "CI Build"
1415
runs-on: self-hosted
1516
timeout-minutes: 1380
1617

17-
if: github.repository == 'qmk/qmk_firmware'
18-
1918
strategy:
2019
fail-fast: false
2120
matrix:
@@ -58,3 +57,12 @@ jobs:
5857
*.hex
5958
*.uf2
6059
.build/failed.*
60+
61+
- name: 'CI Discord Notification'
62+
if: always()
63+
working-directory: util/ci/
64+
env:
65+
DISCORD_WEBHOOK: ${{ secrets.CI_DISCORD_WEBHOOK }}
66+
run: |
67+
python3 -m pip install -r requirements.txt
68+
python3 ./discord-results.py --branch ${{ matrix.branch }} --keymap ${{ matrix.keymap }} --url ${{ env.GITHUB_SERVER_URL }}/${{ env.GITHUB_REPOSITORY }}/actions/runs/${{ env.GITHUB_RUN_ID }}

lib/python/qmk/cli/format/python.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
from qmk.path import normpath
88

99
py_file_suffixes = ('py',)
10-
py_dirs = ['lib/python']
10+
py_dirs = ['lib/python', 'util/ci']
1111

1212

1313
def yapf_run(files):

util/ci/discord-results.py

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
#!/usr/bin/env python3
2+
3+
import argparse
4+
import os
5+
import re
6+
import sys
7+
from pathlib import Path
8+
from discord_webhook import DiscordWebhook, DiscordEmbed
9+
10+
parser = argparse.ArgumentParser(prog='discord-results.py', description='Sends a Discord webhook notification at the end of a CI run.')
11+
parser.add_argument('-b', '--branch')
12+
parser.add_argument('-k', '--keymap')
13+
parser.add_argument('-u', '--url')
14+
args = parser.parse_args()
15+
16+
qmk_dir = Path(__file__).resolve().parents[2].resolve()
17+
18+
keyboard_re = re.compile(r'CI Metadata: KEYBOARD=(.*)$', re.MULTILINE)
19+
keymap_re = re.compile(r'CI Metadata: KEYMAP=(.*)$', re.MULTILINE)
20+
21+
successful_builds = sum([len(list(qmk_dir.glob(f'*.{extension}'))) for extension in ['uf2', 'bin', 'hex']])
22+
failures = list(sorted([f.resolve() for f in (qmk_dir / '.build/').glob('failed.log.*')]))
23+
failed_builds = []
24+
for f in failures:
25+
with open(f) as fh:
26+
data = fh.read()
27+
kb = keyboard_re.search(data).group(1)
28+
km = keymap_re.search(data).group(1)
29+
failed_builds.append(f'{kb}:{km}')
30+
31+
webhook = DiscordWebhook(url=os.getenv('DISCORD_WEBHOOK'), username="QMK GitHub CI")
32+
if len(failed_builds) > 0:
33+
failstr = ''
34+
for f in failed_builds:
35+
if len(failstr) >= 1800:
36+
failstr += '<<snip>>'
37+
break
38+
failstr += f'{f}\n'
39+
40+
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')
41+
else:
42+
embed = DiscordEmbed(title=f':infinity: CI Build Success ({args.branch}, {args.keymap})', description=f'**{successful_builds}** builds succeeded.', color='99ff99')
43+
44+
embed.add_embed_field(name='Build Target', value=f'[**{args.branch}**](https://github.com/qmk/qmk_firmware/tree/{args.branch}) / **{args.keymap}** keymap')
45+
embed.add_embed_field(name='Workflow Run', value=f'[**Link**]({args.url})')
46+
embed.set_timestamp()
47+
48+
webhook.add_embed(embed)
49+
webhook.execute()

util/ci/requirements.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
discord-webhook

0 commit comments

Comments
 (0)