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.
|
|
|
|
|
|
|
|
|
|
|
|
DEPS = [
|
|
|
|
'build/file',
|
|
|
|
'recipe_engine/json',
|
|
|
|
'recipe_engine/path',
|
|
|
|
'recipe_engine/properties',
|
|
|
|
'recipe_engine/shutil',
|
|
|
|
'recipe_engine/step',
|
|
|
|
'recipe_engine/time',
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2016-10-05 18:43:41 +00:00
|
|
|
import calendar
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
DM_JSON = 'dm.json'
|
|
|
|
GS_BUCKET = 'gs://skia-infra-gm'
|
2016-10-04 13:32:54 +00:00
|
|
|
UPLOAD_ATTEMPTS = 5
|
2016-09-27 13:52:26 +00:00
|
|
|
VERBOSE_LOG = 'verbose.log'
|
|
|
|
|
|
|
|
|
2016-10-04 13:32:54 +00:00
|
|
|
def cp(api, name, src, dst, extra_args=None):
|
|
|
|
cmd = ['gsutil', 'cp']
|
|
|
|
if extra_args:
|
|
|
|
cmd.extend(extra_args)
|
|
|
|
cmd.extend([src, dst])
|
|
|
|
|
|
|
|
name = 'upload %s' % name
|
|
|
|
for i in xrange(UPLOAD_ATTEMPTS):
|
|
|
|
step_name = name
|
|
|
|
if i > 0:
|
|
|
|
step_name += ' (attempt %d)' % (i+1)
|
|
|
|
try:
|
|
|
|
api.step(step_name, cmd=cmd)
|
|
|
|
break
|
|
|
|
except api.step.StepFailure:
|
|
|
|
if i == UPLOAD_ATTEMPTS - 1:
|
|
|
|
raise
|
|
|
|
|
|
|
|
|
2016-09-27 13:52:26 +00:00
|
|
|
def RunSteps(api):
|
|
|
|
builder_name = api.properties['buildername']
|
|
|
|
revision = api.properties['revision']
|
2016-09-27 15:30:48 +00:00
|
|
|
|
2016-11-21 21:06:19 +00:00
|
|
|
results_dir = api.path['start_dir'].join('dm')
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
# Move dm.json and verbose.log to their own directory.
|
2016-09-30 19:18:47 +00:00
|
|
|
json_file = results_dir.join(DM_JSON)
|
2016-09-27 13:52:26 +00:00
|
|
|
log_file = results_dir.join(VERBOSE_LOG)
|
2016-11-21 21:06:19 +00:00
|
|
|
tmp_dir = api.path['start_dir'].join('tmp_upload')
|
2016-09-27 13:52:26 +00:00
|
|
|
api.shutil.makedirs('tmp dir', tmp_dir, infra_step=True)
|
|
|
|
api.shutil.copy('copy dm.json', json_file, tmp_dir)
|
|
|
|
api.shutil.copy('copy verbose.log', log_file, tmp_dir)
|
|
|
|
api.shutil.remove('rm old dm.json', json_file)
|
|
|
|
api.shutil.remove('rm old verbose.log', log_file)
|
|
|
|
|
|
|
|
# Upload the images.
|
|
|
|
image_dest_path = '/'.join((GS_BUCKET, 'dm-images-v1'))
|
|
|
|
files_to_upload = api.file.glob(
|
|
|
|
'find images',
|
|
|
|
results_dir.join('*'),
|
|
|
|
test_data=['someimage.png'],
|
|
|
|
infra_step=True)
|
|
|
|
if len(files_to_upload) > 0:
|
2016-10-04 13:32:54 +00:00
|
|
|
cp(api, 'images', results_dir.join('*'), image_dest_path)
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
# Upload the JSON summary and verbose.log.
|
|
|
|
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,
|
|
|
|
builder_name,
|
2016-10-05 18:43:41 +00:00
|
|
|
str(int(calendar.timegm(now.utctimetuple())))])
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
# Trybot results are further siloed by issue/patchset.
|
2016-10-13 13:23:45 +00:00
|
|
|
issue = str(api.properties.get('issue', ''))
|
|
|
|
patchset = str(api.properties.get('patchset', ''))
|
2016-11-07 22:16:05 +00:00
|
|
|
if api.properties.get('patch_storage', '') == 'gerrit':
|
2016-10-27 13:35:51 +00:00
|
|
|
issue = str(api.properties['patch_issue'])
|
2016-11-07 22:16:05 +00:00
|
|
|
patchset = str(api.properties['patch_set'])
|
2016-10-13 13:23:45 +00:00
|
|
|
if issue and patchset:
|
|
|
|
summary_dest_path = '/'.join((
|
|
|
|
'trybot', summary_dest_path, issue, patchset))
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
summary_dest_path = '/'.join((GS_BUCKET, summary_dest_path))
|
|
|
|
|
2016-10-04 13:32:54 +00:00
|
|
|
cp(api, 'JSON and logs', tmp_dir.join('*'), summary_dest_path,
|
|
|
|
['-z', 'json,log'])
|
2016-09-27 13:52:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
def GenTests(api):
|
|
|
|
builder = 'Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Debug'
|
|
|
|
yield (
|
|
|
|
api.test('normal_bot') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen')
|
|
|
|
)
|
|
|
|
|
2016-10-04 13:32:54 +00:00
|
|
|
yield (
|
|
|
|
api.test('failed_once') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen') +
|
|
|
|
api.step_data('upload images', retcode=1)
|
|
|
|
)
|
|
|
|
|
|
|
|
yield (
|
|
|
|
api.test('failed_all') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen') +
|
|
|
|
api.step_data('upload images', retcode=1) +
|
|
|
|
api.step_data('upload images (attempt 2)', retcode=1) +
|
|
|
|
api.step_data('upload images (attempt 3)', retcode=1) +
|
|
|
|
api.step_data('upload images (attempt 4)', retcode=1) +
|
|
|
|
api.step_data('upload images (attempt 5)', retcode=1)
|
|
|
|
)
|
|
|
|
|
2016-09-27 13:52:26 +00:00
|
|
|
builder = 'Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Debug-Trybot'
|
|
|
|
yield (
|
|
|
|
api.test('trybot') +
|
|
|
|
api.properties(buildername=builder,
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen',
|
|
|
|
issue='12345',
|
|
|
|
patchset='1002')
|
|
|
|
)
|
2016-09-27 15:30:48 +00:00
|
|
|
|
|
|
|
yield (
|
|
|
|
api.test('recipe_with_gerrit_patch') +
|
|
|
|
api.properties(
|
|
|
|
buildername=builder,
|
|
|
|
revision='abc123',
|
|
|
|
path_config='kitchen',
|
2016-10-27 13:35:51 +00:00
|
|
|
patch_storage='gerrit') +
|
|
|
|
api.properties.tryserver(
|
|
|
|
buildername=builder,
|
|
|
|
gerrit_project='skia',
|
|
|
|
gerrit_url='https://skia-review.googlesource.com/',
|
|
|
|
)
|
2016-09-27 15:30:48 +00:00
|
|
|
)
|