# Copyright 2018 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 which generates the Gold images for lottie-web using docker DEPS = [ 'checkout', 'env', 'infra', 'recipe_engine/file', 'recipe_engine/path', 'recipe_engine/properties', 'recipe_engine/python', 'recipe_engine/step', 'run', 'vars', ] DOCKER_IMAGE = 'gcr.io/skia-public/gold-lottie-web-puppeteer:v2' LOTTIECAP_SCRIPT = '/SRC/skia/infra/lottiecap/docker/lottiecap_gold.sh' def RunSteps(api): api.vars.setup() checkout_root = api.path['start_dir'] out_dir = api.vars.swarming_out_dir lottie_files_src = api.vars.slave_dir.join('lottie-samples') lottie_files_dir = '/tmp/lottie_files' # The lottie-web repo is DEP'd in. This links to its build directory # to make finding the lottie.min.js easier to reference from inside # the docker image. lottie_build = checkout_root.join('lottie', 'build', 'player') # Make sure this exists, otherwise Docker will make it with root permissions. api.file.ensure_directory('mkdirs out_dir', out_dir, mode=0777) # When lottie files are brought in via isolate or CIPD, they are just # symlinks, which does not work well with Docker because we can't mount # the folder as a volume. # e.g. /LOTTIE_FILES/foo.json -> ../.cipd/alpha/beta/foo.json # To get around this, we just copy the lottie files into a temporary # directory. api.file.rmtree('remove previous lottie files', lottie_files_dir) api.file.copytree('copy lottie files', lottie_files_src, lottie_files_dir) api.python.inline( name='Set up for docker', program=''' import os import sys lottie_files_dir = sys.argv[1] out_dir = sys.argv[2] lottie_build = sys.argv[3] # Make sure all the lottie files are readable by everyone so we can see # them in the docker container. os.system('chmod 0644 %s/*' % lottie_files_dir) os.system('chmod 0644 %s/*' % lottie_build) # Prepare output folder, api.file.ensure_directory doesn't touch # the permissions of the out directory if it already exists. # This typically means that the non-privileged docker won't be able to write. os.chmod(out_dir, 0o777) ''', args=[lottie_files_dir, out_dir, lottie_build], infra_step=True) cmd = ['docker', 'run', '--shm-size=2gb', '--rm', '-v', '%s:/SRC' % checkout_root, '-v', '%s:/OUT' % out_dir, '-v', '%s:/LOTTIE_BUILD' % lottie_build, '-v', '%s:/LOTTIE_FILES' % lottie_files_dir] cmd.extend([ DOCKER_IMAGE, LOTTIECAP_SCRIPT, '--builder', api.vars.builder_name, '--git_hash', api.properties['revision'], '--buildbucket_build_id', api.properties.get('buildbucket_build_id', ''), '--bot_id', api.vars.swarming_bot_id, '--task_id', api.vars.swarming_task_id, '--browser', 'Chrome', '--config', api.vars.configuration, ]) if api.vars.is_trybot: cmd.extend([ '--issue', api.vars.issue, '--patchset', api.vars.patchset, '--patch_storage', api.vars.patch_storage, ]) # Override DOCKER_CONFIG set by Kitchen. env = {'DOCKER_CONFIG': '/home/chrome-bot/.docker'} with api.env(env): api.run( api.step, 'Create lottie-web Gold output with Docker', cmd=cmd) def GenTests(api): yield ( api.test('Test-Debian9-none-GCE-CPU-AVX2-x86_64-Debug-All-LottieWeb') + api.properties(buildername=('Test-Debian9-none-GCE-CPU-AVX2' '-x86_64-Debug-All-LottieWeb'), repository='https://skia.googlesource.com/skia.git', revision='abc123', path_config='kitchen', swarm_out_dir='[SWARM_OUT_DIR]') ) yield ( api.test('lottie_web_trybot') + api.properties(buildername=('Test-Debian9-none-GCE-CPU-AVX2' '-x86_64-Debug-All-LottieWeb'), repository='https://skia.googlesource.com/skia.git', revision='abc123', path_config='kitchen', swarm_out_dir='[SWARM_OUT_DIR]', patch_ref='89/456789/12', patch_repo='https://skia.googlesource.com/skia.git', patch_storage='gerrit', patch_set=7, patch_issue=1234, gerrit_project='skia', gerrit_url='https://skia-review.googlesource.com/') )