2016-09-27 13:52:26 +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 for uploading DM results.
|
|
|
|
|
|
|
|
|
2017-04-10 12:19:10 +00:00
|
|
|
import calendar
|
|
|
|
|
2021-11-30 18:59:12 +00:00
|
|
|
PYTHON_VERSION_COMPATIBILITY = "PY3"
|
2017-04-10 12:19:10 +00:00
|
|
|
|
2016-09-27 13:52:26 +00:00
|
|
|
DEPS = [
|
2017-06-16 17:10:22 +00:00
|
|
|
'recipe_engine/file',
|
2017-04-10 12:19:10 +00:00
|
|
|
'recipe_engine/json',
|
|
|
|
'recipe_engine/path',
|
2016-09-27 13:52:26 +00:00
|
|
|
'recipe_engine/properties',
|
2017-04-10 12:19:10 +00:00
|
|
|
'recipe_engine/step',
|
|
|
|
'recipe_engine/time',
|
2017-10-09 19:26:19 +00:00
|
|
|
'gsutil',
|
2019-10-08 00:11:36 +00:00
|
|
|
'vars',
|
2016-09-27 13:52:26 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2017-04-10 12:19:10 +00:00
|
|
|
DM_JSON = 'dm.json'
|
|
|
|
VERBOSE_LOG = 'verbose.log'
|
|
|
|
|
|
|
|
|
2016-09-27 13:52:26 +00:00
|
|
|
def RunSteps(api):
|
2019-10-08 00:11:36 +00:00
|
|
|
api.vars.setup()
|
2017-04-10 12:19:10 +00:00
|
|
|
revision = api.properties['revision']
|
|
|
|
|
2018-06-20 17:23:16 +00:00
|
|
|
results_dir = api.path['start_dir'].join('test')
|
2017-04-10 12:19:10 +00:00
|
|
|
|
2018-08-20 15:28:56 +00:00
|
|
|
# Upload the images. It is *vital* that the images are uploaded first
|
|
|
|
# so they exist whenever the json is processed.
|
2018-08-02 06:51:38 +00:00
|
|
|
image_dest_path = 'gs://%s/dm-images-v1' % api.properties['gs_bucket']
|
2017-06-16 17:10:22 +00:00
|
|
|
for ext in ['.png', '.pdf']:
|
|
|
|
files_to_upload = api.file.glob_paths(
|
2018-08-16 12:59:41 +00:00
|
|
|
'find %s images' % ext,
|
2017-06-16 17:10:22 +00:00
|
|
|
results_dir,
|
|
|
|
'*%s' % ext,
|
|
|
|
test_data=['someimage.png'])
|
|
|
|
# For some reason, glob returns results_dir when it should return nothing.
|
|
|
|
files_to_upload = [f for f in files_to_upload if str(f).endswith(ext)]
|
|
|
|
if len(files_to_upload) > 0:
|
2018-08-20 15:28:56 +00:00
|
|
|
api.gsutil.cp('%s images' % ext, results_dir.join('*%s' % ext),
|
2018-01-16 21:06:09 +00:00
|
|
|
image_dest_path, multithread=True)
|
2017-04-10 12:19:10 +00:00
|
|
|
|
2018-08-20 15:28:56 +00:00
|
|
|
# Compute the directory to upload results to
|
2017-04-10 12:19:10 +00:00
|
|
|
now = api.time.utcnow()
|
|
|
|
summary_dest_path = '/'.join([
|
|
|
|
'dm-json-v1',
|
|
|
|
str(now.year ).zfill(4),
|
|
|
|
str(now.month).zfill(2),
|
|
|
|
str(now.day ).zfill(2),
|
|
|
|
str(now.hour ).zfill(2),
|
|
|
|
revision,
|
2019-10-08 00:11:36 +00:00
|
|
|
api.vars.builder_name,
|
2017-04-10 12:19:10 +00:00
|
|
|
str(int(calendar.timegm(now.utctimetuple())))])
|
|
|
|
|
|
|
|
# Trybot results are further siloed by issue/patchset.
|
2019-10-08 00:11:36 +00:00
|
|
|
if api.vars.is_trybot:
|
|
|
|
summary_dest_path = '/'.join(('trybot', summary_dest_path,
|
|
|
|
str(api.vars.issue), str(api.vars.patchset)))
|
2017-04-10 12:19:10 +00:00
|
|
|
|
|
|
|
summary_dest_path = 'gs://%s/%s' % (api.properties['gs_bucket'],
|
|
|
|
summary_dest_path)
|
|
|
|
|
2018-08-20 15:28:56 +00:00
|
|
|
# Directly upload dm.json and verbose.log if it exists
|
|
|
|
json_file = results_dir.join(DM_JSON)
|
|
|
|
log_file = results_dir.join(VERBOSE_LOG)
|
|
|
|
|
|
|
|
api.gsutil.cp('dm.json', json_file,
|
|
|
|
summary_dest_path + '/' + DM_JSON, extra_args=['-Z'])
|
|
|
|
|
|
|
|
files = api.file.listdir('check for optional verbose.log file',
|
|
|
|
results_dir, test_data=['dm.json', 'verbose.log'])
|
|
|
|
if log_file in files:
|
|
|
|
api.gsutil.cp('verbose.log', log_file,
|
|
|
|
summary_dest_path + '/' + VERBOSE_LOG, extra_args=['-Z'])
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
def GenTests(api):
|
2020-04-07 01:27:14 +00:00
|
|
|
builder = 'Upload-Test-Debian10-Clang-GCE-CPU-AVX2-x86_64-Debug-All'
|
2016-09-27 13:52:26 +00:00
|
|
|
yield (
|
2017-04-10 12:19:10 +00:00
|
|
|
api.test('normal_bot') +
|
|
|
|
api.properties(buildername=builder,
|
2017-02-06 20:38:41 +00:00
|
|
|
gs_bucket='skia-infra-gm',
|
2016-09-27 13:52:26 +00:00
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen')
|
|
|
|
)
|
2017-04-10 12:19:10 +00:00
|
|
|
|
2017-09-15 13:56:24 +00:00
|
|
|
yield (
|
|
|
|
api.test('alternate_bucket') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
gs_bucket='skia-infra-gm-alt',
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen')
|
|
|
|
)
|
|
|
|
|
2017-04-10 12:19:10 +00:00
|
|
|
yield (
|
|
|
|
api.test('failed_once') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
gs_bucket='skia-infra-gm',
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen') +
|
2018-08-20 15:28:56 +00:00
|
|
|
api.step_data('upload .png images', retcode=1)
|
2017-04-10 12:19:10 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
yield (
|
|
|
|
api.test('failed_all') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
gs_bucket='skia-infra-gm',
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen') +
|
2018-08-20 15:28:56 +00:00
|
|
|
api.step_data('upload .png images', retcode=1) +
|
|
|
|
api.step_data('upload .png images (attempt 2)', retcode=1) +
|
|
|
|
api.step_data('upload .png images (attempt 3)', retcode=1) +
|
|
|
|
api.step_data('upload .png images (attempt 4)', retcode=1) +
|
|
|
|
api.step_data('upload .png images (attempt 5)', retcode=1)
|
2017-04-10 12:19:10 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
yield (
|
2017-04-10 13:56:10 +00:00
|
|
|
api.test('trybot') +
|
2019-10-08 00:11:36 +00:00
|
|
|
api.properties.tryserver(
|
|
|
|
gerrit_project='skia',
|
|
|
|
gerrit_url='https://skia-review.googlesource.com/',
|
|
|
|
) +
|
2017-04-10 12:19:10 +00:00
|
|
|
api.properties(
|
|
|
|
buildername=builder,
|
|
|
|
gs_bucket='skia-infra-gm',
|
|
|
|
revision='abc123',
|
2019-10-08 00:11:36 +00:00
|
|
|
path_config='kitchen')
|
2017-04-10 12:19:10 +00:00
|
|
|
)
|