Index: infra/bots/recipes/swarm_RecreateSKPs.py |
diff --git a/infra/bots/recipes/swarm_RecreateSKPs.py b/infra/bots/recipes/swarm_RecreateSKPs.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..6863b020b753ee453b08ee1dd59a4caf93e488f8 |
--- /dev/null |
+++ b/infra/bots/recipes/swarm_RecreateSKPs.py |
@@ -0,0 +1,191 @@ |
+# Copyright 2014 The Chromium Authors. All rights reserved. |
+# Use of this source code is governed by a BSD-style license that can be |
+# found in the LICENSE file. |
+ |
+ |
+"""Recipe for the Skia RecreateSKPs Bot.""" |
+ |
+ |
+DEPS = [ |
+ 'build/file', |
+ 'depot_tools/gclient', |
+ 'recipe_engine/path', |
+ 'recipe_engine/properties', |
+ 'recipe_engine/python', |
+ 'recipe_engine/raw_io', |
+ 'recipe_engine/step', |
+ 'skia', |
+] |
+ |
+ |
+TEST_BUILDERS = { |
+ 'client.skia.compile': { |
+ 'skiabot-linux-swarm-000': [ |
+ 'Housekeeper-Nightly-RecreateSKPs_Canary', |
+ 'Housekeeper-Weekly-RecreateSKPs', |
+ ], |
+ }, |
+} |
+ |
+ |
+DEPOT_TOOLS_AUTH_TOKEN_FILE = '.depot_tools_oauth2_tokens' |
+DEPOT_TOOLS_AUTH_TOKEN_FILE_BACKUP = '.depot_tools_oauth2_tokens.old' |
+UPDATE_SKPS_KEY = 'depot_tools_auth_update_skps' |
+ |
+ |
+class depot_tools_auth(object): |
+ """Temporarily authenticate to depot_tools via GCE metadata.""" |
+ def __init__(self, api, metadata_key): |
+ self.m = api |
+ self._key = metadata_key |
+ |
+ def __enter__(self): |
+ return self.m.python.inline( |
+ 'depot-tools-auth login', |
+ """ |
+import os |
+import urllib2 |
+ |
+TOKEN_FILE = '%s' |
+TOKEN_FILE_BACKUP = '%s' |
+TOKEN_URL = 'http://metadata/computeMetadata/v1/project/attributes/%s' |
+ |
+req = urllib2.Request(TOKEN_URL, headers={'Metadata-Flavor': 'Google'}) |
+contents = urllib2.urlopen(req).read() |
+ |
+home = os.path.expanduser('~') |
+token_file = os.path.join(home, TOKEN_FILE) |
+if os.path.isfile(token_file): |
+ os.rename(token_file, os.path.join(home, TOKEN_FILE_BACKUP)) |
+ |
+with open(token_file, 'w') as f: |
+ f.write(contents) |
+ """ % (DEPOT_TOOLS_AUTH_TOKEN_FILE, |
+ DEPOT_TOOLS_AUTH_TOKEN_FILE_BACKUP, |
+ self._key), |
+ ) |
+ |
+ def __exit__(self, t, v, tb): |
+ return self.m.python.inline( |
+ 'depot-tools-auth logout', |
+ """ |
+import os |
+ |
+ |
+TOKEN_FILE = '%s' |
+TOKEN_FILE_BACKUP = '%s' |
+ |
+ |
+home = os.path.expanduser('~') |
+token_file = os.path.join(home, TOKEN_FILE) |
+if os.path.isfile(token_file): |
+ os.remove(token_file) |
+ |
+backup_file = os.path.join(home, TOKEN_FILE_BACKUP) |
+if os.path.isfile(backup_file): |
+ os.rename(backup_file, token_file) |
+ """ % (DEPOT_TOOLS_AUTH_TOKEN_FILE, |
+ DEPOT_TOOLS_AUTH_TOKEN_FILE_BACKUP), |
+ ) |
+ |
+ |
+def RunSteps(api): |
+ # Check out Chrome. |
+ api.skia.setup() |
+ api.gclient.runhooks( |
+ env={'CPPFLAGS': '-DSK_ALLOW_CROSSPROCESS_PICTUREIMAGEFILTERS=1'}) |
+ |
+ src_dir = api.skia.checkout_root.join('src') |
+ |
+ # Call build/gyp_chromium |
+ api.step('gyp_chromium', |
+ ['build/gyp_chromium'], |
+ env={'CPPFLAGS': '-DSK_ALLOW_CROSSPROCESS_PICTUREIMAGEFILTERS=1', |
+ 'GYP_GENERATORS': 'ninja'}, |
+ cwd=src_dir) |
+ # Build Chrome. |
+ api.step('Build Chrome', |
+ ['ninja', '-C', 'out/Release', 'chrome'], |
+ cwd=src_dir) |
+ |
+ # Download boto file (needed by recreate_skps.py) to tmp dir. |
+ boto_file = api.path['slave_build'].join('tmp', '.boto') |
+ api.python.inline( |
+ 'download boto file', |
+ """ |
+import os |
+import urllib2 |
+ |
+BOTO_URL = 'http://metadata/computeMetadata/v1/project/attributes/boto-file' |
+ |
+dest_path = '%s' |
+dest_dir = os.path.dirname(dest_path) |
+if not os.path.exists(dest_dir): |
+ os.makedirs(dest_dir) |
+ |
+req = urllib2.Request(BOTO_URL, headers={'Metadata-Flavor': 'Google'}) |
+contents = urllib2.urlopen(req).read() |
+ |
+with open(dest_path, 'w') as f: |
+ f.write(contents) |
+ """ % boto_file) |
+ |
+ # Clean up the output dir. |
+ output_dir = api.path['slave_build'].join('skp_output') |
+ if api.path.exists(output_dir): |
+ api.file.rmtree('skp_output', output_dir) |
+ api.file.makedirs('skp_output', output_dir) |
+ |
+ # Capture the SKPs. |
+ path_var= api.path.pathsep.join([str(api.path['depot_tools']), '%(PATH)s']) |
+ env = { |
+ 'CHROME_HEADLESS': '1', |
+ 'PATH': path_var, |
+ } |
+ boto_env = { |
+ 'AWS_CREDENTIAL_FILE': boto_file, |
+ 'BOTO_CONFIG': boto_file, |
+ } |
+ recreate_skps_env = {} |
+ recreate_skps_env.update(env) |
+ recreate_skps_env.update(boto_env) |
+ asset_dir = api.skia.infrabots_dir.join('assets', 'skp') |
+ cmd = ['python', asset_dir.join('create.py'), |
+ '--chrome_src_path', src_dir, |
+ '--browser_executable', src_dir.join('out', 'Release', 'chrome'), |
+ '--target_dir', output_dir] |
+ if 'Canary' not in api.properties['buildername']: |
+ cmd.append('--upload_to_partner_bucket') |
+ api.step('Recreate SKPs', |
+ cmd=cmd, |
+ cwd=api.skia.skia_dir, |
+ env=recreate_skps_env) |
+ |
+ # Upload the SKPs. |
+ if 'Canary' not in api.properties['buildername']: |
+ cmd = ['python', |
+ api.skia.skia_dir.join('infra', 'bots', 'upload_skps.py'), |
+ '--target_dir', output_dir] |
+ with depot_tools_auth(api, UPDATE_SKPS_KEY): |
+ api.step('Upload SKPs', |
+ cmd=cmd, |
+ cwd=api.skia.skia_dir, |
+ env=env) |
+ |
+ |
+def GenTests(api): |
+ for mastername, slaves in TEST_BUILDERS.iteritems(): |
+ for slavename, builders_by_slave in slaves.iteritems(): |
+ for builder in builders_by_slave: |
+ test = ( |
+ api.test(builder) + |
+ api.properties(buildername=builder, |
+ mastername=mastername, |
+ slavename=slavename, |
+ revision='abc123', |
+ buildnumber=2, |
+ path_config='kitchen', |
+ swarm_out_dir='[SWARM_OUT_DIR]') + |
+ api.path.exists(api.path['slave_build'].join('skp_output')) |
+ ) |
+ yield test |