2021-09-15 12:59:39 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import sys
|
2021-09-15 13:04:29 +00:00
|
|
|
import logging
|
2021-10-20 11:25:14 +00:00
|
|
|
from github import Github
|
2021-11-26 14:00:09 +00:00
|
|
|
|
|
|
|
from env_helper import GITHUB_RUN_ID, GITHUB_REPOSITORY, GITHUB_SERVER_URL
|
|
|
|
from pr_info import PRInfo
|
2021-10-20 11:25:14 +00:00
|
|
|
from get_robot_token import get_best_robot_token
|
2021-11-12 12:36:25 +00:00
|
|
|
from commit_status_helper import get_commit
|
2021-09-15 12:59:39 +00:00
|
|
|
|
|
|
|
NAME = 'Run Check (actions)'
|
|
|
|
|
|
|
|
TRUSTED_ORG_IDS = {
|
|
|
|
7409213, # yandex
|
|
|
|
28471076, # altinity
|
|
|
|
54801242, # clickhouse
|
|
|
|
}
|
|
|
|
|
|
|
|
OK_TEST_LABEL = set(["can be tested", "release", "pr-documentation", "pr-doc-fix"])
|
|
|
|
DO_NOT_TEST_LABEL = "do not test"
|
|
|
|
|
|
|
|
# Individual trusted contirbutors who are not in any trusted organization.
|
|
|
|
# Can be changed in runtime: we will append users that we learned to be in
|
|
|
|
# a trusted org, to save GitHub API calls.
|
2021-12-13 14:34:17 +00:00
|
|
|
TRUSTED_CONTRIBUTORS = {e.lower() for e in [
|
2021-09-15 12:59:39 +00:00
|
|
|
"achimbab",
|
|
|
|
"adevyatova ", # DOCSUP
|
|
|
|
"Algunenano", # Raúl Marín, Tinybird
|
|
|
|
"AnaUvarova", # DOCSUP
|
|
|
|
"anauvarova", # technical writer, Yandex
|
|
|
|
"annvsh", # technical writer, Yandex
|
|
|
|
"atereh", # DOCSUP
|
|
|
|
"azat",
|
|
|
|
"bharatnc", # Newbie, but already with many contributions.
|
|
|
|
"bobrik", # Seasoned contributor, CloundFlare
|
|
|
|
"BohuTANG",
|
2021-11-17 23:05:41 +00:00
|
|
|
"codyrobert", # Flickerbox engineer
|
2021-12-16 13:13:40 +00:00
|
|
|
"cwurm", # Employee
|
2021-09-15 12:59:39 +00:00
|
|
|
"damozhaeva", # DOCSUP
|
|
|
|
"den-crane",
|
2021-11-23 21:34:57 +00:00
|
|
|
"flickerbox-tom", # Flickerbox
|
2021-09-15 12:59:39 +00:00
|
|
|
"gyuton", # technical writer, Yandex
|
|
|
|
"hagen1778", # Roman Khavronenko, seasoned contributor
|
|
|
|
"hczhcz",
|
|
|
|
"hexiaoting", # Seasoned contributor
|
|
|
|
"ildus", # adjust, ex-pgpro
|
|
|
|
"javisantana", # a Spanish ClickHouse enthusiast, ex-Carto
|
|
|
|
"ka1bi4", # DOCSUP
|
|
|
|
"kirillikoff", # DOCSUP
|
|
|
|
"kitaisreal", # Seasoned contributor
|
|
|
|
"kreuzerkrieg",
|
|
|
|
"lehasm", # DOCSUP
|
|
|
|
"michon470", # DOCSUP
|
|
|
|
"MyroTk", # Tester in Altinity
|
|
|
|
"myrrc", # Michael Kot, Altinity
|
|
|
|
"nikvas0",
|
|
|
|
"nvartolomei",
|
|
|
|
"olgarev", # DOCSUP
|
|
|
|
"otrazhenia", # Yandex docs contractor
|
|
|
|
"pdv-ru", # DOCSUP
|
|
|
|
"podshumok", # cmake expert from QRator Labs
|
|
|
|
"s-mx", # Maxim Sabyanin, former employee, present contributor
|
|
|
|
"sevirov", # technical writer, Yandex
|
|
|
|
"spongedu", # Seasoned contributor
|
|
|
|
"ucasFL", # Amos Bird's friend
|
|
|
|
"vdimir", # Employee
|
|
|
|
"vzakaznikov",
|
|
|
|
"YiuRULE",
|
2021-12-13 14:34:17 +00:00
|
|
|
"zlobober", # Developer of YT
|
2021-12-17 05:55:46 +00:00
|
|
|
"ilejn", # Arenadata, responsible for Kerberized Kafka
|
2021-12-13 14:34:17 +00:00
|
|
|
]}
|
2021-09-15 12:59:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
def pr_is_by_trusted_user(pr_user_login, pr_user_orgs):
|
2021-12-13 14:34:17 +00:00
|
|
|
if pr_user_login.lower() in TRUSTED_CONTRIBUTORS:
|
2021-10-27 07:03:24 +00:00
|
|
|
logging.info("User '%s' is trusted", pr_user_login)
|
2021-09-15 12:59:39 +00:00
|
|
|
return True
|
|
|
|
|
2021-10-27 07:03:24 +00:00
|
|
|
logging.info("User '%s' is not trusted", pr_user_login)
|
2021-09-15 12:59:39 +00:00
|
|
|
|
|
|
|
for org_id in pr_user_orgs:
|
|
|
|
if org_id in TRUSTED_ORG_IDS:
|
2021-10-27 07:03:24 +00:00
|
|
|
logging.info("Org '%s' is trusted; will mark user %s as trusted", org_id, pr_user_login)
|
2021-09-15 12:59:39 +00:00
|
|
|
return True
|
2021-10-27 07:03:24 +00:00
|
|
|
logging.info("Org '%s' is not trusted", org_id)
|
2021-09-15 12:59:39 +00:00
|
|
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
# Returns whether we should look into individual checks for this PR. If not, it
|
|
|
|
# can be skipped entirely.
|
|
|
|
def should_run_checks_for_pr(pr_info):
|
|
|
|
# Consider the labels and whether the user is trusted.
|
2021-12-22 08:13:04 +00:00
|
|
|
print("Got labels", pr_info.labels)
|
2021-09-30 11:26:46 +00:00
|
|
|
force_labels = set(['force tests']).intersection(pr_info.labels)
|
2021-09-15 12:59:39 +00:00
|
|
|
if force_labels:
|
|
|
|
return True, "Labeled '{}'".format(', '.join(force_labels))
|
|
|
|
|
|
|
|
if 'do not test' in pr_info.labels:
|
|
|
|
return False, "Labeled 'do not test'"
|
|
|
|
|
|
|
|
if 'can be tested' not in pr_info.labels and not pr_is_by_trusted_user(pr_info.user_login, pr_info.user_orgs):
|
|
|
|
return False, "Needs 'can be tested' label"
|
|
|
|
|
2021-09-30 11:26:46 +00:00
|
|
|
if 'release' in pr_info.labels or 'pr-backport' in pr_info.labels or 'pr-cherrypick' in pr_info.labels:
|
|
|
|
return False, "Don't try new checks for release/backports/cherry-picks"
|
|
|
|
|
2021-09-15 12:59:39 +00:00
|
|
|
return True, "No special conditions apply"
|
|
|
|
|
2021-11-26 14:00:09 +00:00
|
|
|
|
2021-09-15 12:59:39 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
logging.basicConfig(level=logging.INFO)
|
|
|
|
|
2021-12-22 07:54:50 +00:00
|
|
|
pr_info = PRInfo(need_orgs=True, labels_from_api=True)
|
2021-09-15 12:59:39 +00:00
|
|
|
can_run, description = should_run_checks_for_pr(pr_info)
|
2021-10-20 11:25:14 +00:00
|
|
|
gh = Github(get_best_robot_token())
|
|
|
|
commit = get_commit(gh, pr_info.sha)
|
2021-11-26 14:00:09 +00:00
|
|
|
url = f"{GITHUB_SERVER_URL}/{GITHUB_REPOSITORY}/actions/runs/{GITHUB_RUN_ID}"
|
2021-09-15 12:59:39 +00:00
|
|
|
if not can_run:
|
2021-09-16 10:39:36 +00:00
|
|
|
print("::notice ::Cannot run")
|
2021-10-20 11:25:14 +00:00
|
|
|
commit.create_status(context=NAME, description=description, state="failure", target_url=url)
|
2021-09-15 12:59:39 +00:00
|
|
|
sys.exit(1)
|
2021-09-15 13:36:48 +00:00
|
|
|
else:
|
2021-10-26 10:34:12 +00:00
|
|
|
if 'pr-documentation' in pr_info.labels or 'pr-doc-fix' in pr_info.labels:
|
|
|
|
commit.create_status(context=NAME, description="Skipping checks for documentation", state="success", target_url=url)
|
|
|
|
print("::notice ::Can run, but it's documentation PR, skipping")
|
|
|
|
else:
|
|
|
|
print("::notice ::Can run")
|
|
|
|
commit.create_status(context=NAME, description=description, state="pending", target_url=url)
|