Merge pull request #2932 from DarkLordZach/azure-gitpages
ci: Iterate through GitHub pages for pull requests
This commit is contained in:
commit
f8ce672b67
|
@ -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,11 +14,13 @@ 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)
|
||||||
|
if j == []:
|
||||||
|
return
|
||||||
for pr in j:
|
for pr in j:
|
||||||
if (check_individual(pr["labels"])):
|
if (check_individual(pr["labels"])):
|
||||||
pn = pr["number"]
|
pn = pr["number"]
|
||||||
|
@ -26,5 +28,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,30):
|
||||||
|
do_page(i)
|
||||||
except:
|
except:
|
||||||
sys.exit(-1)
|
sys.exit(-1)
|
||||||
|
|
Reference in New Issue