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):
 | 
				
			||||||
 | 
					    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", "merge", "--squash", 'origin/' + ref.replace('refs/heads/','')]))
 | 
				
			||||||
 | 
					    print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)]))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def main():
 | 
				
			||||||
    url = 'https://%sdev.azure.com/%s/%s/_apis/git/pullrequests?api-version=5.1' % (user, org, repo)
 | 
					    url = 'https://%sdev.azure.com/%s/%s/_apis/git/pullrequests?api-version=5.1' % (user, org, repo)
 | 
				
			||||||
    response = requests.get(url)
 | 
					    response = requests.get(url)
 | 
				
			||||||
    if (response.ok):
 | 
					    if (response.ok):
 | 
				
			||||||
        j = json.loads(response.content)
 | 
					        js = response.json()
 | 
				
			||||||
        for pr in j["value"]:
 | 
					        tagged_prs = filter(lambda pr: check_individual(pr['repository']['id'], pr['pullRequestId']), js['value'])
 | 
				
			||||||
            repo_id = pr['repository']['id']
 | 
					        map(lambda pr: merge_pr(pr['pullRequestId'], pr['sourceRefName']), tagged_prs)
 | 
				
			||||||
            pr_id = pr['pullRequestId']
 | 
					
 | 
				
			||||||
            if (check_individual(repo_id, pr_id)):
 | 
					if __name__ == '__main__':
 | 
				
			||||||
                pn = pr_id
 | 
					    try:
 | 
				
			||||||
                ref  = pr['sourceRefName']
 | 
					        main()
 | 
				
			||||||
                print("Matched PR# %s" % pn)
 | 
					    except:
 | 
				
			||||||
                print(subprocess.check_output(["git", "fetch", "https://%sdev.azure.com/%s/_git/%s" % (user, org, repo), ref, "-f"]))
 | 
					        traceback.print_exc(file=sys.stdout)
 | 
				
			||||||
                print(subprocess.check_output(["git", "merge", "--squash", 'origin/' + ref.replace('refs/heads/','')]))
 | 
					        sys.exit(-1)
 | 
				
			||||||
                print(subprocess.check_output(["git", "commit", "-m\"Merge %s PR %s\"" % (tagline, pn)]))
 | 
					 | 
				
			||||||
except:
 | 
					 | 
				
			||||||
    traceback.print_exc(file=sys.stdout)
 | 
					 | 
				
			||||||
    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)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user