Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(365)

Side by Side Diff: infra/bots/recipes/upload_dm_results.py

Issue 2360203004: Add swarming task for upload_dm_results (Closed)
Patch Set: gzip Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 # Copyright 2016 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4
5
6 # Recipe for uploading DM results.
7
8
9 DEPS = [
10 'recipe_engine/json',
11 'recipe_engine/path',
12 'recipe_engine/properties',
13 'recipe_engine/shutil',
14 'recipe_engine/step',
15 'recipe_engine/time',
16 ]
17
18
19 DM_JSON = 'dm.json'
20 GS_BUCKET = 'gs://chromium-skia-gm'
21 VERBOSE_LOG = 'verbose.log'
22
23
24 def RunSteps(api):
25 builder_name = api.properties['buildername']
26 revision = api.properties['revision']
27 issue = str(api.properties.get('issue', ''))
28 patchset = str(api.properties.get('patchset', ''))
29
30 results_dir = api.path['cwd'].join('dm')
31
32 # Validate the JSON file.
33 json_file = results_dir.join(DM_JSON)
34 api.json.read('validate dm.json', json_file)
35
36 # Move dm.json and verbose.log to their own directory.
37 log_file = results_dir.join(VERBOSE_LOG)
38 tmp_dir = api.path['cwd'].join('tmp_upload')
39 api.shutil.makedirs('tmp dir', tmp_dir, infra_step=True)
40 api.shutil.copy('copy dm.json', json_file, tmp_dir)
41 api.shutil.copy('copy verbose.log', log_file, tmp_dir)
42 api.shutil.remove('rm old dm.json', json_file)
43 api.shutil.remove('rm old verbose.log', log_file)
44
45 # Upload the images.
46 # TODO(borenet): Are the permissions correct? We want only Google-readable.
borenet 2016/09/23 15:56:39 It *seems* to be correct, eg. Old upload: http://
stephana 2016/09/26 16:11:24 We should set this to the new bucket before we lan
borenet 2016/09/26 17:35:38 Changed to use the new bucket, and the default per
47 image_dest_path = '/'.join((GS_BUCKET, 'dm-images-v1-test'))
48 api.step(
49 'upload images',
50 cmd=['gsutil', 'cp', results_dir.join('*'), image_dest_path],
51 )
52
53 # Upload the JSON summary and verbose.log.
54 now = api.time.utcnow()
55 # TODO(borenet): These used to also be keyed by build number, which is no
56 # longer a concept. What should we use instead?
borenet 2016/09/23 15:56:39 For nanobench results we don't use a build number;
stephana 2016/09/26 16:11:24 Per our offline conversation we should inject a ti
borenet 2016/09/26 17:35:38 Added the timestamp.
57 summary_dest_path = '/'.join([
58 'dm-json-v1-test',
59 str(now.year ).zfill(4),
60 str(now.month).zfill(2),
61 str(now.day ).zfill(2),
62 str(now.hour ).zfill(2),
63 revision,
64 builder_name])
65
66 # Trybot results are further siloed by issue/patchset.
67 if builder_name.endswith('-Trybot'):
68 if not (issue and patchset): # pragma: nocover
69 raise Exception('issue and patchset properties are required for trybots.')
70 summary_dest_path = '/'.join(('trybot', summary_dest_path, issue, patchset))
71
72 summary_dest_path = '/'.join((GS_BUCKET, summary_dest_path))
73
74 api.step(
75 'upload JSON and logs',
76 cmd=['gsutil', 'cp', '-Z', tmp_dir.join('*'), summary_dest_path],
77 )
78
79
80 def GenTests(api):
81 builder = 'Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Debug'
82 yield (
83 api.test('normal_bot') +
84 api.properties(buildername=builder,
85 revision='abc123',
86 path_config='kitchen')
87 )
88
89 builder = 'Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Debug-Trybot'
90 yield (
91 api.test('trybot') +
92 api.properties(buildername=builder,
93 revision='abc123',
94 path_config='kitchen',
95 issue='12345',
96 patchset='1002')
97 )
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698