ci: Iterate through GitHub pages for pull requests
This commit is contained in:
		| @@ -1,41 +1,45 @@ | |||||||
| # Download all pull requests as patches that match a specific label | # Download all pull requests as patches that match a specific label | ||||||
| # Usage: python download-patches-by-label.py <Label to Match> <Root Path Folder to DL to> | # Usage: python download-patches-by-label.py <Label to Match> <Root Path Folder to DL to> | ||||||
|  |  | ||||||
| import requests, sys, json, urllib3.request, shutil, subprocess, os, traceback | import requests, sys, json, shutil, subprocess, os, traceback | ||||||
|  |  | ||||||
| org = os.getenv("PrivateMergeOrg".upper(), "yuzu-emu") | org = os.getenv("PRIVATEMERGEORG", "yuzu-emu") | ||||||
| repo = os.getenv("PrivateMergeRepo".upper(), "yuzu-private") | repo = os.getenv("PRIVATEMERGEREPO", "yuzu-private") | ||||||
| tagline = sys.argv[3] | tagline = sys.argv[3] | ||||||
| user = sys.argv[1] | user = sys.argv[1] | ||||||
|  |  | ||||||
| http = urllib3.PoolManager() |  | ||||||
| dl_list = {} | dl_list = {} | ||||||
|  |  | ||||||
|  | TAG_NAME = sys.argv[2] | ||||||
|  |  | ||||||
| def check_individual(repo_id, pr_id): | def check_individual(repo_id, pr_id): | ||||||
|     url = 'https://%sdev.azure.com/%s/%s/_apis/git/repositories/%s/pullRequests/%s/labels?api-version=5.1-preview.1' % (user, org, repo, repo_id, pr_id) |     url = 'https://%sdev.azure.com/%s/%s/_apis/git/repositories/%s/pullRequests/%s/labels?api-version=5.1-preview.1' % (user, org, repo, repo_id, pr_id) | ||||||
|     response = requests.get(url) |     response = requests.get(url) | ||||||
|     if (response.ok): |     if (response.ok): | ||||||
|         j = json.loads(response.content) |         try: | ||||||
|         for tg in j['value']: |             js = response.json() | ||||||
|             if (tg['name'] == sys.argv[2]): |             return any(tag.get('name') == TAG_NAME for tag in js['value']) | ||||||
|                 return True |         except: | ||||||
|  |             return False | ||||||
|     return False |     return False | ||||||
|  |  | ||||||
| try: | def merge_pr(pn, ref): | ||||||
|     url = 'https://%sdev.azure.com/%s/%s/_apis/git/pullrequests?api-version=5.1' % (user, org, repo) |  | ||||||
|     response = requests.get(url) |  | ||||||
|     if (response.ok): |  | ||||||
|         j = json.loads(response.content) |  | ||||||
|         for pr in j["value"]: |  | ||||||
|             repo_id = pr['repository']['id'] |  | ||||||
|             pr_id = pr['pullRequestId'] |  | ||||||
|             if (check_individual(repo_id, pr_id)): |  | ||||||
|                 pn = pr_id |  | ||||||
|                 ref  = pr['sourceRefName'] |  | ||||||
|     print("Matched PR# %s" % pn) |     print("Matched PR# %s" % pn) | ||||||
|     print(subprocess.check_output(["git", "fetch", "https://%sdev.azure.com/%s/_git/%s" % (user, org, repo), ref, "-f"])) |     print(subprocess.check_output(["git", "fetch", "https://%sdev.azure.com/%s/_git/%s" % (user, org, repo), ref, "-f"])) | ||||||
|     print(subprocess.check_output(["git", "merge", "--squash", 'origin/' + ref.replace('refs/heads/','')])) |     print(subprocess.check_output(["git", "merge", "--squash", 'origin/' + ref.replace('refs/heads/','')])) | ||||||
|     print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)])) |     print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)])) | ||||||
| except: |  | ||||||
|  | def main(): | ||||||
|  |     url = 'https://%sdev.azure.com/%s/%s/_apis/git/pullrequests?api-version=5.1' % (user, org, repo) | ||||||
|  |     response = requests.get(url) | ||||||
|  |     if (response.ok): | ||||||
|  |         js = response.json() | ||||||
|  |         tagged_prs = filter(lambda pr: check_individual(pr['repository']['id'], pr['pullRequestId']), js['value']) | ||||||
|  |         map(lambda pr: merge_pr(pr['pullRequestId'], pr['sourceRefName']), tagged_prs) | ||||||
|  |  | ||||||
|  | if __name__ == '__main__': | ||||||
|  |     try: | ||||||
|  |         main() | ||||||
|  |     except: | ||||||
|         traceback.print_exc(file=sys.stdout) |         traceback.print_exc(file=sys.stdout) | ||||||
|         sys.exit(-1) |         sys.exit(-1) | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ def check_individual(labels): | |||||||
|             return True |             return True | ||||||
|     return False |     return False | ||||||
|  |  | ||||||
| try: | def do_page(page): | ||||||
|     url = 'https://api.github.com/repos/yuzu-emu/yuzu/pulls' |     url = 'https://api.github.com/repos/yuzu-emu/yuzu/pulls?page=%s' % page | ||||||
|     response = requests.get(url) |     response = requests.get(url) | ||||||
|     if (response.ok): |     if (response.ok): | ||||||
|         j = json.loads(response.content) |         j = json.loads(response.content) | ||||||
| @@ -26,5 +26,9 @@ try: | |||||||
|                 print(subprocess.check_output(["git", "fetch", "https://github.com/yuzu-emu/yuzu.git", "pull/%s/head:pr-%s" % (pn, pn), "-f"])) |                 print(subprocess.check_output(["git", "fetch", "https://github.com/yuzu-emu/yuzu.git", "pull/%s/head:pr-%s" % (pn, pn), "-f"])) | ||||||
|                 print(subprocess.check_output(["git", "merge", "--squash", "pr-%s" % pn])) |                 print(subprocess.check_output(["git", "merge", "--squash", "pr-%s" % pn])) | ||||||
|                 print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)])) |                 print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)])) | ||||||
|  |  | ||||||
|  | try: | ||||||
|  |     for i in range(1,4): | ||||||
|  |         do_page(i) | ||||||
| except: | except: | ||||||
|     sys.exit(-1) |     sys.exit(-1) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user