8e9750d3c5
Building CanvasKit uses very similar logic to PathKit, so there was a fair amount of copy/paste/customize. Fixes the name of skia.js/wasm -> canvaskit.js/wasm and adds a package.json to formally track versions. Also move PathKit helper scripts to align better. Docs-Preview: https://skia.org/?cl=160463 Bug: skia: Change-Id: Ie75b30592dcc4d520dca41f6f5579006aaa8849b Reviewed-on: https://skia-review.googlesource.com/c/160463 Reviewed-by: Eric Boren <borenet@google.com>
178 lines
6.0 KiB
Python
178 lines
6.0 KiB
Python
# 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 runs the PathKit tests using docker
|
|
|
|
DEPS = [
|
|
'checkout',
|
|
'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-karma-chrome-tests:68.0.3440.106_v4'
|
|
INNER_KARMA_SCRIPT = '/SRC/skia/infra/pathkit/test_pathkit.sh'
|
|
|
|
|
|
def RunSteps(api):
|
|
api.vars.setup()
|
|
checkout_root = api.checkout.default_checkout_root
|
|
out_dir = api.vars.swarming_out_dir
|
|
api.checkout.bot_update(checkout_root=checkout_root)
|
|
|
|
# Make sure this exists, otherwise Docker will make it with root permissions.
|
|
api.file.ensure_directory('mkdirs out_dir', out_dir, mode=0777)
|
|
|
|
# The karma script is configured to look in ./npm-(asmjs|wasm)/bin/test/ for
|
|
# the test files to load, so we must copy them there (see Set up for docker).
|
|
copy_dest = checkout_root.join('skia', 'modules', 'pathkit',
|
|
'npm-wasm', 'bin', 'test')
|
|
if 'asmjs' in api.vars.builder_name:
|
|
copy_dest = checkout_root.join('skia', 'modules', 'pathkit',
|
|
'npm-asmjs', 'bin', 'test')
|
|
|
|
base_dir = api.vars.build_dir
|
|
bundle_name = 'pathkit.wasm'
|
|
if 'asmjs' in api.vars.builder_name:
|
|
# release mode has a .js.mem file that needs to come with.
|
|
# debug mode has an optional .map file, but we can omit that for tests
|
|
if 'Debug' in api.vars.builder_name:
|
|
bundle_name = ''
|
|
else:
|
|
bundle_name = 'pathkit.js.mem'
|
|
|
|
api.python.inline(
|
|
name='Set up for docker',
|
|
program='''import errno
|
|
import os
|
|
import shutil
|
|
import sys
|
|
|
|
copy_dest = sys.argv[1]
|
|
base_dir = sys.argv[2]
|
|
bundle_name = sys.argv[3]
|
|
out_dir = sys.argv[4]
|
|
|
|
# Clean out old binaries (if any)
|
|
try:
|
|
shutil.rmtree(copy_dest)
|
|
except OSError as e:
|
|
if e.errno != errno.ENOENT:
|
|
raise
|
|
|
|
# Make folder
|
|
try:
|
|
os.makedirs(copy_dest)
|
|
except OSError as e:
|
|
if e.errno != errno.EEXIST:
|
|
raise
|
|
|
|
# Copy binaries (pathkit.js and pathkit.wasm) to where the karma tests
|
|
# expect them ($SKIA_ROOT/modules/pathkit/npm-wasm/test/)
|
|
dest = os.path.join(copy_dest, 'pathkit.js')
|
|
shutil.copyfile(os.path.join(base_dir, 'pathkit.js'), dest)
|
|
os.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.
|
|
|
|
if bundle_name:
|
|
dest = os.path.join(copy_dest, bundle_name)
|
|
shutil.copyfile(os.path.join(base_dir, bundle_name), dest)
|
|
os.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.
|
|
|
|
# Prepare output folder, api.file.ensure_directory doesn't touch
|
|
# the permissions of the out directory if it already exists.
|
|
os.chmod(out_dir, 0o777) # important, otherwise non-privileged docker can't write.
|
|
''',
|
|
args=[copy_dest, base_dir, bundle_name, out_dir],
|
|
infra_step=True)
|
|
|
|
|
|
|
|
cmd = ['docker', 'run', '--shm-size=2gb', '--rm',
|
|
'-v', '%s:/SRC' % checkout_root, '-v', '%s:/OUT' % out_dir]
|
|
|
|
if 'asmjs' in api.vars.builder_name:
|
|
cmd.extend(['-e', 'ASM_JS=1']) # -e sets environment variables
|
|
|
|
cmd.extend([
|
|
DOCKER_IMAGE, INNER_KARMA_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 'asmjs' in api.vars.builder_name:
|
|
cmd.extend(['--compiled_language', 'asmjs']) # the default is wasm
|
|
|
|
if api.vars.is_trybot:
|
|
cmd.extend([
|
|
'--issue', api.vars.issue,
|
|
'--patchset', api.vars.patchset,
|
|
'--patch_storage', api.vars.patch_storage,
|
|
])
|
|
|
|
api.run(
|
|
api.step,
|
|
'Test PathKit with Docker',
|
|
cmd=cmd)
|
|
|
|
|
|
def GenTests(api):
|
|
yield (
|
|
api.test('Test-Debian9-EMCC-GCE-CPU-AVX2-wasm-Debug-All-PathKit') +
|
|
api.properties(buildername=('Test-Debian9-EMCC-GCE-CPU-AVX2'
|
|
'-wasm-Debug-All-PathKit'),
|
|
repository='https://skia.googlesource.com/skia.git',
|
|
revision='abc123',
|
|
path_config='kitchen',
|
|
swarm_out_dir='[SWARM_OUT_DIR]')
|
|
)
|
|
|
|
yield (
|
|
api.test('Test-Debian9-EMCC-GCE-CPU-AVX2-asmjs-Debug-All-PathKit') +
|
|
api.properties(buildername=('Test-Debian9-EMCC-GCE-CPU-AVX2'
|
|
'-asmjs-Debug-All-PathKit'),
|
|
repository='https://skia.googlesource.com/skia.git',
|
|
revision='abc123',
|
|
path_config='kitchen',
|
|
swarm_out_dir='[SWARM_OUT_DIR]')
|
|
)
|
|
|
|
yield (
|
|
api.test('Test-Debian9-EMCC-GCE-CPU-AVX2-asmjs-Release-All-PathKit') +
|
|
api.properties(buildername=('Test-Debian9-EMCC-GCE-CPU-AVX2'
|
|
'-asmjs-Release-All-PathKit'),
|
|
repository='https://skia.googlesource.com/skia.git',
|
|
revision='abc123',
|
|
path_config='kitchen',
|
|
swarm_out_dir='[SWARM_OUT_DIR]')
|
|
)
|
|
|
|
yield (
|
|
api.test('pathkit_trybot') +
|
|
api.properties(buildername=('Test-Debian9-EMCC-GCE-CPU-AVX2'
|
|
'-wasm-Debug-All-PathKit'),
|
|
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/')
|
|
)
|