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

Side by Side Diff: recipe_modules/properties/test_api.py

Issue 2442173003: Add cleaned up Gerrit props to properties.test_api.tryserver. (Closed)
Patch Set: Add pragma: no cover Created 4 years, 1 month 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
« no previous file with comments | « recipe_modules/properties/example.expected/buildbot_tryserver_gerrit_override_git.json ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright 2015 The LUCI Authors. All rights reserved. 1 # Copyright 2015 The LUCI Authors. All rights reserved.
2 # Use of this source code is governed under the Apache License, Version 2.0 2 # Use of this source code is governed under the Apache License, Version 2.0
3 # that can be found in the LICENSE file. 3 # that can be found in the LICENSE file.
4 4
5 import re
6 import urlparse
7
5 from recipe_engine import recipe_test_api 8 from recipe_engine import recipe_test_api
6 9
7 class PropertiesTestApi(recipe_test_api.RecipeTestApi): 10 class PropertiesTestApi(recipe_test_api.RecipeTestApi):
8 def __call__(self, **kwargs): 11 def __call__(self, **kwargs):
9 ret = self.test(None) 12 ret = self.test(None)
10 ret.properties.update(kwargs) 13 ret.properties.update(kwargs)
11 return ret 14 return ret
12 15
13 def generic(self, **kwargs): 16 def generic(self, **kwargs):
14 """ 17 """
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
47 """ 50 """
48 ret = self.generic( 51 ret = self.generic(
49 branch='master', 52 branch='master',
50 project='', 53 project='',
51 repository='https://chromium.googlesource.com/chromium/src.git', 54 repository='https://chromium.googlesource.com/chromium/src.git',
52 revision='c14d891d44f0afff64e56ed7c9702df1d807b1ee', 55 revision='c14d891d44f0afff64e56ed7c9702df1d807b1ee',
53 ) 56 )
54 ret.properties.update(kwargs) 57 ret.properties.update(kwargs)
55 return ret 58 return ret
56 59
60 def _gerrit_tryserver(self, **kwargs):
61 # Call it through self.tryserver with (gerrit_project='infra/infra').
62 project = kwargs.pop('gerrit_project')
63 gerrit_url = kwargs.pop('gerrit_url', None)
64 git_url = kwargs.pop('git_url', None)
65 if not gerrit_url and not git_url:
66 gerrit_url = 'https://chromium-review.googlesource.com'
67 git_url = 'https://chromium.googlesource.com/' + project
68 elif gerrit_url and not git_url:
69 parsed = list(urlparse.urlparse(gerrit_url))
70 m = re.match(r'^((\w+)(-\w+)*)-review.googlesource.com$', parsed[1])
71 if not m: # pragma: no cover
72 raise AssertionError('Can\'t guess git_url from gerrit_url "%s", '
73 'specify it as extra kwarg' % parsed[1])
74 parsed[1] = m.group(1) + '.googlesource.com'
75 parsed[2] = project
76 git_url = urlparse.urlunparse(parsed)
77 elif git_url and not gerrit_url:
78 parsed = list(urlparse.urlparse(git_url))
79 m = re.match(r'^((\w+)(-\w+)*).googlesource.com$', parsed[1])
80 if not m: # pragma: no cover
81 raise AssertionError('Can\'t guess gerrit_url from git_url "%s", '
82 'specify it as extra kwarg' % parsed[1])
83 parsed[1] = m.group(1) + '-review.googlesource.com'
84 gerrit_url = urlparse.urlunparse(parsed[:2] + [''] * len(parsed[2:]))
85 assert project
86 assert git_url
87 assert gerrit_url
88 # Pop old style values from kwargs.
89 patch_issue = int(kwargs.pop('issue', 456789))
90 patch_set = int(kwargs.pop('patchset', 12))
91 # Note that new Gerrit patch properties all start with 'patch_' prefix.
92 ret = self.generic(
93 patch_storage='gerrit',
94 patch_gerrit_url=gerrit_url,
95 patch_project=project,
96 patch_branch='master',
97 patch_issue=patch_issue,
98 patch_set=patch_set,
99 patch_repository_url=git_url,
100 patch_ref='refs/changes/%2d/%d/%d' % (
101 patch_issue % 100, patch_issue, patch_set)
102 )
103 ret.properties.update(kwargs)
104 return ret
105
57 def tryserver(self, **kwargs): 106 def tryserver(self, **kwargs):
58 """ 107 """
59 Merge kwargs into a typical buildbot properties blob for a job fired off 108 Merge kwargs into a typical buildbot properties blob for a job fired off
60 by a rietveld tryjob on the tryserver, and return the blob. 109 by a rietveld tryjob on the tryserver, and return the blob.
110
111 If gerrit_project is given, generated properties for tryjobs for Gerrit
112 patches as if they were scheduled by CQ. In this case, gerrit_url and
113 git_url could be used to customize expectations.
61 """ 114 """
62 ret = self.generic( 115 if kwargs.get('gerrit_project') is not None:
63 branch='', 116 return self._gerrit_tryserver(**kwargs)
64 issue=12853011, 117 else:
Paweł Hajdan Jr. 2016/10/25 10:58:54 nit: No need for "else" after return.
tandrii(chromium) 2016/10/25 12:38:31 Done.
65 patchset=1, 118 ret = self.generic(
66 project='chrome', 119 branch='',
67 repository='', 120 issue=12853011,
68 requester='commit-bot@chromium.org', 121 patchset=1,
69 revision='HEAD', 122 project='chrome',
70 rietveld='https://codereview.chromium.org', 123 repository='',
71 patch_project='chromium', 124 requester='commit-bot@chromium.org',
72 ) 125 revision='HEAD',
126 rietveld='https://codereview.chromium.org',
127 patch_project='chromium',
128 )
73 ret.properties.update(kwargs) 129 ret.properties.update(kwargs)
74 return ret 130 return ret
75 131
76 def tryserver_gerrit(self, full_project_name, gerrit_host=None, **kwargs): 132 def tryserver_gerrit(self, full_project_name, gerrit_host=None, **kwargs):
77 """ 133 """
134 DEPRECATED. Use tryserver(gerrit_project='infra/infra') instead.
135
78 Merge kwargs into a typical buildbot properties blob for a job fired off 136 Merge kwargs into a typical buildbot properties blob for a job fired off
79 by a gerrit tryjob on the tryserver, and return the blob. 137 by a gerrit tryjob on the tryserver, and return the blob.
80 138
81 Arguments: 139 Arguments:
82 full_project_name: (required) name of the project in Gerrit. 140 full_project_name: (required) name of the project in Gerrit.
83 gerrit_host: hostname of the gerrit server. 141 gerrit_host: hostname of the gerrit server.
84 Example: chromium-review.googlesource.com. 142 Example: chromium-review.googlesource.com.
85 """ 143 """
144 # TODO(tandrii): remove this method.
86 gerrit_host = gerrit_host or 'chromium-review.googlesource.com' 145 gerrit_host = gerrit_host or 'chromium-review.googlesource.com'
87 parts = gerrit_host.split('.') 146 parts = gerrit_host.split('.')
88 assert parts[0].endswith('-review') 147 assert parts[0].endswith('-review')
89 parts[0] = parts[0][:-len('-review')] 148 parts[0] = parts[0][:-len('-review')]
90 repository = 'https://%s/%s' % ('.'.join(parts), full_project_name) 149 repository = 'https://%s/%s' % ('.'.join(parts), full_project_name)
91 150
92 ret = self.generic( 151 ret = self.generic(
93 branch='', 152 branch='',
94 category='cq', 153 category='cq',
95 gerrit='https://%s' % gerrit_host, 154 gerrit='https://%s' % gerrit_host,
96 patch_storage='gerrit', 155 patch_storage='gerrit',
97 project=full_project_name, 156 project=full_project_name,
98 patch_project=full_project_name, 157 patch_project=full_project_name,
99 reason='CQ', 158 reason='CQ',
100 repository=repository, 159 repository=repository,
101 requester='commit-bot@chromium.org', 160 requester='commit-bot@chromium.org',
102 revision='HEAD', 161 revision='HEAD',
103 ) 162 )
104 ret.properties.update({ 163 ret.properties.update({
105 'event.change.id': u'%s~master~Ideadbeaf' % 164 'event.change.id': u'%s~master~Ideadbeaf' %
106 (full_project_name.replace('/', '%2F')), 165 (full_project_name.replace('/', '%2F')),
107 'event.change.number': 338811, 166 'event.change.number': 338811,
108 'event.change.url': u'https://%s/#/c/338811' % gerrit_host, 167 'event.change.url': u'https://%s/#/c/338811' % gerrit_host,
109 'event.patchSet.ref': u'refs/changes/11/338811/3', 168 'event.patchSet.ref': u'refs/changes/11/338811/3',
110 }) 169 })
111 ret.properties.update(kwargs) 170 ret.properties.update(kwargs)
112 return ret 171 return ret
OLDNEW
« no previous file with comments | « recipe_modules/properties/example.expected/buildbot_tryserver_gerrit_override_git.json ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698