blob: 89ada03fbd36816cf14c0cddbd8ece4d775d5d01 [file] [log] [blame]
Alex Kleineb77ffa2019-05-28 14:47:44 -06001# -*- coding: utf-8 -*-
2# Copyright 2019 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""Package related functionality."""
7
8from __future__ import print_function
9
Mike Frysingeref94e4c2020-02-10 23:59:54 -050010import sys
11
Alex Klein076841b2019-08-29 15:19:39 -060012from chromite.api import faux
David Burger1e0fe232019-07-01 14:52:07 -060013from chromite.api import validate
Alex Kleineb77ffa2019-05-28 14:47:44 -060014from chromite.api.controller import controller_util
15from chromite.api.gen.chromite.api import binhost_pb2
David Burger1e0fe232019-07-01 14:52:07 -060016from chromite.api.gen.chromiumos import common_pb2
Alex Kleineb77ffa2019-05-28 14:47:44 -060017from chromite.lib import constants
18from chromite.lib import cros_build_lib
Alex Klein445ae3c2020-01-08 16:40:43 -070019from chromite.lib import cros_logging as logging
Alex Klein87531182019-08-12 15:23:37 -060020from chromite.lib.uprev_lib import GitRef
Alex Kleineb77ffa2019-05-28 14:47:44 -060021from chromite.service import packages
22
23
Mike Frysingeref94e4c2020-02-10 23:59:54 -050024assert sys.version_info >= (3, 6), 'This module requires Python 3.6+'
25
26
Alex Kleineb77ffa2019-05-28 14:47:44 -060027_OVERLAY_TYPE_TO_NAME = {
28 binhost_pb2.OVERLAYTYPE_PUBLIC: constants.PUBLIC_OVERLAYS,
29 binhost_pb2.OVERLAYTYPE_PRIVATE: constants.PRIVATE_OVERLAYS,
30 binhost_pb2.OVERLAYTYPE_BOTH: constants.BOTH_OVERLAYS,
31}
32
Michael Mortensen2677bf62019-10-29 08:31:25 -060033def _UprevResponse(_input_proto, output_proto, _config):
34 """Add fake paths to a successful uprev response."""
35 output_proto.modified_ebuilds.add().path = '/fake/path1'
36 output_proto.modified_ebuilds.add().path = '/fake/path2'
Alex Kleineb77ffa2019-05-28 14:47:44 -060037
Michael Mortensen2677bf62019-10-29 08:31:25 -060038@faux.success(_UprevResponse)
39@faux.empty_error
Alex Klein231d2da2019-07-22 16:44:45 -060040@validate.require('overlay_type')
41@validate.is_in('overlay_type', _OVERLAY_TYPE_TO_NAME)
42@validate.validation_complete
43def Uprev(input_proto, output_proto, _config):
Alex Kleineb77ffa2019-05-28 14:47:44 -060044 """Uprev all cros workon ebuilds that have changes."""
Alex Klein26e472b2020-03-10 14:35:01 -060045 build_targets = controller_util.ParseBuildTargets(input_proto.build_targets)
Alex Kleineb77ffa2019-05-28 14:47:44 -060046 overlay_type = _OVERLAY_TYPE_TO_NAME[input_proto.overlay_type]
47 chroot = controller_util.ParseChroot(input_proto.chroot)
48 output_dir = input_proto.output_dir or None
49
50 try:
Alex Klein5dd6b1e2019-07-31 15:45:24 -060051 uprevved = packages.uprev_build_targets(build_targets, overlay_type, chroot,
52 output_dir)
Alex Kleineb77ffa2019-05-28 14:47:44 -060053 except packages.Error as e:
54 # Handle module errors nicely, let everything else bubble up.
Mike Frysinger6b5c3cd2019-08-27 16:51:00 -040055 cros_build_lib.Die(e)
David Burger1e0fe232019-07-01 14:52:07 -060056
Alex Klein5dd6b1e2019-07-31 15:45:24 -060057 for path in uprevved:
58 output_proto.modified_ebuilds.add().path = path
59
Alex Klein231d2da2019-07-22 16:44:45 -060060
Michael Mortensen2677bf62019-10-29 08:31:25 -060061def _UprevVersionedPackageResponse(_input_proto, output_proto, _config):
62 """Add fake paths to a successful uprev versioned package response."""
63 uprev_response = output_proto.responses.add()
64 uprev_response.modified_ebuilds.add().path = '/uprev/response/path'
65
66
67@faux.success(_UprevVersionedPackageResponse)
68@faux.empty_error
Alex Klein87531182019-08-12 15:23:37 -060069@validate.require('versions')
70@validate.require('package_info.package_name', 'package_info.category')
Alex Klein231d2da2019-07-22 16:44:45 -060071@validate.validation_complete
Alex Klein87531182019-08-12 15:23:37 -060072def UprevVersionedPackage(input_proto, output_proto, _config):
Evan Hernandez38555d42019-08-05 15:11:54 -060073 """Uprev a versioned package.
74
75 See go/pupr-generator for details about this endpoint.
76 """
Alex Klein87531182019-08-12 15:23:37 -060077 chroot = controller_util.ParseChroot(input_proto.chroot)
78 build_targets = controller_util.ParseBuildTargets(input_proto.build_targets)
79 package = controller_util.PackageInfoToCPV(input_proto.package_info)
80 refs = []
81 for ref in input_proto.versions:
82 refs.append(GitRef(path=ref.repository, ref=ref.ref, revision=ref.revision))
83
84 try:
Alex Klein34afcbc2019-08-22 16:14:31 -060085 result = packages.uprev_versioned_package(package, build_targets, refs,
86 chroot)
Alex Klein87531182019-08-12 15:23:37 -060087 except packages.Error as e:
88 # Handle module errors nicely, let everything else bubble up.
Mike Frysinger6b5c3cd2019-08-27 16:51:00 -040089 cros_build_lib.Die(e)
Alex Klein87531182019-08-12 15:23:37 -060090
Alex Klein34afcbc2019-08-22 16:14:31 -060091 if not result.uprevved:
92 # No uprevs executed, skip the output population.
93 return
94
Yaakov Shaul730814a2019-09-10 13:58:25 -060095 for modified in result.modified:
96 uprev_response = output_proto.responses.add()
97 uprev_response.version = modified.new_version
98 for path in modified.files:
99 uprev_response.modified_ebuilds.add().path = path
100
Alex Klein87531182019-08-12 15:23:37 -0600101
Michael Mortensen2677bf62019-10-29 08:31:25 -0600102def _GetBestVisibleResponse(_input_proto, output_proto, _config):
103 """Add fake paths to a successful GetBestVisible response."""
104 package_info = common_pb2.PackageInfo(
105 category='category',
106 package_name='name',
107 version='1.01',
108 )
109 output_proto.package_info.CopyFrom(package_info)
110
111
112@faux.success(_GetBestVisibleResponse)
113@faux.empty_error
David Burger1e0fe232019-07-01 14:52:07 -0600114@validate.require('atom')
Alex Klein231d2da2019-07-22 16:44:45 -0600115@validate.validation_complete
116def GetBestVisible(input_proto, output_proto, _config):
David Burger1e0fe232019-07-01 14:52:07 -0600117 """Returns the best visible PackageInfo for the indicated atom."""
Alex Kleinbbef2b32019-08-27 10:38:50 -0600118 build_target = None
119 if input_proto.build_target.name:
120 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
121
122 cpv = packages.get_best_visible(input_proto.atom, build_target=build_target)
David Burger1e0fe232019-07-01 14:52:07 -0600123 package_info = common_pb2.PackageInfo()
124 controller_util.CPVToPackageInfo(cpv, package_info)
125 output_proto.package_info.CopyFrom(package_info)
Alex Klein551e8052019-08-29 11:23:48 -0600126
127
Michael Mortensen68abdb72019-10-28 09:43:52 -0600128def _ChromeVersionResponse(_input_proto, output_proto, _config):
129 """Add a fake chrome version to a successful response."""
130 output_proto.version = '78.0.3900.0'
131
132
133@faux.success(_ChromeVersionResponse)
134@faux.empty_error
Alex Klein551e8052019-08-29 11:23:48 -0600135@validate.require('build_target.name')
136@validate.validation_complete
137def GetChromeVersion(input_proto, output_proto, _config):
138 """Returns the chrome version."""
139 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
Michael Mortensen9fe740c2019-10-29 14:42:48 -0600140 chrome_version = packages.determine_chrome_version(build_target)
141 if chrome_version:
142 output_proto.version = chrome_version
Alex Kleinda39c6d2019-09-16 14:36:36 -0600143
144
Michael Mortensen2677bf62019-10-29 08:31:25 -0600145def _GetTargetVersionsResponse(_input_proto, output_proto, _config):
146 """Add fake target version fields to a successful response."""
147 output_proto.android_version = '5812377'
148 output_proto.android_branch_version = 'git_nyc-mr1-arc'
149 output_proto.android_target_version = 'cheets'
150 output_proto.chrome_version = '78.0.3900.0'
151 output_proto.platform_version = '12438.0.0'
152 output_proto.milestone_version = '78'
153 output_proto.full_version = 'R78-12438.0.0'
154
155
156@faux.success(_GetTargetVersionsResponse)
157@faux.empty_error
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600158@validate.require('build_target.name')
159@validate.validation_complete
160def GetTargetVersions(input_proto, output_proto, _config):
161 """Returns the target versions."""
162 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
Alex Klein445ae3c2020-01-08 16:40:43 -0700163 # Android version.
Michael Mortensenedf76532019-10-16 14:22:37 -0600164 android_version = packages.determine_android_version([build_target])
Alex Klein445ae3c2020-01-08 16:40:43 -0700165 logging.info('Found android version: %s', android_version)
Michael Mortensenedf76532019-10-16 14:22:37 -0600166 if android_version:
167 output_proto.android_version = android_version
Alex Klein445ae3c2020-01-08 16:40:43 -0700168 # Android branch version.
Michael Mortensenedf76532019-10-16 14:22:37 -0600169 android_branch_version = packages.determine_android_branch(build_target)
Alex Klein445ae3c2020-01-08 16:40:43 -0700170 logging.info('Found android branch version: %s', android_branch_version)
Michael Mortensenedf76532019-10-16 14:22:37 -0600171 if android_branch_version:
172 output_proto.android_branch_version = android_branch_version
Alex Klein445ae3c2020-01-08 16:40:43 -0700173 # Android target version.
Michael Mortensenedf76532019-10-16 14:22:37 -0600174 android_target_version = packages.determine_android_target(build_target)
Alex Klein445ae3c2020-01-08 16:40:43 -0700175 logging.info('Found android target version: %s', android_target_version)
Michael Mortensenedf76532019-10-16 14:22:37 -0600176 if android_target_version:
177 output_proto.android_target_version = android_target_version
Alex Klein445ae3c2020-01-08 16:40:43 -0700178
Michael Mortensen9fe740c2019-10-29 14:42:48 -0600179 # TODO(crbug/1019770): Investigate cases where builds_chrome is true but
180 # chrome_version is None.
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600181 builds_chrome = packages.builds(constants.CHROME_CP, build_target)
182 if builds_chrome:
Alex Klein445ae3c2020-01-08 16:40:43 -0700183 # Chrome version fetch.
Michael Mortensen9fe740c2019-10-29 14:42:48 -0600184 chrome_version = packages.determine_chrome_version(build_target)
Alex Klein445ae3c2020-01-08 16:40:43 -0700185 logging.info('Found chrome version: %s', chrome_version)
Michael Mortensen9fe740c2019-10-29 14:42:48 -0600186 if chrome_version:
187 output_proto.chrome_version = chrome_version
Alex Klein445ae3c2020-01-08 16:40:43 -0700188
189 # The ChromeOS version info.
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600190 output_proto.platform_version = packages.determine_platform_version()
Michael Mortensen009cb662019-10-21 11:38:43 -0600191 output_proto.milestone_version = packages.determine_milestone_version()
192 output_proto.full_version = packages.determine_full_version()
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600193
194
Alex Klein7d66c092020-03-23 15:13:18 -0600195def _HasPrebuiltSuccess(_input_proto, output_proto, _config):
Michael Mortensen68abdb72019-10-28 09:43:52 -0600196 """The mock success case for HasChromePrebuilt."""
197 output_proto.has_prebuilt = True
198
199
Alex Klein7d66c092020-03-23 15:13:18 -0600200@faux.success(_HasPrebuiltSuccess)
Alex Kleinda39c6d2019-09-16 14:36:36 -0600201@faux.empty_error
202@validate.require('build_target.name')
203@validate.validation_complete
204def HasChromePrebuilt(input_proto, output_proto, _config):
205 """Checks if the most recent version of Chrome has a prebuilt."""
206 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
Alex Klein149fd3b2019-12-16 16:01:05 -0700207 useflags = 'chrome_internal' if input_proto.chrome else None
208 exists = packages.has_prebuilt(constants.CHROME_CP, build_target=build_target,
209 useflags=useflags)
Alex Kleinda39c6d2019-09-16 14:36:36 -0600210
211 output_proto.has_prebuilt = exists
Alex Klein73fb6572019-09-30 16:55:23 -0600212
213
Alex Klein7d66c092020-03-23 15:13:18 -0600214@faux.success(_HasPrebuiltSuccess)
215@faux.empty_error
216@validate.require('build_target.name', 'package.category', 'package.name')
217@validate.validation_complete
218def HasPrebuilt(input_proto, output_proto, _config):
219 """Checks if the most recent version of Chrome has a prebuilt."""
220 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
221 package = controller_util.PackageInfoToCPV(input_proto.package_info).cp
222 useflags = 'chrome_internal' if input_proto.chrome else None
223 exists = packages.has_prebuilt(
224 package, build_target=build_target, useflags=useflags)
225
226 output_proto.has_prebuilt = exists
227
228
Alex Klein73fb6572019-09-30 16:55:23 -0600229def _BuildsChromeSuccess(_input_proto, output_proto, _config):
230 """Mock success case for BuildsChrome."""
231 output_proto.builds_chrome = True
232
233
234@faux.success(_BuildsChromeSuccess)
235@faux.empty_error
236@validate.require('build_target.name')
237@validate.validation_complete
238def BuildsChrome(input_proto, output_proto, _config):
239 """Check if the board builds chrome."""
Alex Kleine65131f2019-10-03 10:34:01 -0600240 build_target = controller_util.ParseBuildTarget(input_proto.build_target)
David Burger0f9dd4e2019-10-08 12:33:42 -0600241 cpvs = [controller_util.PackageInfoToCPV(pi) for pi in input_proto.packages]
242 builds_chrome = packages.builds(constants.CHROME_CP, build_target, cpvs)
Alex Kleine65131f2019-10-03 10:34:01 -0600243 output_proto.builds_chrome = builds_chrome