ci: report connections failures with GitHub API

On occasion the scripts that use the GitHub API fail without logging any
useful error:

    ./scripts/get_github_labels.py --id=1568 --has-label=ci/skip/e2e
    Traceback (most recent call last):
      File "./scripts/get_github_labels.py", line 71, in <module>
        main()
      File "./scripts/get_github_labels.py", line 55, in main
        names = get_names(json)
      File "./scripts/get_github_labels.py", line 40, in get_names
        names.append(label['name'])
    TypeError: string indices must be integers

While debugging, it seems that the limit of API calls is reached:

    403 Client Error: rate limit exceeded

It is useful to have failure messages reported in the output of the CI
jobs for future potential troubleshooting.

Signed-off-by: Niels de Vos <ndevos@redhat.com>
This commit is contained in:
Niels de Vos 2020-10-13 10:34:29 +02:00 committed by mergify[bot]
parent bd247db377
commit aa062513c0
2 changed files with 28 additions and 5 deletions

View File

@ -4,9 +4,14 @@ Fetches the labels of an Issue or Pull-Request from GitHub.
Parameters: Parameters:
--id=<id>: the number of the the GitHub Issue or Pull-Request --id=<id>: the number of the the GitHub Issue or Pull-Request
--has-label=<label>: label to check (exit 0 if set, 1 unset), without --has-label=<label>: label to check (exit 0 if set, 2 unset), without
--has-label, all labels of the Issue or Pull-Request --has-label, all labels of the Issue or Pull-Request
get printed. get printed.
Exit codes:
0: success
1: any unexpected failure
2: --has-label=<label> was passed, <label> is not set on the PR
''' '''
import argparse import argparse
@ -28,6 +33,10 @@ def get_json_labels(gh_id):
url = LABEL_URL_FMT % gh_id url = LABEL_URL_FMT % gh_id
headers = {'Accept': 'application/vnd.github.v3+json'} headers = {'Accept': 'application/vnd.github.v3+json'}
res = requests.get(url, headers=headers) res = requests.get(url, headers=headers)
# if "res.status_code != requests.codes.ok", raise an exception
res.raise_for_status()
return res.json() return res.json()
@ -51,15 +60,20 @@ def main():
args = parser.parse_args() args = parser.parse_args()
# get the labels for the issue # get the labels for the issue
try:
json = get_json_labels(args.id) json = get_json_labels(args.id)
except Exception as err:
print('Error: %s' % err)
sys.exit(1)
names = get_names(json) names = get_names(json)
# in case --has-label is passed, exit with 0 or 1 # in case --has-label is passed, exit with 0 or 2
if args.has_label: if args.has_label:
if args.has_label in names: if args.has_label in names:
sys.exit(0) sys.exit(0)
else: else:
sys.exit(1) sys.exit(2)
# --has-label was not passed, list all labels # --has-label was not passed, list all labels
else: else:
for name in names: for name in names:

View File

@ -25,6 +25,10 @@ def get_json_releases():
''' '''
headers = {'Accept': 'application/vnd.github.v3+json'} headers = {'Accept': 'application/vnd.github.v3+json'}
res = requests.get(RELEASE_URL, headers=headers) res = requests.get(RELEASE_URL, headers=headers)
# if "res.status_code != requests.codes.ok", raise an exception
res.raise_for_status()
return res.json() return res.json()
@ -47,7 +51,12 @@ def main():
args = parser.parse_args() args = parser.parse_args()
# get all the releases # get all the releases
try:
json = get_json_releases() json = get_json_releases()
except Exception as err:
print('Error: %s' % err)
sys.exit(1)
releases = get_releases(json) releases = get_releases(json)
# in case --version is passed, exit with 0 or 1 # in case --version is passed, exit with 0 or 1