blob: fe1f99b158476d58a9860d0e7aa053d64c6c9498 [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."""
250 patch_version = self.PatchObject(packages_service,
251 'determine_android_version')
252 patch_branch_version = self.PatchObject(packages_service,
253 'determine_android_branch')
254 patch_target_version = self.PatchObject(packages_service,
255 'determine_android_target')
Michael Mortensenc2615b72019-10-15 08:12:24 -0600256 chrome_version = self.PatchObject(packages_service,
257 'determine_chrome_version')
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600258
259 request = self._GetRequest(board='betty')
260 packages_controller.GetTargetVersions(request, self.response,
261 self.validate_only_config)
262 patch_version.assert_not_called()
263 patch_branch_version.assert_not_called()
264 patch_target_version.assert_not_called()
Michael Mortensenc2615b72019-10-15 08:12:24 -0600265 chrome_version.assert_not_called()
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600266
267 def testNoBuildTargetFails(self):
268 """No build target argument should fail."""
269 request = self._GetRequest()
270
271 with self.assertRaises(cros_build_lib.DieSystemExit):
272 packages_controller.GetTargetVersions(request, self.response,
273 self.api_config)
274
Michael Mortensenc2615b72019-10-15 08:12:24 -0600275 def testGetTargetVersions(self):
276 """Verify basic return values."""
277 chrome_version = '76.0.1.2'
278 self.PatchObject(packages_service, 'determine_chrome_version',
279 return_value=chrome_version)
280 android_version = 'android_test_version'
281 self.PatchObject(packages_service, 'determine_android_version',
282 return_value=android_version)
283 android_branch = 'android_test_branch'
284 self.PatchObject(packages_service, 'determine_android_branch',
285 return_value=android_branch)
286 android_target = 'android_test_target'
287 self.PatchObject(packages_service, 'determine_android_target',
288 return_value=android_target)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600289 platform_version = '12345.1.2'
290 self.PatchObject(packages_service, 'determine_platform_version',
291 return_value=platform_version)
Michael Mortensenc2615b72019-10-15 08:12:24 -0600292 request = self._GetRequest(board='betty')
293 packages_controller.GetTargetVersions(request, self.response,
294 self.api_config)
295 self.assertEqual(self.response.android_version, android_version)
296 self.assertEqual(self.response.android_branch_version, android_branch)
297 self.assertEqual(self.response.android_target_version, android_target)
298 self.assertEqual(self.response.chrome_version, chrome_version)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600299 self.assertEqual(self.response.platform_version, platform_version)
Michael Mortensenc2615b72019-10-15 08:12:24 -0600300
Michael Mortensenedf76532019-10-16 14:22:37 -0600301 def testGetTargetVersionNoAndroid(self):
302 """Verify return values on a board that does not have android."""
303 chrome_version = '76.0.1.2'
304 self.PatchObject(packages_service, 'determine_chrome_version',
305 return_value=chrome_version)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600306 platform_version = '12345.1.2'
307 self.PatchObject(packages_service, 'determine_platform_version',
308 return_value=platform_version)
Michael Mortensenedf76532019-10-16 14:22:37 -0600309 self.PatchObject(packages_service, 'determine_android_version',
310 return_value=None)
311 self.PatchObject(packages_service, 'determine_android_branch',
312 return_value=None)
313 self.PatchObject(packages_service, 'determine_android_target',
314 return_value=None)
315 request = self._GetRequest(board='betty')
316 packages_controller.GetTargetVersions(request, self.response,
317 self.api_config)
318 self.assertEqual(self.response.chrome_version, chrome_version)
319 self.assertFalse(self.response.android_version)
320 self.assertFalse(self.response.android_branch_version)
321 self.assertFalse(self.response.android_target_version)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -0600322 self.assertEqual(self.response.platform_version, platform_version)
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600323
Alex Kleinda39c6d2019-09-16 14:36:36 -0600324class HasChromePrebuiltTest(cros_test_lib.MockTestCase, ApiConfigMixin):
325 """HasChromePrebuilt tests."""
326
327 def setUp(self):
328 self.response = packages_pb2.HasChromePrebuiltResponse()
329
330 def _GetRequest(self, board=None):
331 """Helper to build out a request."""
332 request = packages_pb2.HasChromePrebuiltRequest()
333
334 if board:
335 request.build_target.name = board
336
337 return request
338
339 def testValidateOnly(self):
340 """Sanity check that a validate only call does not execute any logic."""
341 patch = self.PatchObject(packages_service, 'has_prebuilt')
342
343 request = self._GetRequest(board='betty')
344 packages_controller.HasChromePrebuilt(request, self.response,
345 self.validate_only_config)
346 patch.assert_not_called()
347
348 def testNoBuildTargetFails(self):
349 """No build target argument should fail."""
350 request = self._GetRequest()
351
352 with self.assertRaises(cros_build_lib.DieSystemExit):
353 packages_controller.HasChromePrebuilt(request, self.response,
354 self.api_config)
Alex Klein73fb6572019-09-30 16:55:23 -0600355
356
357class BuildsChromeTest(cros_test_lib.MockTestCase, ApiConfigMixin):
358 """BuildsChrome tests."""
359
360 def setUp(self):
361 self.response = packages_pb2.BuildsChromeResponse()
362
David Burger0f9dd4e2019-10-08 12:33:42 -0600363 def _GetRequest(self, board=None, packages=None):
Alex Klein73fb6572019-09-30 16:55:23 -0600364 """Helper to build out a request."""
365 request = packages_pb2.BuildsChromeRequest()
366
367 if board:
368 request.build_target.name = board
369
David Burger0f9dd4e2019-10-08 12:33:42 -0600370 if packages:
371 request.packages.extend(packages)
372
Alex Klein73fb6572019-09-30 16:55:23 -0600373 return request
374
375 def testValidateOnly(self):
376 """Sanity check that a validate only call does not execute any logic."""
Alex Kleine65131f2019-10-03 10:34:01 -0600377 patch = self.PatchObject(packages_service, 'builds')
Alex Klein73fb6572019-09-30 16:55:23 -0600378
379 request = self._GetRequest(board='betty')
380 packages_controller.BuildsChrome(request, self.response,
381 self.validate_only_config)
382 patch.assert_not_called()
383
384 def testNoBuildTargetFails(self):
385 """No build target argument should fail."""
386 request = self._GetRequest()
387
388 with self.assertRaises(cros_build_lib.DieSystemExit):
389 packages_controller.BuildsChrome(request, self.response, self.api_config)
Alex Kleine65131f2019-10-03 10:34:01 -0600390
391 def testBuilds(self):
392 """Test successful call handling."""
393 patch = self.PatchObject(packages_service, 'builds', return_value=True)
394
395 request = self._GetRequest(board='foo')
396 packages_controller.BuildsChrome(request, self.response, self.api_config)
397 self.assertTrue(self.response.builds_chrome)
David Burger0f9dd4e2019-10-08 12:33:42 -0600398 patch.assert_called_once_with(constants.CHROME_CP, BuildTarget('foo'), [])
399
400 def testBuildsChromeWithPackages(self):
401 """Test successful call with packages handling."""
402 patch = self.PatchObject(packages_service, 'builds', return_value=True)
403
404 package = common_pb2.PackageInfo(
405 category='category',
406 package_name='name',
407 version='1.01',
408 )
409 request = self._GetRequest(board='foo', packages=[package])
410 packages_controller.BuildsChrome(request, self.response, self.api_config)
411 self.assertTrue(self.response.builds_chrome)
412 patch.assert_called_once_with(constants.CHROME_CP, BuildTarget('foo'),
413 [controller_util.PackageInfoToCPV(package)])