summaryrefslogtreecommitdiffstats
path: root/.ci/scripts/merge/apply-patches-by-label-private.py
diff options
context:
space:
mode:
authorRodrigo Locatti <reinuseslisp@airmail.cc>2019-09-27 00:30:33 +0200
committerGitHub <noreply@github.com>2019-09-27 00:30:33 +0200
commitc4a99944f2faf4092842cf9a5b84f44c128f5809 (patch)
tree7b2b2b2b1dcb3c22833bf527a0505c0e9b093526 /.ci/scripts/merge/apply-patches-by-label-private.py
parentMerge pull request #2864 from ReinUsesLisp/fix-clang-decompiler (diff)
parentci: Add two step patreon build pipeline (diff)
downloadyuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar.gz
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar.bz2
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar.lz
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar.xz
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.tar.zst
yuzu-c4a99944f2faf4092842cf9a5b84f44c128f5809.zip
Diffstat (limited to '')
-rw-r--r--.ci/scripts/merge/apply-patches-by-label-private.py41
1 files changed, 41 insertions, 0 deletions
diff --git a/.ci/scripts/merge/apply-patches-by-label-private.py b/.ci/scripts/merge/apply-patches-by-label-private.py
new file mode 100644
index 000000000..11ec60010
--- /dev/null
+++ b/.ci/scripts/merge/apply-patches-by-label-private.py
@@ -0,0 +1,41 @@
+# 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>
+
+import requests, sys, json, urllib3.request, shutil, subprocess, os, traceback
+
+org = os.getenv("PrivateMergeOrg".upper(), "yuzu-emu")
+repo = os.getenv("PrivateMergeRepo".upper(), "yuzu-private")
+tagline = os.getenv("MergeTaglinePrivate".upper(), "")
+user = sys.argv[1]
+
+http = urllib3.PoolManager()
+dl_list = {}
+
+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)
+ response = requests.get(url)
+ if (response.ok):
+ j = json.loads(response.content)
+ for tg in j['value']:
+ if (tg['name'] == sys.argv[2]):
+ return True
+ return False
+
+try:
+ 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(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)]))
+except:
+ traceback.print_exc(file=sys.stdout)
+ sys.exit(-1)