mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 22:13:26 +00:00
Automatically generated by the following script, based on the output
of lint with flake8-comma:
import re
import sys
last_filename = None
last_row = None
lines = []
for msg in sys.stdin:
m = re.match(
r"\x1b\[35mflake8 \|\x1b\[0m \x1b\[1;31m(.+):(\d+):(\d+): (\w+)", msg
)
if m:
filename, row_str, col_str, err = m.groups()
row, col = int(row_str), int(col_str)
if filename == last_filename:
assert last_row != row
else:
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
with open(filename) as f:
lines = f.readlines()
last_filename = filename
last_row = row
line = lines[row - 1]
if err in ["C812", "C815"]:
lines[row - 1] = line[: col - 1] + "," + line[col - 1 :]
elif err in ["C819"]:
assert line[col - 2] == ","
lines[row - 1] = line[: col - 2] + line[col - 1 :].lstrip(" ")
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
57 lines
1.9 KiB
Python
57 lines
1.9 KiB
Python
# Webhooks for external integrations.
|
|
from typing import Dict
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
from zerver.decorator import api_key_only_webhook_view
|
|
from zerver.lib.request import REQ, has_request_variables
|
|
from zerver.lib.response import json_success
|
|
from zerver.lib.validator import check_bool, check_dict, check_string
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
|
from zerver.models import UserProfile
|
|
|
|
GOOD_STATUSES = ['Passed', 'Fixed']
|
|
BAD_STATUSES = ['Failed', 'Broken', 'Still Failing', 'Errored', 'Canceled']
|
|
PENDING_STATUSES = ['Pending']
|
|
|
|
MESSAGE_TEMPLATE = (
|
|
'Author: {}\n'
|
|
'Build status: {} {}\n'
|
|
'Details: [changes]({}), [build log]({})'
|
|
)
|
|
|
|
@api_key_only_webhook_view('Travis')
|
|
@has_request_variables
|
|
def api_travis_webhook(request: HttpRequest, user_profile: UserProfile,
|
|
ignore_pull_requests: bool = REQ(validator=check_bool, default=True),
|
|
message: Dict[str, str]=REQ('payload', validator=check_dict([
|
|
('author_name', check_string),
|
|
('status_message', check_string),
|
|
('compare_url', check_string),
|
|
]))) -> HttpResponse:
|
|
|
|
message_status = message['status_message']
|
|
if ignore_pull_requests and message['type'] == 'pull_request':
|
|
return json_success()
|
|
|
|
if message_status in GOOD_STATUSES:
|
|
emoji = ':thumbs_up:'
|
|
elif message_status in BAD_STATUSES:
|
|
emoji = ':thumbs_down:'
|
|
elif message_status in PENDING_STATUSES:
|
|
emoji = ':counterclockwise:'
|
|
else:
|
|
emoji = f"(No emoji specified for status '{message_status}'.)"
|
|
|
|
body = MESSAGE_TEMPLATE.format(
|
|
message['author_name'],
|
|
message_status,
|
|
emoji,
|
|
message['compare_url'],
|
|
message['build_url'],
|
|
)
|
|
topic = 'builds'
|
|
|
|
check_send_webhook_message(request, user_profile, topic, body)
|
|
return json_success()
|