Meta: Nicer IRC notifications

This commit is contained in:
Ben Wiederhake 2020-11-07 22:21:26 +01:00 committed by Andreas Kling
parent 90f55e607d
commit cf9419fc4f
Notes: sideshowbarker 2024-07-19 01:25:05 +09:00
2 changed files with 109 additions and 17 deletions

View file

@ -86,30 +86,26 @@ jobs:
cat <<"EOF"
${{ toJSON(github.event) }}
EOF
- name: Generate IRC message
if: always()
id: ircmsg
run: |
${{ github.workspace }}/Meta/mangle_event_for_irc.py <<"EOF"
["${{ github.actor }}", ${{ github.run_id }}, "${{ job.status }}",
${{ toJSON(github.event) }}
]
EOF
- name: IRC result notification (direct push)
uses: rectalogic/notify-irc@v1
if: github.repository == 'SerenityOS/serenity' && github.ref == 'refs/heads/master' && github.event_name == 'push' && !cancelled()
if: github.repository == 'SerenityOS/serenity' && github.ref == 'refs/heads/master' && github.event_name == 'push' && !cancelled() && steps.ircmsg.outputs.has_output
with:
channel: "#serenityos"
nickname: serenity-ga
message: |-
${{ github.actor }} pushed master on ${{ github.event.compare }}: ${{ job.status }}
Subject: ${{ join(github.event.commits[0].message) }} (+ more, maybe)
Details: https://github.com/${{ github.repository }}/actions/runs/${{github.run_id}}
# There might be hundreds of commits in a push: Printing them all to IRC will fail.
# Accessing the last commit is not possible: The python-y '-1' is not understood.
# Counting is not available: The config-file language is not Turing complete.
# We could write a script just to format the IRC message, but this is getting silly.
# https://github.com/SerenityOS/serenity/pull/3980
message: ${{ steps.ircmsg.outputs.the_line }}
- name: IRC result notification (PR)
uses: rectalogic/notify-irc@v1
if: github.event_name == 'pull_request' && !cancelled()
if: github.repository == 'SerenityOS/serenity' && github.event_name == 'pull_request' && !cancelled() && steps.ircmsg.outputs.has_output
with:
channel: "#serenityos"
nickname: serenity-ga
message: |-
${{ github.actor }} ${{ github.event.action }} PR #${{ github.event.pull_request.number }}: ${{ job.status }}
Subject: ${{ github.event.pull_request.title }}
Details: ${{ github.event.pull_request._links.html.href }}
message: ${{ steps.ircmsg.outputs.the_line }}

96
Meta/mangle_event_for_irc.py Executable file
View file

@ -0,0 +1,96 @@
#!/usr/bin/env python3
import json
import sys
# Must be exactly three lines each!
# No trailing newline! (I.e. keep it as backslash-newline-tripleapostrophe.)
TEMPLATE_PUSH = '''\
{commit}{post_commit} (pushed master: {status}) {compare} https://github.com/SerenityOS/serenity/actions/runs/{run_id}\
'''
TEMPLATE_PR = '''\
{title} ({actor} {action}: {status}) {link} https://github.com/SerenityOS/serenity/actions/runs/{run_id}\
'''
def compute_lines(wrapper):
actor, run_id, raw_status, event = wrapper
if raw_status == 'success':
status = 'The build passed.'
elif raw_status == 'failure':
status = 'The build failed.'
else:
status = 'The build {}(?)'.format(raw_status)
if 'action' not in event:
# This is a push.
if 'commits' not in event or not event['commits']:
show_msg = '??? (No commits in event?!)'
post_commit = ''
else:
commits = event['commits']
show_commit = commits[-1]['message']
if 'skip ci' in show_commit or 'ci skip' in show_commit:
print('User requested to skip IRC notification. Okay!')
return False
# First line of the last commit:
show_msg = show_commit.split('\n')[0]
if len(commits) == 1:
post_commit = ''
elif len(commits) == 2:
post_commit = ' (+1 commit)'
else:
post_commit = ' (+{} commits)'.format(len(commits))
return TEMPLATE_PUSH.format(
actor=actor,
status=status,
run_id=run_id,
commit=show_msg,
post_commit=post_commit,
compare=event.get('compare', '???'),
)
elif 'pull_request' in event:
# This is a PR.
raw_action = event['action']
if raw_action == 'opened':
action = 'opened'
elif raw_action == 'reopened':
action = 'reopened'
elif raw_action == 'synchronize':
action = 'updated'
else:
action = '{}(?)'.format(raw_action)
if event['pull_request'].get('draft', True):
print("This is a draft PR, so IRC won't be notified.")
print('Note: No rebuild occurs when the PR is "un-drafted"!')
return False
return TEMPLATE_PR.format(
actor=actor,
action=action,
status=status,
run_id=run_id,
title=event['pull_request'].get('title', '???'),
link=event['pull_request'].get('_links', dict()).get('html', dict()).get('href', '???'),
)
else:
print('Unrecognized event type?!')
return False
def run_on(json_string):
wrapper = json.loads(json_string)
line = compute_lines(wrapper)
has_output = bool(line)
print('::set-output name=has_output::{}'.format(has_output))
print('> ::set-output name=has_output::{}'.format(has_output))
if has_output:
print('::set-output name=the_line::{}'.format(line))
print('> ::set-output name=the_line::{}'.format(line))
def run():
run_on(sys.stdin.read())
if __name__ == '__main__':
run()