skia2/tools/skqp/make_apk_list.py
Hal Canary cd30375f36 SkQP: make_apk_list.py include pie-cts-dev branch
No-Try: true
Change-Id: I3482f0e55eebe325eef1c140a16b867d89aa6580
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/233081
Commit-Queue: Ben Wagner <bungeman@google.com>
Auto-Submit: Hal Canary <halcanary@google.com>
Reviewed-by: Ben Wagner <bungeman@google.com>
2019-08-07 19:42:38 +00:00

133 lines
4.1 KiB
Python
Executable File

#! /usr/bin/env python
# Copyright 2018 Google LLC.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
from subprocess import call, check_output, CalledProcessError
import os
import re
import sys
import tempfile
HEADER = '''<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>SkQP Pre-built APKs</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
font-family:sans-serif;
max-width:50em;
margin:8px auto;
padding:0 8px;
}
table { max-width:100%; border-collapse: collapse; }
td { padding:12px 8px; vertical-align:top; }
tr:nth-child(even) {background: #F2F2F2; color:#000;}
tr:nth-child(odd) {background: #FFFFFF; color:#000;}
</style>
</head>
<body>
<h1>SkQP Pre-built APKs</h1>
'''
FOOTER = '</body>\n</html>\n'
BUCKET = 'skia-skqp'
NAME_FMT = 'skqp-universal-%s.apk'
def get_existing_files():
cmd = ['gsutil', 'ls', 'gs://' + BUCKET]
try:
output = check_output(cmd)
except (OSError, CalledProcessError):
sys.stderr.write('command: "%s" failed.\n' % ' '.join(cmd))
sys.exit(1)
result = set()
regex = re.compile('gs://%s/%s' % (BUCKET, NAME_FMT % '([0-9a-f]+)'))
for line in output.split('\n'):
m = regex.match(line.strip())
if m is not None:
result.add(m.group(1))
return result
def find(v, extant):
l = min(16, len(v))
while l > 8:
if v[:l] in extant:
return v[:l]
l -= 1
return None
def nowrap(s):
return (s.replace(' ', u'\u00A0'.encode('utf-8'))
.replace('-', u'\u2011'.encode('utf-8')))
def rev_parse(arg):
if isinstance(arg, tuple):
remote_url, branch = arg
for remote in check_output(['git', 'remote']).strip().split('\n'):
remote = remote.strip()
url = check_output(['git', 'remote', 'get-url', remote]).strip()
if url == remote_url:
arg = remote + '/' + branch
break
return check_output(['git', 'rev-parse', arg]).strip()
def table(o, remote, branch, excludes):
env_copy = os.environ.copy()
env_copy['TZ'] = ''
extant = get_existing_files()
commits = [rev_parse((remote, branch))]
for exclude in excludes:
commits.append('^' + rev_parse(exclude))
o.write('<h2>Remote: %s<br>Branch: %s</h2>\n' % (remote, branch))
o.write('<table>\n<tr><th>APK</th><th>Date</th><th>Commit</th></tr>\n')
git_cmd = ['git', 'log', '--format=%H;%cd;%<(100,trunc)%s',
'--date=format-local:%Y-%m-%d %H:%M:%S %Z'] + commits
commits = check_output(git_cmd, env=env_copy)
for line in commits.split('\n'):
line = line.strip()
if not line:
continue
commit, date, subj = line.split(';', 2)
short = find(commit, extant)
if short is not None:
apk_name = NAME_FMT % short
url = 'https://storage.googleapis.com/%s/%s' % (BUCKET, apk_name)
else:
apk_name, url = '', ''
commit_url = '%s/+/%s' % (remote, commit)
o.write('<tr>\n<td><a href="%s">%s</a></td>\n'
'<td>%s</td>\n<td><a href="%s">%s</a></td>\n</tr>\n' %
(url, nowrap(apk_name), nowrap(date), commit_url, subj))
o.write('</table>\n')
def main():
origin = 'https://skia.googlesource.com/skia'
aosp_skqp = 'https://android.googlesource.com/platform/external/skqp'
assert '/' in [os.sep, os.altsep] and '..' == os.pardir
os.chdir(os.path.join(os.path.dirname(__file__), '../..'))
d = tempfile.mkdtemp()
path = os.path.join(d, 'apklist.html')
with open(path, 'w') as o:
o.write(HEADER)
table(o, origin, 'skqp/dev', [(origin, 'master'), '3e34285f2a0'])
table(o, origin, 'skqp/release', [(origin, 'master'), '09ab171c5c0'])
table(o, aosp_skqp, 'pie-cts-dev', ['f084c17322'])
o.write(FOOTER)
print path
call([sys.executable, 'bin/sysopen', path])
gscmd = 'gsutil -h "Content-Type:text/html" cp "%s" gs://skia-skqp/apklist'
print gscmd % path
if __name__ == '__main__':
main()