2016-07-26 18:52:17 +00:00
|
|
|
# Copyright 2016 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 module for Skia Swarming test.
|
|
|
|
|
|
|
|
|
2020-03-02 15:05:23 +00:00
|
|
|
import json
|
|
|
|
|
|
|
|
|
2016-07-26 18:52:17 +00:00
|
|
|
DEPS = [
|
2017-04-24 17:22:56 +00:00
|
|
|
'env',
|
|
|
|
'flavor',
|
2017-05-13 02:09:38 +00:00
|
|
|
'recipe_engine/context',
|
2017-07-07 21:36:58 +00:00
|
|
|
'recipe_engine/file',
|
2016-07-26 18:52:17 +00:00
|
|
|
'recipe_engine/path',
|
|
|
|
'recipe_engine/platform',
|
|
|
|
'recipe_engine/properties',
|
2017-04-10 12:19:10 +00:00
|
|
|
'recipe_engine/python',
|
2016-07-26 18:52:17 +00:00
|
|
|
'recipe_engine/raw_io',
|
2017-04-10 12:19:10 +00:00
|
|
|
'recipe_engine/step',
|
|
|
|
'run',
|
|
|
|
'vars',
|
2016-07-26 18:52:17 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2017-04-10 12:19:10 +00:00
|
|
|
def test_steps(api):
|
|
|
|
"""Run the DM test."""
|
2020-03-23 13:17:24 +00:00
|
|
|
do_upload = api.properties.get('do_upload') == 'true'
|
|
|
|
images = api.properties.get('images') == 'true'
|
|
|
|
lotties = api.properties.get('lotties') == 'true'
|
|
|
|
resources = api.properties.get('resources') == 'true'
|
|
|
|
skps = api.properties.get('skps') == 'true'
|
|
|
|
svgs = api.properties.get('svgs') == 'true'
|
|
|
|
|
|
|
|
api.flavor.install(
|
|
|
|
images=images,
|
|
|
|
lotties=lotties,
|
|
|
|
resources=resources,
|
|
|
|
skps=skps,
|
|
|
|
svgs=svgs,
|
|
|
|
)
|
|
|
|
|
2017-04-10 12:19:10 +00:00
|
|
|
use_hash_file = False
|
2020-03-23 13:17:24 +00:00
|
|
|
if do_upload:
|
2018-05-18 11:36:55 +00:00
|
|
|
host_dm_dir = str(api.flavor.host_dirs.dm_dir)
|
|
|
|
api.flavor.create_clean_host_dir(api.path['start_dir'].join('test'))
|
2017-04-10 12:19:10 +00:00
|
|
|
device_dm_dir = str(api.flavor.device_dirs.dm_dir)
|
|
|
|
if host_dm_dir != device_dm_dir:
|
|
|
|
api.flavor.create_clean_device_dir(device_dm_dir)
|
|
|
|
|
|
|
|
# Obtain the list of already-generated hashes.
|
|
|
|
hash_filename = 'uninteresting_hashes.txt'
|
|
|
|
|
|
|
|
host_hashes_file = api.vars.tmp_dir.join(hash_filename)
|
|
|
|
hashes_file = api.flavor.device_path_join(
|
|
|
|
api.flavor.device_dirs.tmp_dir, hash_filename)
|
|
|
|
api.run(
|
|
|
|
api.python.inline,
|
|
|
|
'get uninteresting hashes',
|
|
|
|
program="""
|
|
|
|
import contextlib
|
|
|
|
import math
|
|
|
|
import socket
|
|
|
|
import sys
|
|
|
|
import time
|
|
|
|
import urllib2
|
|
|
|
|
2018-08-02 06:51:38 +00:00
|
|
|
HASHES_URL = sys.argv[1]
|
2017-04-10 12:19:10 +00:00
|
|
|
RETRIES = 5
|
|
|
|
TIMEOUT = 60
|
|
|
|
WAIT_BASE = 15
|
|
|
|
|
|
|
|
socket.setdefaulttimeout(TIMEOUT)
|
|
|
|
for retry in range(RETRIES):
|
|
|
|
try:
|
|
|
|
with contextlib.closing(
|
|
|
|
urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:
|
|
|
|
hashes = w.read()
|
2018-08-02 06:51:38 +00:00
|
|
|
with open(sys.argv[2], 'w') as f:
|
2017-04-10 12:19:10 +00:00
|
|
|
f.write(hashes)
|
|
|
|
break
|
|
|
|
except Exception as e:
|
|
|
|
print 'Failed to get uninteresting hashes from %s:' % HASHES_URL
|
|
|
|
print e
|
|
|
|
if retry == RETRIES:
|
|
|
|
raise
|
|
|
|
waittime = WAIT_BASE * math.pow(2, retry)
|
|
|
|
print 'Retry in %d seconds.' % waittime
|
|
|
|
time.sleep(waittime)
|
|
|
|
""",
|
2018-08-02 06:51:38 +00:00
|
|
|
args=[api.properties['gold_hashes_url'], host_hashes_file],
|
2017-04-10 12:19:10 +00:00
|
|
|
abort_on_failure=False,
|
|
|
|
fail_build_on_failure=False,
|
|
|
|
infra_step=True)
|
|
|
|
|
|
|
|
if api.path.exists(host_hashes_file):
|
|
|
|
api.flavor.copy_file_to_device(host_hashes_file, hashes_file)
|
|
|
|
use_hash_file = True
|
|
|
|
|
2020-03-02 15:05:23 +00:00
|
|
|
# Find DM flags.
|
|
|
|
args = json.loads(api.properties['dm_flags'])
|
|
|
|
props = json.loads(api.properties['dm_properties'])
|
|
|
|
args.append('--properties')
|
|
|
|
# Map iteration order is arbitrary; in order to maintain a consistent step
|
|
|
|
# ordering, sort by key.
|
|
|
|
for k in sorted(props.keys()):
|
|
|
|
v = props[k]
|
|
|
|
if v == '${SWARMING_BOT_ID}':
|
|
|
|
v = api.vars.swarming_bot_id
|
|
|
|
elif v == '${SWARMING_TASK_ID}':
|
|
|
|
v = api.vars.swarming_task_id
|
|
|
|
if v != '':
|
|
|
|
args.extend([k, v])
|
|
|
|
|
|
|
|
# Paths to required resources.
|
2020-03-23 13:17:24 +00:00
|
|
|
if resources:
|
|
|
|
args.extend(['--resourcePath', api.flavor.device_dirs.resource_dir])
|
|
|
|
if skps:
|
|
|
|
args.extend(['--skps', api.flavor.device_dirs.skp_dir])
|
|
|
|
if images:
|
|
|
|
args.extend([
|
|
|
|
'--images', api.flavor.device_path_join(
|
|
|
|
api.flavor.device_dirs.images_dir, 'dm'),
|
|
|
|
'--colorImages', api.flavor.device_path_join(
|
|
|
|
api.flavor.device_dirs.images_dir, 'colorspace'),
|
|
|
|
])
|
|
|
|
if svgs:
|
2021-02-01 14:30:03 +00:00
|
|
|
# svg_dir is the root of the SVG corpus. Within that directory,
|
|
|
|
# the *.svg inputs are in the 'svg' subdirectory. See skbug.com/11229
|
|
|
|
args.extend(['--svgs', api.flavor.device_path_join(
|
|
|
|
api.flavor.device_dirs.svg_dir, "svg")])
|
2020-03-23 13:17:24 +00:00
|
|
|
if lotties:
|
2020-02-12 20:41:10 +00:00
|
|
|
args.extend([
|
|
|
|
'--lotties',
|
|
|
|
api.flavor.device_path_join(
|
|
|
|
api.flavor.device_dirs.resource_dir, 'skottie'),
|
2020-02-28 19:07:15 +00:00
|
|
|
api.flavor.device_dirs.lotties_dir,
|
|
|
|
])
|
2018-01-16 21:15:57 +00:00
|
|
|
|
|
|
|
if use_hash_file:
|
|
|
|
args.extend(['--uninterestingHashesFile', hashes_file])
|
2020-03-23 13:17:24 +00:00
|
|
|
if do_upload:
|
2018-01-16 21:15:57 +00:00
|
|
|
args.extend(['--writePath', api.flavor.device_dirs.dm_dir])
|
2017-08-31 14:39:05 +00:00
|
|
|
|
2020-03-02 15:05:23 +00:00
|
|
|
# Run DM.
|
2017-10-02 14:48:32 +00:00
|
|
|
api.run(api.flavor.step, 'dm', cmd=args, abort_on_failure=False)
|
2017-04-10 12:19:10 +00:00
|
|
|
|
2020-03-23 13:17:24 +00:00
|
|
|
if do_upload:
|
2017-04-10 12:19:10 +00:00
|
|
|
# Copy images and JSON to host machine if needed.
|
|
|
|
api.flavor.copy_directory_contents_to_host(
|
2018-05-18 11:36:55 +00:00
|
|
|
api.flavor.device_dirs.dm_dir, api.flavor.host_dirs.dm_dir)
|
2017-04-10 12:19:10 +00:00
|
|
|
|
|
|
|
|
2016-07-26 18:52:17 +00:00
|
|
|
def RunSteps(api):
|
2018-05-04 17:46:15 +00:00
|
|
|
api.vars.setup()
|
|
|
|
api.file.ensure_directory('makedirs tmp_dir', api.vars.tmp_dir)
|
2020-02-27 17:19:46 +00:00
|
|
|
api.flavor.setup('dm')
|
|
|
|
|
|
|
|
try:
|
|
|
|
test_steps(api)
|
|
|
|
finally:
|
|
|
|
api.flavor.cleanup_steps()
|
|
|
|
api.run.check_failure()
|
2017-04-10 12:19:10 +00:00
|
|
|
|
|
|
|
|
2017-04-10 13:56:10 +00:00
|
|
|
TEST_BUILDERS = [
|
2018-07-15 19:12:01 +00:00
|
|
|
'Test-Android-Clang-Pixel-GPU-Adreno530-arm-Debug-All-Android_ASAN',
|
2019-09-16 16:38:04 +00:00
|
|
|
'Test-Android-Clang-Pixel2XL-GPU-Adreno540-arm64-Debug-All-Android',
|
2020-04-07 01:27:14 +00:00
|
|
|
'Test-Debian10-Clang-GCE-CPU-AVX2-x86_64-Release-All-Lottie',
|
2017-10-23 20:01:44 +00:00
|
|
|
'Test-Win10-Clang-ShuttleC-GPU-GTX960-x86_64-Debug-All-ANGLE',
|
2017-04-10 13:56:10 +00:00
|
|
|
]
|
2016-07-26 18:52:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
def GenTests(api):
|
2017-04-10 13:56:10 +00:00
|
|
|
for builder in TEST_BUILDERS:
|
2020-03-23 13:17:24 +00:00
|
|
|
props = dict(
|
|
|
|
buildername=builder,
|
|
|
|
buildbucket_build_id='123454321',
|
2021-01-29 16:05:41 +00:00
|
|
|
dm_flags='["dm","--example","--flags"]',
|
2020-03-23 13:17:24 +00:00
|
|
|
dm_properties=('{"key1":"value1","key2":"",'
|
|
|
|
'"bot":"${SWARMING_BOT_ID}",'
|
|
|
|
'"task":"${SWARMING_TASK_ID}"}'),
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen',
|
|
|
|
gold_hashes_url='https://example.com/hashes.txt',
|
|
|
|
swarm_out_dir='[SWARM_OUT_DIR]',
|
|
|
|
task_id='task_12345',
|
|
|
|
resources='true',
|
|
|
|
)
|
|
|
|
if 'ASAN' not in builder:
|
|
|
|
props['do_upload'] = 'true'
|
|
|
|
if 'Lottie' in builder:
|
|
|
|
props['lotties'] = 'true'
|
|
|
|
else:
|
|
|
|
props['images'] = 'true'
|
|
|
|
props['skps'] = 'true'
|
|
|
|
props['svgs'] = 'true'
|
2017-04-10 13:56:10 +00:00
|
|
|
test = (
|
|
|
|
api.test(builder) +
|
2020-03-23 13:17:24 +00:00
|
|
|
api.properties(**props) +
|
2017-04-10 13:56:10 +00:00
|
|
|
api.path.exists(
|
|
|
|
api.path['start_dir'].join('skia'),
|
|
|
|
api.path['start_dir'].join('skia', 'infra', 'bots', 'assets',
|
|
|
|
'skimage', 'VERSION'),
|
|
|
|
api.path['start_dir'].join('skia', 'infra', 'bots', 'assets',
|
|
|
|
'skp', 'VERSION'),
|
|
|
|
api.path['start_dir'].join('skia', 'infra', 'bots', 'assets',
|
|
|
|
'svg', 'VERSION'),
|
|
|
|
api.path['start_dir'].join('tmp', 'uninteresting_hashes.txt')
|
2017-04-30 15:14:51 +00:00
|
|
|
) +
|
|
|
|
api.step_data('get swarming bot id',
|
|
|
|
stdout=api.raw_io.output('skia-bot-123')) +
|
|
|
|
api.step_data('get swarming task id',
|
|
|
|
stdout=api.raw_io.output('123456'))
|
2017-04-10 13:56:10 +00:00
|
|
|
)
|
2019-04-15 14:56:05 +00:00
|
|
|
if 'Win' in builder and not 'LenovoYogaC630' in builder:
|
2017-04-10 13:56:10 +00:00
|
|
|
test += api.platform('win', 64)
|
|
|
|
|
|
|
|
yield test
|