Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Do not reset all labels on commit #2110

Merged
merged 46 commits into from
Dec 13, 2023
Merged
Show file tree
Hide file tree
Changes from 41 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
a2740af
Do not reset all labels on commit
iarspider Nov 9, 2023
c54ca81
Add pyproject.toml with Black and pylint configs
iarspider Nov 9, 2023
da8903e
Changes from review
iarspider Nov 9, 2023
3c20811
Changes from review (1/2)
iarspider Nov 10, 2023
ec2bd46
Changes from review (2/2)
iarspider Nov 11, 2023
5942437
Code-style
iarspider Nov 11, 2023
161a818
Fixes after tests
iarspider Nov 13, 2023
015fa63
Fix style
iarspider Nov 13, 2023
18faffb
Fix initial comment generation (watchers + categories)
iarspider Nov 14, 2023
75f7817
Update process_pr.py
iarspider Nov 15, 2023
82f51ed
Move get_last_commit and get_pr_commits_reversed to github_utils
iarspider Nov 16, 2023
1fe6a65
Code-format
iarspider Nov 16, 2023
7a2145e
Code-format
iarspider Nov 16, 2023
995050b
Fix too-many-commits handling
iarspider Nov 20, 2023
d785a37
Convert packages to categories; fix timestamp handling
iarspider Nov 24, 2023
758e56a
Use API to get list of changed files
iarspider Nov 24, 2023
9ac15d3
Fix tests, code-checks signatures; restorre special handling for ORP …
iarspider Dec 1, 2023
c057d8e
Move code to determine signing-cats back to where it was
iarspider Dec 1, 2023
e5bc0f7
Remove extra check
iarspider Dec 1, 2023
0ee9c9e
Change wording
iarspider Dec 1, 2023
042b550
Remove extra formatting
iarspider Dec 4, 2023
1138c0b
Fix extra braces
iarspider Dec 4, 2023
417d609
Reset all signatures on commit in external/user repos
iarspider Dec 4, 2023
a223925
Do not trigger tests on code-checks signature
iarspider Dec 6, 2023
2657914
Exclude orp and tests as well
iarspider Dec 6, 2023
c97e309
Check for rate-limits before checking for / loading commit cache
iarspider Dec 6, 2023
3aee759
Apply suggestions from code-review
iarspider Dec 6, 2023
0cb4fe9
More changes from review
iarspider Dec 6, 2023
a39283a
Compress commit cache as needed; handle commits with many changed files
iarspider Dec 6, 2023
98e9500
Reset signatures for manually-assigned categories on commit; other ch…
iarspider Dec 6, 2023
5fcd33c
Missed one comment
iarspider Dec 6, 2023
5f4f844
Fix for github_utils
iarspider Dec 7, 2023
fc24b32
Fix for fix for github_utils
iarspider Dec 7, 2023
7539456
Check rates at every call to github_api()
iarspider Dec 7, 2023
77095be
Changes from review
iarspider Dec 7, 2023
4b453f0
Only check commits if the issue is a PR
iarspider Dec 7, 2023
6a22185
Hack to set tests signature to pending
iarspider Dec 7, 2023
c8530bb
Don't recalculate tests signature
iarspider Dec 11, 2023
524a16f
Remove dead branch
iarspider Dec 11, 2023
2e1d4ce
Changes from review
iarspider Dec 11, 2023
4f43741
Fix
iarspider Dec 12, 2023
2654bf7
Fix for fix
iarspider Dec 12, 2023
712cb46
Changes from review
iarspider Dec 12, 2023
377fa08
Add protection from printing non-ascii characters
iarspider Dec 12, 2023
d29f967
reset test_comment on every new commit
smuzaffar Dec 12, 2023
95d76a0
Update process-pull-request.py
smuzaffar Dec 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion check-future-commits-prs.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@
if exists(join(repo_dir, "repo_config.py")):
sys.path.insert(0, repo_dir)
import repo_config
from process_pr import get_last_commit
from github_utils import get_last_commit

gh = Github(login_or_token=open(expanduser(repo_config.GH_TOKEN)).read().strip())
api_rate_limits(gh)
Expand Down
1 change: 1 addition & 0 deletions cms_static.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
CMSBUILD_GH_USER = "cmsbuild"
CMSBOT_IGNORE_MSG = "<cmsbot>\s*</cmsbot>"
CMSBOT_NO_NOTIFY_MSG = "<notify>\s*</notify>"
CMSBOT_TECHNICAL_MSG = "cms-bot internal usage"
VALID_CMS_SW_REPOS_FOR_TESTS = [
"cmssw",
"cmsdist",
Expand Down
70 changes: 66 additions & 4 deletions github_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -522,6 +522,29 @@ def get_rate_limits():
return github_api(uri="/rate_limit", method="GET")


def merge_dicts(old, new):
for k, v in new.items():
if k not in old:
old[k] = new[k]
continue

if isinstance(v, dict):
old[k] = merge_dicts(old[k], new[k])
continue

if isinstance(v, list):
old[k].extend(v)
continue

if old[k] != new[k]:
raise RuntimeError(
f"Unable to merge dictionaries: value for key {k} differs. "
"Old {old[k]} {type(old[k])}, new {new[k]}, {type(new[k])}"
)

return old


def github_api(
uri,
params=None,
Expand All @@ -533,10 +556,15 @@ def github_api(
last_page=False,
all_pages=True,
max_pages=-1,
status=[],
status=None,
):
if status is None:
status = []

check_rate_limits(msg=False)

global GH_RATE_LIMIT, GH_PAGE_RANGE
if max_pages > 0 and page > max_pages:
if max_pages > 0 and page > max_pages: # noqa for readability
return "[]" if raw else []
if not params:
params = {}
Expand Down Expand Up @@ -604,11 +632,15 @@ def github_api(
all_pages=False,
)
for page in GH_PAGE_RANGE:
if max_pages > 0 and page > max_pages:
if max_pages > 0 and page > max_pages: # noqa for readability
break
data += github_api(
new_data = github_api(
uri, params, method, headers, page, raw=raw, per_page=per_page, all_pages=False
)
if isinstance(data, dict):
data = merge_dicts(data, new_data)
else:
data += new_data
return data


Expand Down Expand Up @@ -647,6 +679,10 @@ def pr_get_changed_files(pr):
return rez


def get_commit(repository, commit_sha):
return github_api(f"/repos/{repository}/commits/{commit_sha}", method="GET")


def get_unix_time(data_obj):
return data_obj.strftime("%s")

Expand Down Expand Up @@ -901,3 +937,29 @@ def get_pr(repository, pr_id):
data = github_api("/repos/%s/pulls/%s" % (repository, pr_id), method="GET")

return data


def get_last_commit(pr):
commits_ = get_pr_commits_reversed(pr)
if commits_:
return commits_[-1]
else:
return None


def get_pr_commits_reversed(pr):
"""
:param pr:
:return: PaginatedList[Commit] | List[Commit]
"""
try:
# This requires at least PyGithub 1.23.0. Making it optional for the moment.
return pr.get_commits().reversed
except: # noqa
# This seems to fail for more than 250 commits. Not sure if the
# problem is github itself or the bindings.
try:
return reversed(list(pr.get_commits()))
except IndexError:
print("Index error: May be PR with no commits")
return []
Loading
Loading