blob: 1a6504e78ab895025619a7afffcc6e89f48b277b [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"""packages controller unit tests."""
7
8from __future__ import print_function
9
10import mock
11
Alex Kleinda39c6d2019-09-16 14:36:36 -060012from chromite.api.api_config import ApiConfigMixin
David Burger0f9dd4e2019-10-08 12:33:42 -060013from chromite.api.controller import controller_util
Alex Kleineb77ffa2019-05-28 14:47:44 -060014from chromite.api.controller import packages as packages_controller
David Burger0f9dd4e2019-10-08 12:33:42 -060015from chromite.api.gen.chromiumos import common_pb2
Alex Kleineb77ffa2019-05-28 14:47:44 -060016from chromite.api.gen.chromite.api import binhost_pb2
17from chromite.api.gen.chromite.api import packages_pb2
18from chromite.lib import constants
19from chromite.lib import cros_build_lib
20from chromite.lib import cros_test_lib
David Burger1e0fe232019-07-01 14:52:07 -060021from chromite.lib import portage_util
Alex Kleine65131f2019-10-03 10:34:01 -060022from chromite.lib.build_target_util import BuildTarget
Alex Kleineb77ffa2019-05-28 14:47:44 -060023from chromite.service import packages as packages_service
24
25
Alex Kleinda39c6d2019-09-16 14:36:36 -060026class UprevTest(cros_test_lib.MockTestCase, ApiConfigMixin):
Alex Kleineb77ffa2019-05-28 14:47:44 -060027 """Uprev tests."""
28
29 _PUBLIC = binhost_pb2.OVERLAYTYPE_PUBLIC
30 _PRIVATE = binhost_pb2.OVERLAYTYPE_PRIVATE
31 _BOTH = binhost_pb2.OVERLAYTYPE_BOTH
32 _NONE = binhost_pb2.OVERLAYTYPE_NONE
33
34 def setUp(self):
35 self.uprev_patch = self.PatchObject(packages_service, 'uprev_build_targets')
Alex Klein231d2da2019-07-22 16:44:45 -060036 self.response = packages_pb2.UprevPackagesResponse()
Alex Kleineb77ffa2019-05-28 14:47:44 -060037
38 def _GetRequest(self, targets=None, overlay_type=None, output_dir=None):
39 return packages_pb2.UprevPackagesRequest(
40 build_targets=[{'name': name} for name in targets or []],
41 overlay_type=overlay_type,
42 output_dir=output_dir,
43 )
44
Alex Klein231d2da2019-07-22 16:44:45 -060045 def testValidateOnly(self):
46 """Sanity check that a validate only call does not execute any logic."""
47 patch = self.PatchObject(packages_service, 'uprev_build_targets')
48
49 targets = ['foo', 'bar']
50 request = self._GetRequest(targets=targets, overlay_type=self._BOTH)
51 packages_controller.Uprev(request, self.response, self.validate_only_config)
52 patch.assert_not_called()
Alex Kleineb77ffa2019-05-28 14:47:44 -060053
54 def testNoOverlayTypeFails(self):
55 """No overlay type provided should fail."""
56 request = self._GetRequest(targets=['foo'])
Alex Kleineb77ffa2019-05-28 14:47:44 -060057
58 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -060059 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060060
61 def testOverlayTypeNoneFails(self):
62 """Overlay type none means nothing here and should fail."""
63 request = self._GetRequest(targets=['foo'], overlay_type=self._NONE)
Alex Kleineb77ffa2019-05-28 14:47:44 -060064
65 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -060066 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060067
68 def testSuccess(self):
69 """Test overall successful argument handling."""
70 targets = ['foo', 'bar']
71 output_dir = '/tmp/uprev_output_dir'
Alex Klein5dd6b1e2019-07-31 15:45:24 -060072 changed = ['/ebuild-1.0-r1.ebuild', '/ebuild-1.0-r2.ebuild']
Alex Kleineb77ffa2019-05-28 14:47:44 -060073 expected_type = constants.BOTH_OVERLAYS
74 request = self._GetRequest(targets=targets, overlay_type=self._BOTH,
75 output_dir=output_dir)
Alex Klein5dd6b1e2019-07-31 15:45:24 -060076 uprev_patch = self.PatchObject(packages_service, 'uprev_build_targets',
77 return_value=changed)
Alex Kleineb77ffa2019-05-28 14:47:44 -060078
Alex Klein231d2da2019-07-22 16:44:45 -060079 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060080
81 # Make sure the type is right, verify build targets after.
82 uprev_patch.assert_called_once_with(mock.ANY, expected_type, mock.ANY,
83 output_dir)
84 # First argument (build targets) of the first (only) call.
85 call_targets = uprev_patch.call_args[0][0]
Mike Frysinger678735c2019-09-28 18:23:28 -040086 self.assertCountEqual(targets, [t.name for t in call_targets])
David Burger1e0fe232019-07-01 14:52:07 -060087
Alex Klein231d2da2019-07-22 16:44:45 -060088 for ebuild in self.response.modified_ebuilds:
Alex Klein5dd6b1e2019-07-31 15:45:24 -060089 self.assertIn(ebuild.path, changed)
90 changed.remove(ebuild.path)
91 self.assertFalse(changed)
92
David Burger1e0fe232019-07-01 14:52:07 -060093
Alex Kleinda39c6d2019-09-16 14:36:36 -060094class UprevVersionedPackageTest(cros_test_lib.MockTestCase, ApiConfigMixin):
Alex Klein87531182019-08-12 15:23:37 -060095 """UprevVersionedPackage tests."""
96
97 def setUp(self):
Yaakov Shaul730814a2019-09-10 13:58:25 -060098 self.response = packages_pb2.UprevVersionedPackageResponse()
Alex Klein87531182019-08-12 15:23:37 -060099
100 def _addVersion(self, request, version):
101 """Helper method to add a full version message to the request."""
102 ref = request.versions.add()
103 ref.repository = '/some/path'
Alex Klein34afcbc2019-08-22 16:14:31 -0600104 ref.ref = 'refs/tags/%s' % version
Alex Klein87531182019-08-12 15:23:37 -0600105 ref.revision = 'abc123'
106
107 def testValidateOnly(self):
108 """Sanity check validate only calls are working properly."""
109 service = self.PatchObject(packages_service, 'uprev_versioned_package')
110
111 request = packages_pb2.UprevVersionedPackageRequest()
112 self._addVersion(request, '1.2.3.4')
113 request.package_info.category = 'chromeos-base'
114 request.package_info.package_name = 'chromeos-chrome'
115
116 packages_controller.UprevVersionedPackage(request, self.response,
117 self.validate_only_config)
118
119 service.assert_not_called()
120
121 def testNoVersions(self):
122 """Test no versions provided."""
123 request = packages_pb2.UprevVersionedPackageRequest()
124 request.package_info.category = 'chromeos-base'
125 request.package_info.package_name = 'chromeos-chrome'
126
127 with self.assertRaises(cros_build_lib.DieSystemExit):
128 packages_controller.UprevVersionedPackage(request, self.response,
129 self.api_config)
130
131 def testNoPackageName(self):
132 """Test no package name provided."""
133 request = packages_pb2.UprevVersionedPackageRequest()
134 self._addVersion(request, '1.2.3.4')
135 request.package_info.category = 'chromeos-base'
136
137 with self.assertRaises(cros_build_lib.DieSystemExit):
138 packages_controller.UprevVersionedPackage(request, self.response,
139 self.api_config)
140
141 def testNoCategory(self):
142 """Test no package category provided."""
143 request = packages_pb2.UprevVersionedPackageRequest()
144 self._addVersion(request, '1.2.3.4')
145 request.package_info.package_name = 'chromeos-chrome'
146
147 with self.assertRaises(cros_build_lib.DieSystemExit):
148 packages_controller.UprevVersionedPackage(request, self.response,
149 self.api_config)
150
151 def testOutputHandling(self):
152 """Test the modified files are getting correctly added to the output."""
Alex Klein34afcbc2019-08-22 16:14:31 -0600153 version = '1.2.3.4'
Yaakov Shaul730814a2019-09-10 13:58:25 -0600154 result = packages_service.UprevVersionedPackageResult().add_result(
Alex Klein34afcbc2019-08-22 16:14:31 -0600155 version, ['/file/one', '/file/two'])
Yaakov Shaul730814a2019-09-10 13:58:25 -0600156
Alex Klein34afcbc2019-08-22 16:14:31 -0600157 self.PatchObject(
158 packages_service, 'uprev_versioned_package', return_value=result)
Alex Klein87531182019-08-12 15:23:37 -0600159
160 request = packages_pb2.UprevVersionedPackageRequest()
Alex Klein34afcbc2019-08-22 16:14:31 -0600161 self._addVersion(request, version)
Alex Klein87531182019-08-12 15:23:37 -0600162 request.package_info.category = 'chromeos-base'
163 request.package_info.package_name = 'chromeos-chrome'
164
165 packages_controller.UprevVersionedPackage(request, self.response,
166 self.api_config)
167
Yaakov Shaul730814a2019-09-10 13:58:25 -0600168 for idx, uprev_response in enumerate(self.response.responses):
169 self.assertEqual(result.modified[idx].new_version, uprev_response.version)
Mike Frysinger678735c2019-09-28 18:23:28 -0400170 self.assertCountEqual(
Yaakov Shaul730814a2019-09-10 13:58:25 -0600171 result.modified[idx].files,
172 [ebuild.path for ebuild in uprev_response.modified_ebuilds])
Alex Klein87531182019-08-12 15:23:37 -0600173
174
Alex Kleinda39c6d2019-09-16 14:36:36 -0600175class GetBestVisibleTest(cros_test_lib.MockTestCase, ApiConfigMixin):
David Burger1e0fe232019-07-01 14:52:07 -0600176 """GetBestVisible tests."""
177
Alex Klein231d2da2019-07-22 16:44:45 -0600178 def setUp(self):
179 self.response = packages_pb2.GetBestVisibleResponse()
180
David Burger1e0fe232019-07-01 14:52:07 -0600181 def _GetRequest(self, atom=None):
182 return packages_pb2.GetBestVisibleRequest(
183 atom=atom,
184 )
185
David Burger1e0fe232019-07-01 14:52:07 -0600186 def _MakeCpv(self, category, package, version):
187 unused = {
188 'cp': None,
189 'cpv': None,
190 'cpf': None,
191 'pv': None,
192 'version_no_rev': None,
193 'rev': None,
194 }
195 return portage_util.CPV(
196 category=category,
197 package=package,
198 version=version,
199 **unused
200 )
201
Alex Klein231d2da2019-07-22 16:44:45 -0600202 def testValidateOnly(self):
203 """Sanity check that a validate only call does not execute any logic."""
204 patch = self.PatchObject(packages_service, 'get_best_visible')
205
206 request = self._GetRequest(atom='chromeos-chrome')
207 packages_controller.GetBestVisible(request, self.response,
208 self.validate_only_config)
209 patch.assert_not_called()
210
David Burger1e0fe232019-07-01 14:52:07 -0600211 def testNoAtomFails(self):
212 """No atom provided should fail."""
213 request = self._GetRequest()
David Burger1e0fe232019-07-01 14:52:07 -0600214 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -0600215 packages_controller.GetBestVisible(request, self.response,
216 self.api_config)
David Burger1e0fe232019-07-01 14:52:07 -0600217
218 def testSuccess(self):
219 """Test overall success, argument handling, result forwarding."""
220 cpv = self._MakeCpv('category', 'package', 'version')
221 self.PatchObject(packages_service, 'get_best_visible', return_value=cpv)
222
223 request = self._GetRequest(atom='chromeos-chrome')
David Burger1e0fe232019-07-01 14:52:07 -0600224
Alex Klein231d2da2019-07-22 16:44:45 -0600225 packages_controller.GetBestVisible(request, self.response, self.api_config)
David Burger1e0fe232019-07-01 14:52:07 -0600226
Alex Klein231d2da2019-07-22 16:44:45 -0600227 package_info = self.response.package_info
David Burger1e0fe232019-07-01 14:52:07 -0600228 self.assertEqual(package_info.category, cpv.category)
229 self.assertEqual(package_info.package_name, cpv.package)
230 self.assertEqual(package_info.version, cpv.version)
Alex Kleinda39c6d2019-09-16 14:36:36 -0600231
232
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600233class GetTargetVersionsTest(cros_test_lib.MockTestCase, ApiConfigMixin):
234 """GetTargetVersions tests."""
235
236 def setUp(self):
237 self.response = packages_pb2.GetTargetVersionsResponse()
238
239 def _GetRequest(self, board=None):
240 """Helper to build out a request."""
241 request = packages_pb2.GetTargetVersionsRequest()
242
243 if board:
244 request.build_target.name = board
245
246 return request
247
248 def testValidateOnly(self):
249 """Sanity check that a validate only call does not execute any logic."""
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600250 builds_chrome = self.PatchObject(
251 packages_service, 'builds', return_value=True)
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600252 patch_version = self.PatchObject(packages_service,
253 'determine_android_version')
254 patch_branch_version = self.PatchObject(packages_service,
255 'determine_android_branch')
256 patch_target_version = self.PatchObject(packages_service,
257 'determine_android_target')
Michael Mortensenc2615b72019-10-15 08:12:24 -0600258 chrome_version = self.PatchObject(packages_service,
259 'determine_chrome_version')
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600260
261 request = self._GetRequest(board='betty')
262 packages_controller.GetTargetVersions(request, self.response,
263 self.validate_only_config)
264 patch_version.assert_not_called()
265 patch_branch_version.assert_not_called()
266 patch_target_version.assert_not_called()
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600267 builds_chrome.assert_not_called()
Michael Mortensenc2615b72019-10-15 08:12:24 -0600268 chrome_version.assert_not_called()
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600269
270 def testNoBuildTargetFails(self):
271 """No build target argument should fail."""
272 request = self._GetRequest()
273
274 with self.assertRaises(cros_build_lib.DieSystemExit):
275 packages_controller.GetTargetVersions(request, self.response,
276 self.api_config)
277
Michael Mortensenc2615b72019-10-15 08:12:24 -0600278 def testGetTargetVersions(self):
279 """Verify basic return values."""
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600280 # Mock that chrome is built and set the chrome_version.
281 self.PatchObject(packages_service, 'builds', return_value=True)
Michael Mortensenc2615b72019-10-15 08:12:24 -0600282 chrome_version = '76.0.1.2'
283 self.PatchObject(packages_service, 'determine_chrome_version',
284 return_value=chrome_version)
285 android_version = 'android_test_version'
286 self.PatchObject(packages_service, 'determine_android_version',
287 return_value=android_version)
288 android_branch = 'android_test_branch'
289 self.PatchObject(packages_service, 'determine_android_branch',
290 return_value=android_branch)
291 android_target = 'android_test_target'
292 self.PatchObject(packages_service, 'determine_android_target',
293 return_value=android_target)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600294 platform_version = '12345.1.2'
295 self.PatchObject(packages_service, 'determine_platform_version',
296 return_value=platform_version)
Michael Mortensenc2615b72019-10-15 08:12:24 -0600297 request = self._GetRequest(board='betty')
298 packages_controller.GetTargetVersions(request, self.response,
299 self.api_config)
300 self.assertEqual(self.response.android_version, android_version)
301 self.assertEqual(self.response.android_branch_version, android_branch)
302 self.assertEqual(self.response.android_target_version, android_target)
303 self.assertEqual(self.response.chrome_version, chrome_version)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600304 self.assertEqual(self.response.platform_version, platform_version)
Michael Mortensenc2615b72019-10-15 08:12:24 -0600305
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600306 def testGetTargetVersionNoAndroidNoChrome(self):
Michael Mortensenedf76532019-10-16 14:22:37 -0600307 """Verify return values on a board that does not have android."""
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600308 platform_version = '12345.1.2'
309 self.PatchObject(packages_service, 'determine_platform_version',
310 return_value=platform_version)
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600311 self.PatchObject(packages_service, 'builds', return_value=False)
Michael Mortensenedf76532019-10-16 14:22:37 -0600312 self.PatchObject(packages_service, 'determine_android_version',
313 return_value=None)
314 self.PatchObject(packages_service, 'determine_android_branch',
315 return_value=None)
316 self.PatchObject(packages_service, 'determine_android_target',
317 return_value=None)
318 request = self._GetRequest(board='betty')
319 packages_controller.GetTargetVersions(request, self.response,
320 self.api_config)
Michael Mortensen1d2ab0d2019-10-17 13:19:25 -0600321 self.assertFalse(self.response.chrome_version)
Michael Mortensenedf76532019-10-16 14:22:37 -0600322 self.assertFalse(self.response.android_version)
323 self.assertFalse(self.response.android_branch_version)
324 self.assertFalse(self.response.android_target_version)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600325 self.assertEqual(self.response.platform_version, platform_version)
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600326
Alex Kleinda39c6d2019-09-16 14:36:36 -0600327class HasChromePrebuiltTest(cros_test_lib.MockTestCase, ApiConfigMixin):
328 """HasChromePrebuilt tests."""
329
330 def setUp(self):
331 self.response = packages_pb2.HasChromePrebuiltResponse()
332
333 def _GetRequest(self, board=None):
334 """Helper to build out a request."""
335 request = packages_pb2.HasChromePrebuiltRequest()
336
337 if board:
338 request.build_target.name = board
339
340 return request
341
342 def testValidateOnly(self):
343 """Sanity check that a validate only call does not execute any logic."""
344 patch = self.PatchObject(packages_service, 'has_prebuilt')
345
346 request = self._GetRequest(board='betty')
347 packages_controller.HasChromePrebuilt(request, self.response,
348 self.validate_only_config)
349 patch.assert_not_called()
350
351 def testNoBuildTargetFails(self):
352 """No build target argument should fail."""
353 request = self._GetRequest()
354
355 with self.assertRaises(cros_build_lib.DieSystemExit):
356 packages_controller.HasChromePrebuilt(request, self.response,
357 self.api_config)
Alex Klein73fb6572019-09-30 16:55:23 -0600358
359
360class BuildsChromeTest(cros_test_lib.MockTestCase, ApiConfigMixin):
361 """BuildsChrome tests."""
362
363 def setUp(self):
364 self.response = packages_pb2.BuildsChromeResponse()
365
David Burger0f9dd4e2019-10-08 12:33:42 -0600366 def _GetRequest(self, board=None, packages=None):
Alex Klein73fb6572019-09-30 16:55:23 -0600367 """Helper to build out a request."""
368 request = packages_pb2.BuildsChromeRequest()
369
370 if board:
371 request.build_target.name = board
372
David Burger0f9dd4e2019-10-08 12:33:42 -0600373 if packages:
374 request.packages.extend(packages)
375
Alex Klein73fb6572019-09-30 16:55:23 -0600376 return request
377
378 def testValidateOnly(self):
379 """Sanity check that a validate only call does not execute any logic."""
Alex Kleine65131f2019-10-03 10:34:01 -0600380 patch = self.PatchObject(packages_service, 'builds')
Alex Klein73fb6572019-09-30 16:55:23 -0600381
382 request = self._GetRequest(board='betty')
383 packages_controller.BuildsChrome(request, self.response,
384 self.validate_only_config)
385 patch.assert_not_called()
386
387 def testNoBuildTargetFails(self):
388 """No build target argument should fail."""
389 request = self._GetRequest()
390
391 with self.assertRaises(cros_build_lib.DieSystemExit):
392 packages_controller.BuildsChrome(request, self.response, self.api_config)
Alex Kleine65131f2019-10-03 10:34:01 -0600393
394 def testBuilds(self):
395 """Test successful call handling."""
396 patch = self.PatchObject(packages_service, 'builds', return_value=True)
397
398 request = self._GetRequest(board='foo')
399 packages_controller.BuildsChrome(request, self.response, self.api_config)
400 self.assertTrue(self.response.builds_chrome)
David Burger0f9dd4e2019-10-08 12:33:42 -0600401 patch.assert_called_once_with(constants.CHROME_CP, BuildTarget('foo'), [])
402
403 def testBuildsChromeWithPackages(self):
404 """Test successful call with packages handling."""
405 patch = self.PatchObject(packages_service, 'builds', return_value=True)
406
407 package = common_pb2.PackageInfo(
408 category='category',
409 package_name='name',
410 version='1.01',
411 )
412 request = self._GetRequest(board='foo', packages=[package])
413 packages_controller.BuildsChrome(request, self.response, self.api_config)
414 self.assertTrue(self.response.builds_chrome)
415 patch.assert_called_once_with(constants.CHROME_CP, BuildTarget('foo'),
416 [controller_util.PackageInfoToCPV(package)])