blob: 5f7da3d22fb0a3ab383594a0c72fa03146c11916 [file] [log] [blame]
Mike Frysingere58c0e22017-10-04 15:43:30 -04001# -*- coding: utf-8 -*-
Chris Sosa9ba47752012-02-27 15:27:37 -08002# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Chris Sosadad0d322011-01-31 16:37:33 -08003# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""This module uprevs Chrome for cbuildbot.
7
8After calling, it prints outs CHROME_VERSION_ATOM=(version atom string). A
9caller could then use this atom with emerge to build the newly uprevved version
10of Chrome e.g.
11
12./cros_mark_chrome_as_stable tot
13Returns chrome-base/chromeos-chrome-8.0.552.0_alpha_r1
14
15emerge-x86-generic =chrome-base/chromeos-chrome-8.0.552.0_alpha_r1
16"""
17
Mike Frysinger383367e2014-09-16 15:06:17 -040018from __future__ import print_function
19
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070020import base64
21import distutils.version
Chris Sosa8be39132011-04-14 12:09:24 -070022import filecmp
Chris Sosadad0d322011-01-31 16:37:33 -080023import os
24import re
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070025import urlparse
Chris Sosadad0d322011-01-31 16:37:33 -080026
Aviv Keshetb7519e12016-10-04 00:50:00 -070027from chromite.lib import constants
Mike Frysingera13c04f2016-09-01 00:35:17 -040028from chromite.lib import commandline
David James1b363582012-12-17 11:53:11 -080029from chromite.lib import cros_build_lib
Ralph Nathan03047282015-03-23 11:09:32 -070030from chromite.lib import cros_logging as logging
David James97d95872012-11-16 15:09:56 -080031from chromite.lib import git
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070032from chromite.lib import gob_util
Alex Deymo075c2292014-09-04 18:31:50 -070033from chromite.lib import portage_util
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070034from chromite.lib import timeout_util
Mike Frysinger6cb624a2012-05-24 18:17:38 -040035from chromite.scripts import cros_mark_as_stable
Chris Sosadad0d322011-01-31 16:37:33 -080036
Mike Frysinger750c5f52014-09-16 16:16:57 -040037
Chris Sosadad0d322011-01-31 16:37:33 -080038# Helper regex's for finding ebuilds.
David James7c352bc2013-03-15 14:19:57 -070039_CHROME_VERSION_REGEX = r'\d+\.\d+\.\d+\.\d+'
40_NON_STICKY_REGEX = r'%s[(_rc.*)|(_alpha.*)]+' % _CHROME_VERSION_REGEX
Chris Sosadad0d322011-01-31 16:37:33 -080041
42# Dir where all the action happens.
David Zeuthen665d3132014-08-25 15:27:02 -040043_OVERLAY_DIR = '%(srcroot)s/third_party/chromiumos-overlay/'
Chris Sosadad0d322011-01-31 16:37:33 -080044
David Zeuthen665d3132014-08-25 15:27:02 -040045_GIT_COMMIT_MESSAGE = ('Marking %(chrome_rev)s for %(chrome_pn)s ebuild '
46 'with version %(chrome_version)s as stable.')
Chris Sosadad0d322011-01-31 16:37:33 -080047
Chris Masone592cab52011-08-02 14:05:48 -070048# URLs that print lists of chrome revisions between two versions of the browser.
49_CHROME_VERSION_URL = ('http://omahaproxy.appspot.com/changelog?'
50 'old_version=%(old)s&new_version=%(new)s')
Chris Sosadd611df2012-02-03 15:26:23 -080051
52# Only print links when we rev these types.
53_REV_TYPES_FOR_LINKS = [constants.CHROME_REV_LATEST,
54 constants.CHROME_REV_STICKY]
Chris Masone592cab52011-08-02 14:05:48 -070055
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070056# TODO(szager): This is inaccurate, but is it safe to change? I have no idea.
Chris Masone592cab52011-08-02 14:05:48 -070057_CHROME_SVN_TAG = 'CROS_SVN_COMMIT'
Chris Sosadad0d322011-01-31 16:37:33 -080058
ChromeOS Developer03118eb2013-02-12 14:27:09 -080059
petermayo@chromium.org163b3372011-09-12 02:06:05 -040060def _GetVersionContents(chrome_version_info):
Peter Mayo177500f2011-09-09 17:25:23 -040061 """Returns the current Chromium version, from the contents of a VERSION file.
Chris Sosadad0d322011-01-31 16:37:33 -080062
Peter Mayo177500f2011-09-09 17:25:23 -040063 Args:
Mike Frysinger6f3c48e2015-05-06 02:38:51 -040064 chrome_version_info: The contents of a chromium VERSION file.
Peter Mayo177500f2011-09-09 17:25:23 -040065 """
Chris Sosadad0d322011-01-31 16:37:33 -080066 chrome_version_array = []
Chris Sosadad0d322011-01-31 16:37:33 -080067 for line in chrome_version_info.splitlines():
68 chrome_version_array.append(line.rpartition('=')[2])
69
70 return '.'.join(chrome_version_array)
71
Mike Frysingercc838832014-05-24 13:10:30 -040072
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070073def _GetSpecificVersionUrl(git_url, revision, time_to_wait=600):
petermayo@chromium.org163b3372011-09-12 02:06:05 -040074 """Returns the Chromium version, from a repository URL and version.
Peter Mayo177500f2011-09-09 17:25:23 -040075
76 Args:
Mike Frysinger6f3c48e2015-05-06 02:38:51 -040077 git_url: Repository URL for chromium.
78 revision: the git revision we want to use.
79 time_to_wait: the minimum period before abandoning our wait for the
80 desired revision to be present.
Peter Mayo177500f2011-09-09 17:25:23 -040081 """
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070082 parsed_url = urlparse.urlparse(git_url)
83 host = parsed_url[1]
84 path = parsed_url[2].rstrip('/') + (
85 '/+/%s/chrome/VERSION?format=text' % revision)
petermayo@chromium.org163b3372011-09-12 02:06:05 -040086
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070087 # Allow for git repository replication lag with sleep/retry loop.
88 def _fetch():
89 fh = gob_util.FetchUrl(host, path, ignore_404=True)
90 return fh.read() if fh else None
petermayo@chromium.org163b3372011-09-12 02:06:05 -040091
Mike Frysingercc55c782014-12-03 22:32:08 -050092 def _wait_msg(_remaining):
Ralph Nathan03047282015-03-23 11:09:32 -070093 logging.info('Repository does not yet have revision %s. Sleeping...',
94 revision)
petermayo@chromium.org163b3372011-09-12 02:06:05 -040095
Stefan Zagerd49d9ff2014-08-15 21:33:37 -070096 content = timeout_util.WaitForSuccess(
97 retry_check=lambda x: not bool(x),
98 func=_fetch,
99 timeout=time_to_wait,
100 period=30,
101 side_effect_func=_wait_msg)
102 return _GetVersionContents(base64.b64decode(content))
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400103
Peter Mayo177500f2011-09-09 17:25:23 -0400104
105def _GetTipOfTrunkVersionFile(root):
106 """Returns the current Chromium version, from a file in a checkout.
107
108 Args:
Mike Frysinger6f3c48e2015-05-06 02:38:51 -0400109 root: path to the root of the chromium checkout.
Peter Mayo177500f2011-09-09 17:25:23 -0400110 """
111 version_file = os.path.join(root, 'src', 'chrome', 'VERSION')
ChromeOS Developer03118eb2013-02-12 14:27:09 -0800112 chrome_version_info = cros_build_lib.RunCommand(
Peter Mayo177500f2011-09-09 17:25:23 -0400113 ['cat', version_file],
114 redirect_stdout=True,
J. Richard Barnetted422f622011-11-17 09:39:46 -0800115 error_message='Could not read version file at %s.' % version_file).output
Peter Mayo177500f2011-09-09 17:25:23 -0400116
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400117 return _GetVersionContents(chrome_version_info)
Peter Mayo177500f2011-09-09 17:25:23 -0400118
ChromeOS Developer03118eb2013-02-12 14:27:09 -0800119
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700120def CheckIfChromeRightForOS(deps_content):
Dharani Govindan4beb94c2014-07-18 13:31:47 -0700121 """Checks if DEPS is right for Chrome OS.
122
123 This function checks for a variable called 'buildspec_platforms' to
124 find out if its 'chromeos' or 'all'. If any of those values,
125 then it chooses that DEPS.
126
127 Args:
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700128 deps_content: Content of release buildspec DEPS file.
Dharani Govindan4beb94c2014-07-18 13:31:47 -0700129
130 Returns:
131 True if DEPS is the right Chrome for Chrome OS.
132 """
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700133 platforms_search = re.search(r'buildspec_platforms.*\s.*\s', deps_content)
Dharani Govindancbbf69c2014-07-29 15:37:39 -0700134
135 if platforms_search:
136 platforms = platforms_search.group()
137 if 'chromeos' in platforms or 'all' in platforms:
138 return True
Dharani Govindan4beb94c2014-07-18 13:31:47 -0700139
140 return False
141
142
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700143def GetLatestRelease(git_url, branch=None):
144 """Gets the latest release version from the release tags in the repository.
Chris Sosadad0d322011-01-31 16:37:33 -0800145
146 Args:
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700147 git_url: URL of git repository.
Mike Frysingerad8c6ca2014-02-03 11:28:45 -0500148 branch: If set, gets the latest release for branch, otherwise latest
Chris Sosadad0d322011-01-31 16:37:33 -0800149 release.
Mike Frysinger1a736a82013-12-12 01:50:59 -0500150
Chris Sosadad0d322011-01-31 16:37:33 -0800151 Returns:
152 Latest version string.
153 """
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700154 # TODO(szager): This only works for public release buildspecs in the chromium
155 # src repository. Internal buildspecs are tracked differently. At the time
156 # of writing, I can't find any callers that use this method to scan for
157 # internal buildspecs. But there may be something lurking...
158
159 parsed_url = urlparse.urlparse(git_url)
160 path = parsed_url[2].rstrip('/') + '/+refs/tags?format=JSON'
161 j = gob_util.FetchUrlJson(parsed_url[1], path, ignore_404=False)
Chris Sosadad0d322011-01-31 16:37:33 -0800162 if branch:
David James7c352bc2013-03-15 14:19:57 -0700163 chrome_version_re = re.compile(r'^%s\.\d+.*' % branch)
Chris Sosadad0d322011-01-31 16:37:33 -0800164 else:
David James7c352bc2013-03-15 14:19:57 -0700165 chrome_version_re = re.compile(r'^[0-9]+\..*')
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700166 matching_versions = [key for key in j.keys() if chrome_version_re.match(key)]
167 matching_versions.sort(key=distutils.version.LooseVersion)
168 for chrome_version in reversed(matching_versions):
169 path = parsed_url[2].rstrip() + (
170 '/+/refs/tags/%s/DEPS?format=text' % chrome_version)
171 fh = gob_util.FetchUrl(parsed_url[1], path, ignore_404=False)
172 content = fh.read() if fh else None
173 if content:
174 deps_content = base64.b64decode(content)
175 if CheckIfChromeRightForOS(deps_content):
176 return chrome_version
Peter Mayoad8173d2011-11-08 16:18:23 -0500177
178 return None
Chris Sosadad0d322011-01-31 16:37:33 -0800179
180
181def _GetStickyEBuild(stable_ebuilds):
182 """Returns the sticky ebuild."""
183 sticky_ebuilds = []
184 non_sticky_re = re.compile(_NON_STICKY_REGEX)
185 for ebuild in stable_ebuilds:
186 if not non_sticky_re.match(ebuild.version):
187 sticky_ebuilds.append(ebuild)
188
189 if not sticky_ebuilds:
190 raise Exception('No sticky ebuilds found')
191 elif len(sticky_ebuilds) > 1:
Ralph Nathan446aee92015-03-23 14:44:56 -0700192 logging.warning('More than one sticky ebuild found')
Chris Sosadad0d322011-01-31 16:37:33 -0800193
Alex Deymo075c2292014-09-04 18:31:50 -0700194 return portage_util.BestEBuild(sticky_ebuilds)
Chris Sosadad0d322011-01-31 16:37:33 -0800195
196
Alex Deymo075c2292014-09-04 18:31:50 -0700197class ChromeEBuild(portage_util.EBuild):
Chris Sosadad0d322011-01-31 16:37:33 -0800198 """Thin sub-class of EBuild that adds a chrome_version field."""
David Zeuthen665d3132014-08-25 15:27:02 -0400199 chrome_version_re = re.compile(r'.*-(%s|9999).*' % (
200 _CHROME_VERSION_REGEX))
Chris Sosadad0d322011-01-31 16:37:33 -0800201 chrome_version = ''
202
203 def __init__(self, path):
Alex Deymo075c2292014-09-04 18:31:50 -0700204 portage_util.EBuild.__init__(self, path)
Chris Sosadad0d322011-01-31 16:37:33 -0800205 re_match = self.chrome_version_re.match(self.ebuild_path_no_revision)
206 if re_match:
207 self.chrome_version = re_match.group(1)
208
Chris Sosadad0d322011-01-31 16:37:33 -0800209 def __str__(self):
210 return self.ebuild_path
211
212
David Zeuthen665d3132014-08-25 15:27:02 -0400213def FindChromeCandidates(package_dir):
Chris Sosadad0d322011-01-31 16:37:33 -0800214 """Return a tuple of chrome's unstable ebuild and stable ebuilds.
215
216 Args:
David Zeuthen665d3132014-08-25 15:27:02 -0400217 package_dir: The path to where the package ebuild is stored.
Mike Frysinger1a736a82013-12-12 01:50:59 -0500218
Chris Sosadad0d322011-01-31 16:37:33 -0800219 Returns:
220 Tuple [unstable_ebuild, stable_ebuilds].
Mike Frysinger1a736a82013-12-12 01:50:59 -0500221
Chris Sosadad0d322011-01-31 16:37:33 -0800222 Raises:
223 Exception: if no unstable ebuild exists for Chrome.
224 """
225 stable_ebuilds = []
226 unstable_ebuilds = []
227 for path in [
David Zeuthen665d3132014-08-25 15:27:02 -0400228 os.path.join(package_dir, entry) for entry in os.listdir(package_dir)]:
Chris Sosadad0d322011-01-31 16:37:33 -0800229 if path.endswith('.ebuild'):
230 ebuild = ChromeEBuild(path)
231 if not ebuild.chrome_version:
Lann Martinffb95162018-08-28 12:02:54 -0600232 logging.warning('Poorly formatted ebuild found at %s', path)
Chris Sosadad0d322011-01-31 16:37:33 -0800233 else:
234 if '9999' in ebuild.version:
235 unstable_ebuilds.append(ebuild)
236 else:
237 stable_ebuilds.append(ebuild)
238
239 # Apply some sanity checks.
240 if not unstable_ebuilds:
David Zeuthen665d3132014-08-25 15:27:02 -0400241 raise Exception('Missing 9999 ebuild for %s' % package_dir)
Chris Sosadad0d322011-01-31 16:37:33 -0800242 if not stable_ebuilds:
Lann Martinffb95162018-08-28 12:02:54 -0600243 logging.warning('Missing stable ebuild for %s', package_dir)
Chris Sosadad0d322011-01-31 16:37:33 -0800244
Alex Deymo075c2292014-09-04 18:31:50 -0700245 return portage_util.BestEBuild(unstable_ebuilds), stable_ebuilds
Chris Sosadad0d322011-01-31 16:37:33 -0800246
247
248def FindChromeUprevCandidate(stable_ebuilds, chrome_rev, sticky_branch):
249 """Finds the Chrome uprev candidate for the given chrome_rev.
250
251 Using the pre-flight logic, this means the stable ebuild you are uprevving
252 from. The difference here is that the version could be different and in
253 that case we want to find it to delete it.
254
255 Args:
256 stable_ebuilds: A list of stable ebuilds.
257 chrome_rev: The chrome_rev designating which candidate to find.
Mike Frysingerad8c6ca2014-02-03 11:28:45 -0500258 sticky_branch: The the branch that is currently sticky with Major/Minor
Chris Sosa9ba47752012-02-27 15:27:37 -0800259 components. For example: 9.0.553. Can be None but not if chrome_rev
260 is CHROME_REV_STICKY.
Mike Frysinger1a736a82013-12-12 01:50:59 -0500261
Chris Sosadad0d322011-01-31 16:37:33 -0800262 Returns:
Mike Frysinger1a736a82013-12-12 01:50:59 -0500263 The EBuild, otherwise None if none found.
Chris Sosadad0d322011-01-31 16:37:33 -0800264 """
265 candidates = []
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400266 if chrome_rev in [constants.CHROME_REV_LOCAL, constants.CHROME_REV_TOT,
267 constants.CHROME_REV_SPEC]:
268 # These are labelled alpha, for historic reasons,
Peter Mayo177500f2011-09-09 17:25:23 -0400269 # not just for the fun of confusion.
David James7c352bc2013-03-15 14:19:57 -0700270 chrome_branch_re = re.compile(r'%s.*_alpha.*' % _CHROME_VERSION_REGEX)
Chris Sosadad0d322011-01-31 16:37:33 -0800271 for ebuild in stable_ebuilds:
272 if chrome_branch_re.search(ebuild.version):
273 candidates.append(ebuild)
274
Ryan Cuic6e097d2011-06-16 12:23:14 -0700275 elif chrome_rev == constants.CHROME_REV_STICKY:
Chris Sosa9ba47752012-02-27 15:27:37 -0800276 assert sticky_branch is not None
David James7c352bc2013-03-15 14:19:57 -0700277 chrome_branch_re = re.compile(r'%s\..*' % sticky_branch)
Chris Sosadad0d322011-01-31 16:37:33 -0800278 for ebuild in stable_ebuilds:
279 if chrome_branch_re.search(ebuild.version):
280 candidates.append(ebuild)
281
282 else:
David James7c352bc2013-03-15 14:19:57 -0700283 chrome_branch_re = re.compile(r'%s.*_rc.*' % _CHROME_VERSION_REGEX)
Chris Sosadad0d322011-01-31 16:37:33 -0800284 for ebuild in stable_ebuilds:
Chris Sosa9ba47752012-02-27 15:27:37 -0800285 if chrome_branch_re.search(ebuild.version):
Chris Sosadad0d322011-01-31 16:37:33 -0800286 candidates.append(ebuild)
287
288 if candidates:
Alex Deymo075c2292014-09-04 18:31:50 -0700289 return portage_util.BestEBuild(candidates)
Chris Sosadad0d322011-01-31 16:37:33 -0800290 else:
291 return None
292
Mike Frysingercc838832014-05-24 13:10:30 -0400293
Chris Masone592cab52011-08-02 14:05:48 -0700294def GetChromeRevisionLinkFromVersions(old_chrome_version, chrome_version):
295 """Return appropriately formatted link to revision info, given versions
296
297 Given two chrome version strings (e.g. 9.0.533.0), generate a link to a
298 page that prints the Chromium revisions between those two versions.
299
300 Args:
301 old_chrome_version: version to diff from
302 chrome_version: version to which to diff
Mike Frysinger1a736a82013-12-12 01:50:59 -0500303
Chris Masone592cab52011-08-02 14:05:48 -0700304 Returns:
305 The desired URL.
306 """
Mike Frysingerd6e2df02014-11-26 02:55:04 -0500307 return _CHROME_VERSION_URL % {'old': old_chrome_version,
308 'new': chrome_version}
Chris Masone592cab52011-08-02 14:05:48 -0700309
Mike Frysinger750c5f52014-09-16 16:16:57 -0400310
Chris Masone592cab52011-08-02 14:05:48 -0700311def GetChromeRevisionListLink(old_chrome, new_chrome, chrome_rev):
312 """Returns a link to the list of revisions between two Chromium versions
313
314 Given two ChromeEBuilds and the kind of rev we're doing, generate a
315 link to a page that prints the Chromium changes between those two
316 revisions, inclusive.
317
318 Args:
319 old_chrome: ebuild for the version to diff from
320 new_chrome: ebuild for the version to which to diff
321 chrome_rev: one of constants.VALID_CHROME_REVISIONS
Mike Frysinger1a736a82013-12-12 01:50:59 -0500322
Chris Masone592cab52011-08-02 14:05:48 -0700323 Returns:
324 The desired URL.
325 """
Chris Sosadd611df2012-02-03 15:26:23 -0800326 assert chrome_rev in _REV_TYPES_FOR_LINKS
327 return GetChromeRevisionLinkFromVersions(old_chrome.chrome_version,
328 new_chrome.chrome_version)
Chris Sosadad0d322011-01-31 16:37:33 -0800329
Mike Frysingercc838832014-05-24 13:10:30 -0400330
David Zeuthen665d3132014-08-25 15:27:02 -0400331def MarkChromeEBuildAsStable(stable_candidate, unstable_ebuild, chrome_pn,
332 chrome_rev, chrome_version, commit, package_dir):
David James7c352bc2013-03-15 14:19:57 -0700333 r"""Uprevs the chrome ebuild specified by chrome_rev.
Chris Sosadad0d322011-01-31 16:37:33 -0800334
335 This is the main function that uprevs the chrome_rev from a stable candidate
336 to its new version.
337
338 Args:
339 stable_candidate: ebuild that corresponds to the stable ebuild we are
340 revving from. If None, builds the a new ebuild given the version
341 and logic for chrome_rev type with revision set to 1.
Mike Frysingerad8c6ca2014-02-03 11:28:45 -0500342 unstable_ebuild: ebuild corresponding to the unstable ebuild for chrome.
David Zeuthen665d3132014-08-25 15:27:02 -0400343 chrome_pn: package name.
Peter Mayo177500f2011-09-09 17:25:23 -0400344 chrome_rev: one of constants.VALID_CHROME_REVISIONS or LOCAL
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400345 constants.CHROME_REV_SPEC - Requires commit value. Revs the ebuild for
346 the specified version and uses the portage suffix of _alpha.
Ryan Cuic6e097d2011-06-16 12:23:14 -0700347 constants.CHROME_REV_TOT - Requires commit value. Revs the ebuild for
348 the TOT version and uses the portage suffix of _alpha.
Peter Mayo177500f2011-09-09 17:25:23 -0400349 constants.CHROME_REV_LOCAL - Requires a chrome_root. Revs the ebuild for
350 the local version and uses the portage suffix of _alpha.
Ryan Cuic6e097d2011-06-16 12:23:14 -0700351 constants.CHROME_REV_LATEST - This uses the portage suffix of _rc as they
352 are release candidates for the next sticky version.
353 constants.CHROME_REV_STICKY - Revs the sticky version.
Mike Frysingerad8c6ca2014-02-03 11:28:45 -0500354 chrome_version: The \d.\d.\d.\d version of Chrome.
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700355 commit: Used with constants.CHROME_REV_TOT. The git revision of chrome.
David Zeuthen665d3132014-08-25 15:27:02 -0400356 package_dir: Path to the chromeos-chrome package dir.
Mike Frysinger1a736a82013-12-12 01:50:59 -0500357
Chris Sosadad0d322011-01-31 16:37:33 -0800358 Returns:
359 Full portage version atom (including rc's, etc) that was revved.
360 """
Chris Sosa8be39132011-04-14 12:09:24 -0700361 def IsTheNewEBuildRedundant(new_ebuild, stable_ebuild):
362 """Returns True if the new ebuild is redundant.
363
364 This is True if there if the current stable ebuild is the exact same copy
David James89608f92012-11-03 14:14:12 -0700365 of the new one.
Chris Sosa8be39132011-04-14 12:09:24 -0700366 """
367 if not stable_ebuild:
368 return False
369
370 if stable_candidate.chrome_version == new_ebuild.chrome_version:
David James89608f92012-11-03 14:14:12 -0700371 return filecmp.cmp(
372 new_ebuild.ebuild_path, stable_ebuild.ebuild_path, shallow=False)
Chris Sosa8be39132011-04-14 12:09:24 -0700373
David James629febb2012-11-25 13:07:34 -0800374 # Mark latest release and sticky branches as stable.
375 mark_stable = chrome_rev not in [constants.CHROME_REV_TOT,
376 constants.CHROME_REV_SPEC,
377 constants.CHROME_REV_LOCAL]
378
Chris Sosadad0d322011-01-31 16:37:33 -0800379 # Case where we have the last stable candidate with same version just rev.
380 if stable_candidate and stable_candidate.chrome_version == chrome_version:
381 new_ebuild_path = '%s-r%d.ebuild' % (
382 stable_candidate.ebuild_path_no_revision,
383 stable_candidate.current_revision + 1)
384 else:
David James629febb2012-11-25 13:07:34 -0800385 suffix = 'rc' if mark_stable else 'alpha'
David Zeuthen665d3132014-08-25 15:27:02 -0400386 pf = '%s-%s_%s-r1' % (chrome_pn, chrome_version, suffix)
387 new_ebuild_path = os.path.join(package_dir, '%s.ebuild' % pf)
Chris Sosadad0d322011-01-31 16:37:33 -0800388
David Jamesa6792552012-04-03 10:05:35 -0700389 chrome_variables = dict()
390 if commit:
391 chrome_variables[_CHROME_SVN_TAG] = commit
392
Alex Deymo075c2292014-09-04 18:31:50 -0700393 portage_util.EBuild.MarkAsStable(
David James065b2012012-04-01 14:51:11 -0700394 unstable_ebuild.ebuild_path, new_ebuild_path,
David Jamesa6792552012-04-03 10:05:35 -0700395 chrome_variables, make_stable=mark_stable)
Chris Sosadad0d322011-01-31 16:37:33 -0800396 new_ebuild = ChromeEBuild(new_ebuild_path)
Chris Sosa8be39132011-04-14 12:09:24 -0700397
398 # Determine whether this is ebuild is redundant.
399 if IsTheNewEBuildRedundant(new_ebuild, stable_candidate):
David James1b363582012-12-17 11:53:11 -0800400 msg = 'Previous ebuild with same version found and ebuild is redundant.'
Ralph Nathan03047282015-03-23 11:09:32 -0700401 logging.info(msg)
Chris Sosa8be39132011-04-14 12:09:24 -0700402 os.unlink(new_ebuild_path)
403 return None
Chris Sosadad0d322011-01-31 16:37:33 -0800404
Chris Sosadd611df2012-02-03 15:26:23 -0800405 if stable_candidate and chrome_rev in _REV_TYPES_FOR_LINKS:
David Riley3e3f64e2016-02-03 08:17:55 -0800406 logging.PrintBuildbotLink('Chromium revisions',
407 GetChromeRevisionListLink(stable_candidate,
408 new_ebuild, chrome_rev))
Chris Masone592cab52011-08-02 14:05:48 -0700409
David Zeuthen665d3132014-08-25 15:27:02 -0400410 git.RunGit(package_dir, ['add', new_ebuild_path])
Chris Sosa9ba47752012-02-27 15:27:37 -0800411 if stable_candidate and not stable_candidate.IsSticky():
David Zeuthen665d3132014-08-25 15:27:02 -0400412 git.RunGit(package_dir, ['rm', stable_candidate.ebuild_path])
Chris Sosadad0d322011-01-31 16:37:33 -0800413
Alex Deymo075c2292014-09-04 18:31:50 -0700414 portage_util.EBuild.CommitChange(
David Zeuthen665d3132014-08-25 15:27:02 -0400415 _GIT_COMMIT_MESSAGE % {'chrome_pn': chrome_pn,
416 'chrome_rev': chrome_rev,
Mike Frysinger2ebe3732012-05-08 17:04:12 -0400417 'chrome_version': chrome_version},
David Zeuthen665d3132014-08-25 15:27:02 -0400418 package_dir)
Chris Sosadad0d322011-01-31 16:37:33 -0800419
Chris Sosadad0d322011-01-31 16:37:33 -0800420 return '%s-%s' % (new_ebuild.package, new_ebuild.version)
421
422
Mike Frysingera13c04f2016-09-01 00:35:17 -0400423def GetParser():
424 """Return a command line parser."""
425 parser = commandline.ArgumentParser(description=__doc__)
426 parser.add_argument('-b', '--boards')
427 parser.add_argument('-c', '--chrome_url',
428 default=constants.CHROMIUM_GOB_URL)
429 parser.add_argument('-f', '--force_version',
430 help='Chrome version or git revision hash to use')
431 parser.add_argument('-s', '--srcroot',
432 default=os.path.join(os.environ['HOME'], 'trunk', 'src'),
433 help='Path to the src directory')
434 parser.add_argument('-t', '--tracking_branch', default='cros/master',
435 help='Branch we are tracking changes against')
436 parser.add_argument('revision', choices=constants.VALID_CHROME_REVISIONS)
437 return parser
Chris Sosadad0d322011-01-31 16:37:33 -0800438
Chris Sosadad0d322011-01-31 16:37:33 -0800439
Mike Frysingera13c04f2016-09-01 00:35:17 -0400440def main(argv):
441 parser = GetParser()
442 options = parser.parse_args(argv)
443 options.Freeze()
444 chrome_rev = options.revision
445
446 if options.force_version and chrome_rev not in (constants.CHROME_REV_SPEC,
447 constants.CHROME_REV_LATEST):
David Jamesfb160012014-07-01 10:00:57 -0700448 parser.error('--force_version is not compatible with the %r '
Mike Frysingera13c04f2016-09-01 00:35:17 -0400449 'option.' % (chrome_rev,))
David Jamesfb160012014-07-01 10:00:57 -0700450
David Zeuthen665d3132014-08-25 15:27:02 -0400451 overlay_dir = os.path.abspath(_OVERLAY_DIR % {'srcroot': options.srcroot})
452 chrome_package_dir = os.path.join(overlay_dir, constants.CHROME_CP)
Chris Sosadad0d322011-01-31 16:37:33 -0800453 version_to_uprev = None
454 commit_to_use = None
Chris Sosa9ba47752012-02-27 15:27:37 -0800455 sticky_branch = None
Chris Sosadad0d322011-01-31 16:37:33 -0800456
David Zeuthen665d3132014-08-25 15:27:02 -0400457 (unstable_ebuild, stable_ebuilds) = FindChromeCandidates(chrome_package_dir)
Chris Sosadad0d322011-01-31 16:37:33 -0800458
Peter Mayo177500f2011-09-09 17:25:23 -0400459 if chrome_rev == constants.CHROME_REV_LOCAL:
460 if 'CHROME_ROOT' in os.environ:
461 chrome_root = os.environ['CHROME_ROOT']
462 else:
463 chrome_root = os.path.join(os.environ['HOME'], 'chrome_root')
464
465 version_to_uprev = _GetTipOfTrunkVersionFile(chrome_root)
466 commit_to_use = 'Unknown'
Ralph Nathan03047282015-03-23 11:09:32 -0700467 logging.info('Using local source, versioning is untrustworthy.')
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400468 elif chrome_rev == constants.CHROME_REV_SPEC:
David Jamesfb160012014-07-01 10:00:57 -0700469 if '.' in options.force_version:
470 version_to_uprev = options.force_version
471 else:
472 commit_to_use = options.force_version
473 if '@' in commit_to_use:
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700474 commit_to_use = commit_to_use.rpartition('@')[2]
David Jamesfb160012014-07-01 10:00:57 -0700475 version_to_uprev = _GetSpecificVersionUrl(options.chrome_url,
476 commit_to_use)
Peter Mayo177500f2011-09-09 17:25:23 -0400477 elif chrome_rev == constants.CHROME_REV_TOT:
Stefan Zagerd49d9ff2014-08-15 21:33:37 -0700478 commit_to_use = gob_util.GetTipOfTrunkRevision(options.chrome_url)
petermayo@chromium.org163b3372011-09-12 02:06:05 -0400479 version_to_uprev = _GetSpecificVersionUrl(options.chrome_url,
480 commit_to_use)
Ryan Cuic6e097d2011-06-16 12:23:14 -0700481 elif chrome_rev == constants.CHROME_REV_LATEST:
David James9a5980e2014-07-16 09:37:00 -0700482 if options.force_version:
483 if '.' not in options.force_version:
484 parser.error('%s only accepts released Chrome versions, not SVN or '
485 'Git revisions.' % (chrome_rev,))
486 version_to_uprev = options.force_version
487 else:
488 version_to_uprev = GetLatestRelease(options.chrome_url)
Chris Sosadad0d322011-01-31 16:37:33 -0800489 else:
Chris Sosa9ba47752012-02-27 15:27:37 -0800490 sticky_ebuild = _GetStickyEBuild(stable_ebuilds)
491 sticky_version = sticky_ebuild.chrome_version
492 sticky_branch = sticky_version.rpartition('.')[0]
Yu-Ju Hong39806322014-06-24 16:46:32 -0700493 version_to_uprev = GetLatestRelease(options.chrome_url, sticky_branch)
Chris Sosadad0d322011-01-31 16:37:33 -0800494
495 stable_candidate = FindChromeUprevCandidate(stable_ebuilds, chrome_rev,
496 sticky_branch)
497
498 if stable_candidate:
Lann Martinffb95162018-08-28 12:02:54 -0600499 logging.info('Stable candidate found %s', stable_candidate)
Chris Sosadad0d322011-01-31 16:37:33 -0800500 else:
Ralph Nathan03047282015-03-23 11:09:32 -0700501 logging.info('No stable candidate found.')
Chris Sosadad0d322011-01-31 16:37:33 -0800502
Chris Sosa8049f3b2011-05-02 20:09:28 -0700503 tracking_branch = 'remotes/m/%s' % os.path.basename(options.tracking_branch)
David Zeuthen665d3132014-08-25 15:27:02 -0400504 existing_branch = git.GetCurrentBranch(chrome_package_dir)
Ryan Cui05a31ba2011-05-31 17:47:37 -0700505 work_branch = cros_mark_as_stable.GitBranch(constants.STABLE_EBUILD_BRANCH,
David Zeuthen665d3132014-08-25 15:27:02 -0400506 tracking_branch,
507 chrome_package_dir)
Chris Sosadad0d322011-01-31 16:37:33 -0800508 work_branch.CreateBranch()
David Jamesd6708c02012-03-22 10:49:15 -0700509
510 # In the case of uprevving overlays that have patches applied to them,
511 # include the patched changes in the stabilizing branch.
512 if existing_branch:
David Zeuthen665d3132014-08-25 15:27:02 -0400513 git.RunGit(chrome_package_dir, ['rebase', existing_branch])
David Jamesd6708c02012-03-22 10:49:15 -0700514
Chris Sosadad0d322011-01-31 16:37:33 -0800515 chrome_version_atom = MarkChromeEBuildAsStable(
David Zeuthen665d3132014-08-25 15:27:02 -0400516 stable_candidate, unstable_ebuild, 'chromeos-chrome', chrome_rev,
517 version_to_uprev, commit_to_use, chrome_package_dir)
Yu-Ju Hong078c9ec2014-08-06 18:25:16 -0700518 if chrome_version_atom:
519 if options.boards:
David James96c2c992015-07-14 10:21:50 -0700520 cros_mark_as_stable.CleanStalePackages(options.srcroot,
521 options.boards.split(':'),
Yu-Ju Hong078c9ec2014-08-06 18:25:16 -0700522 [chrome_version_atom])
David Zeuthen665d3132014-08-25 15:27:02 -0400523
524 # If we did rev Chrome, now is a good time to uprev other packages.
525 for other_ebuild in constants.OTHER_CHROME_PACKAGES:
526 other_ebuild_name = os.path.basename(other_ebuild)
527 other_package_dir = os.path.join(overlay_dir, other_ebuild)
528 (other_unstable_ebuild, other_stable_ebuilds) = FindChromeCandidates(
529 other_package_dir)
530 other_stable_candidate = FindChromeUprevCandidate(other_stable_ebuilds,
531 chrome_rev,
532 sticky_branch)
533 revved_atom = MarkChromeEBuildAsStable(other_stable_candidate,
534 other_unstable_ebuild,
535 other_ebuild_name,
536 chrome_rev, version_to_uprev,
537 commit_to_use, other_package_dir)
538 if revved_atom and options.boards:
David James96c2c992015-07-14 10:21:50 -0700539 cros_mark_as_stable.CleanStalePackages(options.srcroot,
540 options.boards.split(':'),
David Zeuthen665d3132014-08-25 15:27:02 -0400541 [revved_atom])
542
543 # Explicit print to communicate to caller.
544 if chrome_version_atom:
Mike Frysinger383367e2014-09-16 15:06:17 -0400545 print('CHROME_VERSION_ATOM=%s' % chrome_version_atom)