blob: 41cf0f0a644102b92392bd2049c839adaed9652d [file] [log] [blame]
Mike Frysingerf1ba7ad2022-09-12 05:42:57 -04001# Copyright 2019 The ChromiumOS Authors
Alex Kleineb77ffa2019-05-28 14:47:44 -06002# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5"""Packages service tests."""
6
Madeleine Hardt8ae7f102022-03-24 20:26:11 +00007import io
Andrew Lamb2bde9e42019-11-04 13:24:09 -07008import json
9import os
Michael Mortensen009cb662019-10-21 11:38:43 -060010import re
Madeleine Hardt8ae7f102022-03-24 20:26:11 +000011from unittest import mock
Michael Mortensen009cb662019-10-21 11:38:43 -060012
Mike Frysinger2c024062021-05-22 15:43:22 -040013from chromite.third_party.google.protobuf import json_format
14from chromite.third_party.google.protobuf.field_mask_pb2 import FieldMask
Mike Frysinger68796b52019-08-25 00:04:27 -040015import pytest
Andrew Lamb2bde9e42019-11-04 13:24:09 -070016
Chris McDonaldea0312c2020-05-04 23:33:15 -060017import chromite as cr
Andrew Lamb2bde9e42019-11-04 13:24:09 -070018from chromite.api.gen.config.replication_config_pb2 import (
Mike Frysinger68796b52019-08-25 00:04:27 -040019 FILE_TYPE_JSON,
20 FileReplicationRule,
21 REPLICATION_TYPE_FILTER,
22 ReplicationConfig,
23)
Alex Klein2960c752020-03-09 13:43:38 -060024from chromite.lib import build_target_lib
Ram Chandrasekar60f69f32022-06-03 22:49:30 +000025from chromite.lib import chromeos_version
Andrew Lamb2bde9e42019-11-04 13:24:09 -070026from chromite.lib import constants
Michael Mortensene0f4b542019-10-24 15:30:23 -060027from chromite.lib import cros_build_lib
Alex Kleineb77ffa2019-05-28 14:47:44 -060028from chromite.lib import cros_test_lib
Alex Klein6becabc2020-09-11 14:03:05 -060029from chromite.lib import dependency_graph
Mike Frysinger68796b52019-08-25 00:04:27 -040030from chromite.lib import depgraph
Michael Mortensenb70e8a82019-10-10 18:43:41 -060031from chromite.lib import osutils
Mike Frysinger88d96362020-02-14 19:05:45 -050032from chromite.lib import partial_mock
Alex Klein87531182019-08-12 15:23:37 -060033from chromite.lib import portage_util
Chris McDonaldea0312c2020-05-04 23:33:15 -060034from chromite.lib import uprev_lib
Alex Klein87531182019-08-12 15:23:37 -060035from chromite.lib.chroot_lib import Chroot
Alex Klein18a60af2020-06-11 12:08:47 -060036from chromite.lib.parser import package_info
Andrew Lamb2bde9e42019-11-04 13:24:09 -070037from chromite.lib.uprev_lib import GitRef
Shao-Chuan Lee05e51142021-11-24 12:27:37 +090038from chromite.service import android
Alex Kleineb77ffa2019-05-28 14:47:44 -060039from chromite.service import packages
40
Mike Frysinger68796b52019-08-25 00:04:27 -040041
Andrew Lamb2bde9e42019-11-04 13:24:09 -070042D = cros_test_lib.Directory
43
Alex Kleineb77ffa2019-05-28 14:47:44 -060044
Alex Klein4de25e82019-08-05 15:58:39 -060045class UprevAndroidTest(cros_test_lib.RunCommandTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -060046 """Uprev android tests."""
Alex Klein4de25e82019-08-05 15:58:39 -060047
Alex Klein1699fab2022-09-08 08:46:06 -060048 def _mock_successful_uprev(self):
49 self.rc.AddCmdResult(
50 partial_mock.In("cros_mark_android_as_stable"),
51 stdout=(
52 '{"revved": true,'
53 ' "android_atom": "android/android-1.0",'
54 ' "modified_files": ["file1", "file2"]}'
55 ),
56 )
Shao-Chuan Lee84bf9a22021-11-19 17:42:11 +090057
Alex Klein1699fab2022-09-08 08:46:06 -060058 def test_success(self):
59 """Test successful run handling."""
60 self._mock_successful_uprev()
61 build_targets = [
62 build_target_lib.BuildTarget(t) for t in ["foo", "bar"]
63 ]
Alex Klein4de25e82019-08-05 15:58:39 -060064
Alex Klein1699fab2022-09-08 08:46:06 -060065 result = packages.uprev_android(
66 "android/package", Chroot(), build_targets=build_targets
67 )
68 self.assertCommandContains(
69 [
70 "cros_mark_android_as_stable",
71 "--android_package=android/package",
72 "--boards=foo:bar",
73 ]
74 )
75 self.assertCommandContains(["emerge-foo"])
76 self.assertCommandContains(["emerge-bar"])
Alex Klein4de25e82019-08-05 15:58:39 -060077
Alex Klein1699fab2022-09-08 08:46:06 -060078 self.assertTrue(result.revved)
79 self.assertEqual(result.android_atom, "android/android-1.0")
80 self.assertListEqual(result.modified_files, ["file1", "file2"])
Shao-Chuan Lee84bf9a22021-11-19 17:42:11 +090081
Alex Klein1699fab2022-09-08 08:46:06 -060082 def test_android_build_branch(self):
83 """Test specifying android_build_branch option."""
84 self._mock_successful_uprev()
Shao-Chuan Leea4b4f302021-05-12 14:40:20 +090085
Alex Klein1699fab2022-09-08 08:46:06 -060086 packages.uprev_android(
87 "android/package",
88 Chroot(),
89 android_build_branch="android-build-branch",
90 )
91 self.assertCommandContains(
92 [
93 "cros_mark_android_as_stable",
94 "--android_package=android/package",
95 "--android_build_branch=android-build-branch",
96 ]
97 )
Shao-Chuan Leea4b4f302021-05-12 14:40:20 +090098
Alex Klein1699fab2022-09-08 08:46:06 -060099 def test_android_version(self):
100 """Test specifying android_version option."""
101 self._mock_successful_uprev()
Shao-Chuan Leea4b4f302021-05-12 14:40:20 +0900102
Alex Klein1699fab2022-09-08 08:46:06 -0600103 packages.uprev_android(
104 "android/package", Chroot(), android_version="7123456"
105 )
106 self.assertCommandContains(
107 [
108 "cros_mark_android_as_stable",
109 "--android_package=android/package",
110 "--force_version=7123456",
111 ]
112 )
Shao-Chuan Leea4b4f302021-05-12 14:40:20 +0900113
Alex Klein1699fab2022-09-08 08:46:06 -0600114 def test_skip_commit(self):
115 """Test specifying skip_commit option."""
116 self._mock_successful_uprev()
Shao-Chuan Lee85ba7ce2021-02-09 13:50:11 +0900117
Alex Klein1699fab2022-09-08 08:46:06 -0600118 packages.uprev_android("android/package", Chroot(), skip_commit=True)
119 self.assertCommandContains(
120 [
121 "cros_mark_android_as_stable",
122 "--android_package=android/package",
123 "--skip_commit",
124 ]
125 )
Shao-Chuan Lee85ba7ce2021-02-09 13:50:11 +0900126
Alex Klein1699fab2022-09-08 08:46:06 -0600127 def test_no_uprev(self):
128 """Test no uprev handling."""
129 self.rc.AddCmdResult(
130 partial_mock.In("cros_mark_android_as_stable"),
131 stdout='{"revved": false}',
132 )
133 build_targets = [
134 build_target_lib.BuildTarget(t) for t in ["foo", "bar"]
135 ]
136 result = packages.uprev_android(
137 "android/package", Chroot(), build_targets=build_targets
138 )
Alex Klein4de25e82019-08-05 15:58:39 -0600139
Alex Klein1699fab2022-09-08 08:46:06 -0600140 self.assertCommandContains(
141 ["cros_mark_android_as_stable", "--boards=foo:bar"]
142 )
143 self.assertCommandContains(["emerge-foo"], expected=False)
144 self.assertCommandContains(["emerge-bar"], expected=False)
Alex Klein4de25e82019-08-05 15:58:39 -0600145
Alex Klein1699fab2022-09-08 08:46:06 -0600146 self.assertFalse(result.revved)
Shao-Chuan Lee84bf9a22021-11-19 17:42:11 +0900147
Alex Klein1699fab2022-09-08 08:46:06 -0600148 def test_ignore_junk_in_stdout(self):
149 """Test when stdout contains junk messages."""
150 self.rc.AddCmdResult(
151 partial_mock.In("cros_mark_android_as_stable"),
152 stdout='foo\nbar\n{"revved": false}\n',
153 )
154 result = packages.uprev_android("android/package", Chroot())
Shao-Chuan Leedea458f2021-11-25 23:46:53 +0900155
Alex Klein1699fab2022-09-08 08:46:06 -0600156 self.assertFalse(result.revved)
Shao-Chuan Leedea458f2021-11-25 23:46:53 +0900157
Alex Klein4de25e82019-08-05 15:58:39 -0600158
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900159class UprevAndroidLKGBTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600160 """Tests for uprevving Android with LKGB."""
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900161
Alex Klein1699fab2022-09-08 08:46:06 -0600162 def test_registered_handlers(self):
163 """Test that each Android package has an uprev handler registered."""
164 mock_handler = self.PatchObject(packages, "uprev_android_lkgb")
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900165
Shao-Chuan Leeca2cbcc2022-11-02 08:28:31 +0900166 for android_package in android.GetAllAndroidPackages():
Alex Klein1699fab2022-09-08 08:46:06 -0600167 cpv = package_info.SplitCPV(
168 "chromeos-base/" + android_package, strict=False
169 )
170 build_targets = [build_target_lib.BuildTarget("foo")]
171 chroot = Chroot()
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900172
Alex Klein1699fab2022-09-08 08:46:06 -0600173 packages.uprev_versioned_package(cpv, build_targets, [], chroot)
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900174
Alex Klein1699fab2022-09-08 08:46:06 -0600175 mock_handler.assert_called_once_with(
176 android_package, build_targets, chroot
177 )
178 mock_handler.reset_mock()
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900179
Alex Klein1699fab2022-09-08 08:46:06 -0600180 def test_success(self):
181 """Test a successful uprev."""
182 self.PatchObject(android, "OVERLAY_DIR", new="overlay-dir")
Shao-Chuan Leee0b9ba92023-01-18 19:35:36 +0900183 self.PatchObject(
184 android, "ReadLKGB", return_value=dict(build_id="android-lkgb")
185 )
Alex Klein1699fab2022-09-08 08:46:06 -0600186 self.PatchObject(
187 packages,
188 "uprev_android",
189 return_value=packages.UprevAndroidResult(
190 revved=True,
191 android_atom="android-atom",
192 modified_files=["file1", "file2"],
193 ),
194 )
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900195
Alex Klein1699fab2022-09-08 08:46:06 -0600196 result = packages.uprev_android_lkgb("android-package", [], Chroot())
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900197
Alex Klein1699fab2022-09-08 08:46:06 -0600198 self.assertListEqual(
199 result.modified,
200 [
201 uprev_lib.UprevVersionedPackageModifications(
202 "android-lkgb",
203 [
204 os.path.join("overlay-dir", "file1"),
205 os.path.join("overlay-dir", "file2"),
206 ],
207 )
208 ],
209 )
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900210
Alex Klein1699fab2022-09-08 08:46:06 -0600211 def test_no_rev(self):
212 """Test when nothing revved."""
Shao-Chuan Leee0b9ba92023-01-18 19:35:36 +0900213 self.PatchObject(
214 android, "ReadLKGB", return_value=dict(build_id="android-lkgb")
215 )
Alex Klein1699fab2022-09-08 08:46:06 -0600216 self.PatchObject(
217 packages,
218 "uprev_android",
219 return_value=packages.UprevAndroidResult(revved=False),
220 )
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900221
Alex Klein1699fab2022-09-08 08:46:06 -0600222 result = packages.uprev_android_lkgb("android-package", [], Chroot())
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900223
Alex Klein1699fab2022-09-08 08:46:06 -0600224 self.assertListEqual(result.modified, [])
Shao-Chuan Lee05e51142021-11-24 12:27:37 +0900225
226
Jeremy Bettisaf96afb2023-01-11 16:09:58 -0700227class UprevECUtilsTest(cros_test_lib.MockTestCase):
228 """Tests for upreving ecutils."""
229
230 def test_success(self):
231 """Test a successful uprev."""
232
233 def fakeRunTasks(func, inputs):
234 results = []
235 for args in inputs:
236 results.append(func(*args))
237 return results
238
239 self.PatchObject(
240 packages.uprev_lib.parallel,
241 "RunTasksInProcessPool",
242 side_effect=fakeRunTasks,
243 )
244 mock_devutils = mock.MagicMock(name="dev-utils")
245 mock_ecutils = mock.MagicMock(name="ec-utils")
246 mock_ecutilstest = mock.MagicMock(name="ec-utils-test")
247 self.PatchObject(
248 packages.uprev_lib.portage_util,
249 "GetOverlayEBuilds",
250 return_value=[
251 mock_devutils,
252 mock_ecutils,
253 mock_ecutilstest,
254 ],
255 )
256 mock_overlay_mgr = mock.MagicMock(name="overlay-manager")
257 mock_overlay_mgr.modified_ebuilds = ["file1", "file2"]
258 self.PatchObject(
259 packages.uprev_lib,
260 "UprevOverlayManager",
261 return_value=mock_overlay_mgr,
262 )
Jeremy Bettis0186d252023-01-19 14:47:46 -0700263
264 for package in [
265 "chromeos-base/ec-devutils",
266 "chromeos-base/ec-utils",
267 "chromeos-base/ec-utils-test",
268 ]:
269 cpv = package_info.SplitCPV(package, strict=False)
270 assert cpv is not None
271 build_targets = [build_target_lib.BuildTarget("foo")]
272 refs = [
273 GitRef(
274 path="/platform/ec",
275 ref="main",
276 revision="123",
277 )
278 ]
279 chroot = Chroot()
280
281 result = packages.uprev_versioned_package(
282 cpv, build_targets, refs, chroot
Jeremy Bettisaf96afb2023-01-11 16:09:58 -0700283 )
Jeremy Bettisaf96afb2023-01-11 16:09:58 -0700284
Jeremy Bettis0186d252023-01-19 14:47:46 -0700285 self.assertEqual(1, len(result.modified))
286 self.assertEqual("123", result.modified[0].new_version)
287 self.assertListEqual(result.modified[0].files, ["file1", "file2"])
Jeremy Bettisaf96afb2023-01-11 16:09:58 -0700288
Jeremy Bettis0186d252023-01-19 14:47:46 -0700289 mock_overlay_mgr.uprev.assert_called_with(
290 package_list=[
291 package,
292 ],
293 force=True,
294 )
Jeremy Bettisaf96afb2023-01-11 16:09:58 -0700295
296
Alex Kleineb77ffa2019-05-28 14:47:44 -0600297class UprevBuildTargetsTest(cros_test_lib.RunCommandTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600298 """uprev_build_targets tests."""
Alex Kleineb77ffa2019-05-28 14:47:44 -0600299
Alex Klein1699fab2022-09-08 08:46:06 -0600300 def test_invalid_type_fails(self):
301 """Test invalid type fails."""
302 with self.assertRaises(AssertionError):
303 packages.uprev_build_targets(
304 [build_target_lib.BuildTarget("foo")], "invalid"
305 )
Alex Kleineb77ffa2019-05-28 14:47:44 -0600306
Alex Klein1699fab2022-09-08 08:46:06 -0600307 def test_none_type_fails(self):
308 """Test None type fails."""
309 with self.assertRaises(AssertionError):
310 packages.uprev_build_targets(
311 [build_target_lib.BuildTarget("foo")], None
312 )
Alex Kleineb77ffa2019-05-28 14:47:44 -0600313
314
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000315class PatchEbuildVarsTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600316 """patch_ebuild_vars test."""
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000317
Alex Klein1699fab2022-09-08 08:46:06 -0600318 def setUp(self):
319 self.mock_input = self.PatchObject(packages.fileinput, "input")
320 self.mock_stdout_write = self.PatchObject(packages.sys.stdout, "write")
321 self.ebuild_path = "/path/to/ebuild"
322 self.old_var_value = "R100-5678.0.123456789"
323 self.new_var_value = "R102-5678.0.234566789"
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000324
Alex Klein1699fab2022-09-08 08:46:06 -0600325 def test_patch_ebuild_vars_var_only(self):
326 """patch_ebuild_vars changes ^var=value$."""
327 ebuild_contents = (
328 "This line does not change.\n"
329 'AFDO_PROFILE_VERSION="{var_value}"\n'
330 "\n"
331 "# The line with AFDO_PROFILE_VERSION is also unchanged."
332 )
333 # Ebuild contains old_var_value.
334 self.mock_input.return_value = io.StringIO(
335 ebuild_contents.format(var_value=self.old_var_value)
336 )
337 expected_calls = []
338 # Expect the line with new_var_value.
339 for line in io.StringIO(
340 ebuild_contents.format(var_value=self.new_var_value)
341 ):
342 expected_calls.append(mock.call(line))
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000343
Alex Klein1699fab2022-09-08 08:46:06 -0600344 packages.patch_ebuild_vars(
345 self.ebuild_path, {"AFDO_PROFILE_VERSION": self.new_var_value}
346 )
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000347
Alex Klein1699fab2022-09-08 08:46:06 -0600348 self.mock_stdout_write.assert_has_calls(expected_calls)
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000349
Alex Klein1699fab2022-09-08 08:46:06 -0600350 def test_patch_ebuild_vars_ignore_export(self):
351 """patch_ebuild_vars changes ^export var=value$ and keeps export."""
352 ebuild_contents = (
353 "This line does not change.\n"
354 'export AFDO_PROFILE_VERSION="{var_value}"\n'
355 "# This line is also unchanged."
356 )
357 # Ebuild contains old_var_value.
358 self.mock_input.return_value = io.StringIO(
359 ebuild_contents.format(var_value=self.old_var_value)
360 )
361 expected_calls = []
362 # Expect the line with new_var_value.
363 for line in io.StringIO(
364 ebuild_contents.format(var_value=self.new_var_value)
365 ):
366 expected_calls.append(mock.call(line))
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000367
Alex Klein1699fab2022-09-08 08:46:06 -0600368 packages.patch_ebuild_vars(
369 self.ebuild_path, {"AFDO_PROFILE_VERSION": self.new_var_value}
370 )
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000371
Alex Klein1699fab2022-09-08 08:46:06 -0600372 self.mock_stdout_write.assert_has_calls(expected_calls)
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000373
Alex Klein1699fab2022-09-08 08:46:06 -0600374 def test_patch_ebuild_vars_partial_match(self):
375 """patch_ebuild_vars ignores ^{prefix}var=value$."""
376 ebuild_contents = (
Alex Kleina53bd282022-09-09 12:42:55 -0600377 'This and the line below do not change.\nNEW_AFDO="{var_value}"'
Alex Klein1699fab2022-09-08 08:46:06 -0600378 )
379 # Ebuild contains old_var_value.
380 self.mock_input.return_value = io.StringIO(
381 ebuild_contents.format(var_value=self.old_var_value)
382 )
383 expected_calls = []
384 # Expect the line with UNCHANGED old_var_value.
385 for line in io.StringIO(
386 ebuild_contents.format(var_value=self.old_var_value)
387 ):
388 expected_calls.append(mock.call(line))
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000389
Alex Kleinfee86da2023-01-20 18:40:06 -0700390 # Note that the var name partially matches the ebuild var and hence it
391 # has to be ignored.
Alex Klein1699fab2022-09-08 08:46:06 -0600392 packages.patch_ebuild_vars(
393 self.ebuild_path, {"AFDO": self.new_var_value}
394 )
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000395
Alex Klein1699fab2022-09-08 08:46:06 -0600396 self.mock_stdout_write.assert_has_calls(expected_calls)
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000397
Alex Klein1699fab2022-09-08 08:46:06 -0600398 def test_patch_ebuild_vars_no_vars(self):
399 """patch_ebuild_vars keeps ebuild intact if there are no vars."""
400 ebuild_contents = (
401 "This line does not change.\n"
402 "The line with AFDO_PROFILE_VERSION is also unchanged."
403 )
404 self.mock_input.return_value = io.StringIO(ebuild_contents)
405 expected_calls = []
406 for line in io.StringIO(ebuild_contents):
407 expected_calls.append(mock.call(line))
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000408
Alex Klein1699fab2022-09-08 08:46:06 -0600409 packages.patch_ebuild_vars(
410 self.ebuild_path, {"AFDO_PROFILE_VERSION": self.new_var_value}
411 )
412
413 self.mock_stdout_write.assert_has_calls(expected_calls)
Madeleine Hardt8ae7f102022-03-24 20:26:11 +0000414
415
Alex Klein87531182019-08-12 15:23:37 -0600416class UprevsVersionedPackageTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600417 """uprevs_versioned_package decorator test."""
Alex Klein87531182019-08-12 15:23:37 -0600418
Alex Klein1699fab2022-09-08 08:46:06 -0600419 @packages.uprevs_versioned_package("category/package")
420 def uprev_category_package(self, *args, **kwargs):
421 """Registered function for testing."""
Alex Klein87531182019-08-12 15:23:37 -0600422
Alex Klein1699fab2022-09-08 08:46:06 -0600423 def test_calls_function(self):
424 """Test calling a registered function."""
425 self.PatchObject(self, "uprev_category_package")
Alex Klein87531182019-08-12 15:23:37 -0600426
Alex Klein1699fab2022-09-08 08:46:06 -0600427 cpv = package_info.SplitCPV("category/package", strict=False)
428 packages.uprev_versioned_package(cpv, [], [], Chroot())
Alex Klein87531182019-08-12 15:23:37 -0600429
Alex Kleinfee86da2023-01-20 18:40:06 -0700430 # TODO(crbug/1065172): Invalid assertion that was previously mocked.
Alex Klein1699fab2022-09-08 08:46:06 -0600431 # patch.assert_called()
Alex Klein87531182019-08-12 15:23:37 -0600432
Alex Klein1699fab2022-09-08 08:46:06 -0600433 def test_unregistered_package(self):
434 """Test calling with an unregistered package."""
435 cpv = package_info.SplitCPV("does-not/exist", strict=False)
Alex Klein87531182019-08-12 15:23:37 -0600436
Alex Klein1699fab2022-09-08 08:46:06 -0600437 with self.assertRaises(packages.UnknownPackageError):
438 packages.uprev_versioned_package(cpv, [], [], Chroot())
Alex Klein87531182019-08-12 15:23:37 -0600439
440
Trent Begin6daa8702020-01-29 14:58:12 -0700441class UprevEbuildFromPinTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600442 """Tests uprev_ebuild_from_pin function"""
Trent Begin315d9d92019-12-03 21:55:53 -0700443
Alex Klein1699fab2022-09-08 08:46:06 -0600444 package = "category/package"
445 version = "1.2.3"
446 new_version = "1.2.4"
447 ebuild_template = "package-%s-r1.ebuild"
448 ebuild = ebuild_template % version
449 unstable_ebuild = "package-9999.ebuild"
450 manifest = "Manifest"
Trent Begin315d9d92019-12-03 21:55:53 -0700451
Alex Klein1699fab2022-09-08 08:46:06 -0600452 def test_uprev_ebuild(self):
453 """Tests uprev of ebuild with version path"""
454 file_layout = (
455 D(self.package, [self.ebuild, self.unstable_ebuild, self.manifest]),
456 )
457 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Trent Begin315d9d92019-12-03 21:55:53 -0700458
Alex Klein1699fab2022-09-08 08:46:06 -0600459 package_path = os.path.join(self.tempdir, self.package)
Trent Begin315d9d92019-12-03 21:55:53 -0700460
Alex Klein1699fab2022-09-08 08:46:06 -0600461 ebuild_path = os.path.join(package_path, self.ebuild)
462 self.WriteTempFile(ebuild_path, 'KEYWORDS="*"\n')
Fergus Dall2209d0b2020-08-06 11:51:43 +1000463
Alex Klein1699fab2022-09-08 08:46:06 -0600464 result = uprev_lib.uprev_ebuild_from_pin(
465 package_path, self.new_version, chroot=Chroot()
466 )
467 self.assertEqual(
468 len(result.modified),
469 1,
470 "unexpected number of results: %s" % len(result.modified),
471 )
Trent Begin315d9d92019-12-03 21:55:53 -0700472
Alex Klein1699fab2022-09-08 08:46:06 -0600473 mod = result.modified[0]
474 self.assertEqual(
475 mod.new_version,
476 self.new_version + "-r1",
477 "unexpected version number: %s" % mod.new_version,
478 )
Trent Begin315d9d92019-12-03 21:55:53 -0700479
Alex Klein1699fab2022-09-08 08:46:06 -0600480 old_ebuild_path = os.path.join(
481 package_path, self.ebuild_template % self.version
482 )
483 new_ebuild_path = os.path.join(
484 package_path, self.ebuild_template % self.new_version
485 )
486 manifest_path = os.path.join(package_path, "Manifest")
Trent Begin2e5344f2020-03-02 10:46:55 -0700487
Alex Klein1699fab2022-09-08 08:46:06 -0600488 expected_modified_files = [
489 old_ebuild_path,
490 new_ebuild_path,
491 manifest_path,
492 ]
493 self.assertCountEqual(mod.files, expected_modified_files)
Trent Begin4a11a632020-02-28 12:59:58 -0700494
Alex Klein1699fab2022-09-08 08:46:06 -0600495 self.assertCommandContains(["ebuild", "manifest"])
Trent Begin6daa8702020-01-29 14:58:12 -0700496
Alex Klein1699fab2022-09-08 08:46:06 -0600497 def test_uprev_ebuild_same_version(self):
Alex Kleinfee86da2023-01-20 18:40:06 -0700498 """Tests uprev of ebuild with version path with unchanged version.
Fergus Dall2209d0b2020-08-06 11:51:43 +1000499
Alex Klein1699fab2022-09-08 08:46:06 -0600500 This should result in bumping the revision number.
501 """
502 file_layout = (
503 D(self.package, [self.ebuild, self.unstable_ebuild, self.manifest]),
504 )
505 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Fergus Dall2209d0b2020-08-06 11:51:43 +1000506
Alex Klein1699fab2022-09-08 08:46:06 -0600507 package_path = os.path.join(self.tempdir, self.package)
Fergus Dall2209d0b2020-08-06 11:51:43 +1000508
Alex Klein1699fab2022-09-08 08:46:06 -0600509 ebuild_path = os.path.join(package_path, self.ebuild)
510 self.WriteTempFile(ebuild_path, 'KEYWORDS="*"\n')
Fergus Dall2209d0b2020-08-06 11:51:43 +1000511
Alex Klein1699fab2022-09-08 08:46:06 -0600512 result = uprev_lib.uprev_ebuild_from_pin(
513 package_path, self.version, chroot=Chroot()
514 )
515 self.assertEqual(
516 len(result.modified),
517 1,
518 "unexpected number of results: %s" % len(result.modified),
519 )
Fergus Dall2209d0b2020-08-06 11:51:43 +1000520
Alex Klein1699fab2022-09-08 08:46:06 -0600521 mod = result.modified[0]
522 self.assertEqual(
523 mod.new_version,
524 self.version + "-r2",
525 "unexpected version number: %s" % mod.new_version,
526 )
Fergus Dall2209d0b2020-08-06 11:51:43 +1000527
Alex Klein1699fab2022-09-08 08:46:06 -0600528 old_ebuild_path = os.path.join(
529 package_path, self.ebuild_template % self.version
530 )
531 new_ebuild_path = os.path.join(
532 package_path, "package-%s-r2.ebuild" % self.version
533 )
534 manifest_path = os.path.join(package_path, "Manifest")
Fergus Dall2209d0b2020-08-06 11:51:43 +1000535
Alex Klein1699fab2022-09-08 08:46:06 -0600536 expected_modified_files = [
537 old_ebuild_path,
538 new_ebuild_path,
539 manifest_path,
540 ]
541 self.assertCountEqual(mod.files, expected_modified_files)
Fergus Dall2209d0b2020-08-06 11:51:43 +1000542
Alex Klein1699fab2022-09-08 08:46:06 -0600543 self.assertCommandContains(["ebuild", "manifest"])
Fergus Dall2209d0b2020-08-06 11:51:43 +1000544
Alex Klein1699fab2022-09-08 08:46:06 -0600545 def test_no_ebuild(self):
546 """Tests assertion is raised if package has no ebuilds"""
547 file_layout = (D(self.package, [self.manifest]),)
548 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Trent Begin315d9d92019-12-03 21:55:53 -0700549
Alex Klein1699fab2022-09-08 08:46:06 -0600550 package_path = os.path.join(self.tempdir, self.package)
Trent Begin315d9d92019-12-03 21:55:53 -0700551
Alex Klein1699fab2022-09-08 08:46:06 -0600552 with self.assertRaises(uprev_lib.EbuildUprevError):
553 uprev_lib.uprev_ebuild_from_pin(
554 package_path, self.new_version, chroot=Chroot()
555 )
Trent Begin315d9d92019-12-03 21:55:53 -0700556
Alex Klein1699fab2022-09-08 08:46:06 -0600557 def test_multiple_stable_ebuilds(self):
558 """Tests assertion is raised if multiple stable ebuilds are present"""
559 file_layout = (
560 D(
561 self.package,
562 [self.ebuild, self.ebuild_template % "1.2.1", self.manifest],
563 ),
564 )
565 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Fergus Dall2209d0b2020-08-06 11:51:43 +1000566
Alex Klein1699fab2022-09-08 08:46:06 -0600567 package_path = os.path.join(self.tempdir, self.package)
Fergus Dall2209d0b2020-08-06 11:51:43 +1000568
Alex Klein1699fab2022-09-08 08:46:06 -0600569 ebuild_path = os.path.join(package_path, self.ebuild)
570 self.WriteTempFile(ebuild_path, 'KEYWORDS="*"\n')
Fergus Dall2209d0b2020-08-06 11:51:43 +1000571
Alex Klein1699fab2022-09-08 08:46:06 -0600572 ebuild_path = os.path.join(package_path, self.ebuild_template % "1.2.1")
573 self.WriteTempFile(ebuild_path, 'KEYWORDS="*"\n')
Fergus Dall2209d0b2020-08-06 11:51:43 +1000574
Alex Klein1699fab2022-09-08 08:46:06 -0600575 with self.assertRaises(uprev_lib.EbuildUprevError):
576 uprev_lib.uprev_ebuild_from_pin(
577 package_path, self.new_version, chroot=Chroot()
578 )
Fergus Dall2209d0b2020-08-06 11:51:43 +1000579
Alex Klein1699fab2022-09-08 08:46:06 -0600580 def test_multiple_unstable_ebuilds(self):
581 """Tests assertion is raised if multiple unstable ebuilds are present"""
582 file_layout = (
583 D(
584 self.package,
585 [self.ebuild, self.ebuild_template % "1.2.1", self.manifest],
586 ),
587 )
588 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Trent Begin315d9d92019-12-03 21:55:53 -0700589
Alex Klein1699fab2022-09-08 08:46:06 -0600590 package_path = os.path.join(self.tempdir, self.package)
Trent Begin315d9d92019-12-03 21:55:53 -0700591
Alex Klein1699fab2022-09-08 08:46:06 -0600592 with self.assertRaises(uprev_lib.EbuildUprevError):
593 uprev_lib.uprev_ebuild_from_pin(
594 package_path, self.new_version, chroot=Chroot()
595 )
Trent Begin315d9d92019-12-03 21:55:53 -0700596
597
Andrew Lamb9563a152019-12-04 11:42:18 -0700598class ReplicatePrivateConfigTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600599 """replicate_private_config tests."""
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700600
Alex Klein1699fab2022-09-08 08:46:06 -0600601 def setUp(self):
602 # Set up fake public and private chromeos-config overlays.
603 private_package_root = (
604 "src/private-overlays/overlay-coral-private/chromeos-base/"
605 "chromeos-config-bsp"
606 )
607 self.public_package_root = (
608 "src/overlays/overlay-coral/chromeos-base/chromeos-config-bsp"
609 )
610 file_layout = (
611 D(
612 os.path.join(private_package_root, "files"),
613 ["build_config.json"],
614 ),
615 D(private_package_root, ["replication_config.jsonpb"]),
616 D(
617 os.path.join(self.public_package_root, "files"),
618 ["build_config.json"],
619 ),
620 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700621
Alex Klein1699fab2022-09-08 08:46:06 -0600622 cros_test_lib.CreateOnDiskHierarchy(self.tempdir, file_layout)
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700623
Alex Klein1699fab2022-09-08 08:46:06 -0600624 # Private config contains 'a' and 'b' fields.
625 self.private_config_path = os.path.join(
626 private_package_root, "files", "build_config.json"
627 )
628 self.WriteTempFile(
629 self.private_config_path,
630 json.dumps({"chromeos": {"configs": [{"a": 3, "b": 2}]}}),
631 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700632
Alex Kleinfee86da2023-01-20 18:40:06 -0700633 # Public config only contains the 'a' field. Note that the value of 'a'
634 # is 1 in the public config; it will get updated to 3 when the private
635 # config is replicated.
Alex Klein1699fab2022-09-08 08:46:06 -0600636 self.public_config_path = os.path.join(
637 self.public_package_root, "files", "build_config.json"
638 )
639 self.WriteTempFile(
640 self.public_config_path,
641 json.dumps({"chromeos": {"configs": [{"a": 1}]}}),
642 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700643
Alex Klein1699fab2022-09-08 08:46:06 -0600644 # Put a ReplicationConfig JSONPB in the private package. Note that it
645 # specifies only the 'a' field is replicated.
646 self.replication_config_path = os.path.join(
647 self.tempdir, private_package_root, "replication_config.jsonpb"
648 )
649 replication_config = ReplicationConfig(
650 file_replication_rules=[
651 FileReplicationRule(
652 source_path=self.private_config_path,
653 destination_path=self.public_config_path,
654 file_type=FILE_TYPE_JSON,
655 replication_type=REPLICATION_TYPE_FILTER,
656 destination_fields=FieldMask(paths=["a"]),
657 )
658 ]
659 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700660
Alex Klein1699fab2022-09-08 08:46:06 -0600661 osutils.WriteFile(
662 self.replication_config_path,
663 json_format.MessageToJson(replication_config),
664 )
665 self.PatchObject(constants, "SOURCE_ROOT", new=self.tempdir)
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700666
Alex Klein1699fab2022-09-08 08:46:06 -0600667 self.rc.SetDefaultCmdResult(side_effect=self._write_generated_c_files)
Andrew Lamb9563a152019-12-04 11:42:18 -0700668
Alex Klein1699fab2022-09-08 08:46:06 -0600669 def _write_generated_c_files(self, *_args, **_kwargs):
670 """Write fake generated C files to the public output dir.
Andrew Lamb9563a152019-12-04 11:42:18 -0700671
Alex Kleinfee86da2023-01-20 18:40:06 -0700672 Note that this function accepts args and kwargs so it can be used as a
673 side effect.
Alex Klein1699fab2022-09-08 08:46:06 -0600674 """
675 output_dir = os.path.join(self.public_package_root, "files")
676 self.WriteTempFile(os.path.join(output_dir, "config.c"), "")
677 self.WriteTempFile(os.path.join(output_dir, "ec_config.c"), "")
678 self.WriteTempFile(os.path.join(output_dir, "ec_config.h"), "")
Andrew Lamb9563a152019-12-04 11:42:18 -0700679
Alex Klein1699fab2022-09-08 08:46:06 -0600680 def _write_incorrect_generated_c_files(self, *_args, **_kwargs):
681 """Similar to _write_generated_c_files, with an expected file missing.
Andrew Lamb9563a152019-12-04 11:42:18 -0700682
Alex Kleinfee86da2023-01-20 18:40:06 -0700683 Note that this function accepts args and kwargs so it can be used as a
684 side effect.
Alex Klein1699fab2022-09-08 08:46:06 -0600685 """
686 output_dir = os.path.join(self.public_package_root, "files")
687 self.WriteTempFile(os.path.join(output_dir, "config.c"), "")
688 self.WriteTempFile(os.path.join(output_dir, "ec_config.c"), "")
Andrew Lamb9563a152019-12-04 11:42:18 -0700689
Alex Klein1699fab2022-09-08 08:46:06 -0600690 def test_replicate_private_config(self):
691 """Basic replication test."""
692 refs = [
693 GitRef(
694 path="/chromeos/overlays/overlay-coral-private",
695 ref="main",
696 revision="123",
697 )
698 ]
699 chroot = Chroot()
700 result = packages.replicate_private_config(
701 _build_targets=None, refs=refs, chroot=chroot
702 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700703
Alex Klein1699fab2022-09-08 08:46:06 -0600704 self.assertCommandContains(
705 [
706 "cros_config_schema",
707 "-m",
708 os.path.join(
709 constants.CHROOT_SOURCE_ROOT, self.public_config_path
710 ),
711 "-g",
712 os.path.join(
713 constants.CHROOT_SOURCE_ROOT,
714 self.public_package_root,
715 "files",
716 ),
717 "-f",
718 '"TRUE"',
719 ],
720 enter_chroot=True,
721 chroot_args=chroot.get_enter_args(),
722 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700723
Alex Klein1699fab2022-09-08 08:46:06 -0600724 self.assertEqual(len(result.modified), 1)
725 # The public build_config.json and generated C files were modified.
726 expected_modified_files = [
727 os.path.join(self.tempdir, self.public_config_path),
728 os.path.join(
729 self.tempdir, self.public_package_root, "files", "config.c"
730 ),
731 os.path.join(
732 self.tempdir, self.public_package_root, "files", "ec_config.c"
733 ),
734 os.path.join(
735 self.tempdir, self.public_package_root, "files", "ec_config.h"
736 ),
737 ]
738 self.assertEqual(result.modified[0].files, expected_modified_files)
739 self.assertEqual(result.modified[0].new_version, "123")
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700740
Alex Kleinfee86da2023-01-20 18:40:06 -0700741 # The update from the private build_config.json was copied to the
742 # public. Note that only the 'a' field is present, as per
743 # destination_fields.
Alex Klein1699fab2022-09-08 08:46:06 -0600744 self.assertEqual(
745 json.loads(self.ReadTempFile(self.public_config_path)),
746 {"chromeos": {"configs": [{"a": 3}]}},
747 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700748
Alex Klein1699fab2022-09-08 08:46:06 -0600749 def test_replicate_private_config_no_build_config(self):
750 """If there is no build config, don't generate C files."""
Alex Kleinfee86da2023-01-20 18:40:06 -0700751 # Modify the replication config to write to "other_config.json" instead
752 # of "build_config.json"
Alex Klein1699fab2022-09-08 08:46:06 -0600753 modified_destination_path = self.public_config_path.replace(
754 "build_config", "other_config"
755 )
756 replication_config = ReplicationConfig(
757 file_replication_rules=[
758 FileReplicationRule(
759 source_path=self.private_config_path,
760 destination_path=modified_destination_path,
761 file_type=FILE_TYPE_JSON,
762 replication_type=REPLICATION_TYPE_FILTER,
763 destination_fields=FieldMask(paths=["a"]),
764 )
765 ]
766 )
767 osutils.WriteFile(
768 self.replication_config_path,
769 json_format.MessageToJson(replication_config),
770 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700771
Alex Klein1699fab2022-09-08 08:46:06 -0600772 refs = [
773 GitRef(
774 path="/chromeos/overlays/overlay-coral-private",
775 ref="main",
776 revision="123",
777 )
778 ]
779 result = packages.replicate_private_config(
780 _build_targets=None, refs=refs, chroot=Chroot()
781 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700782
Alex Klein1699fab2022-09-08 08:46:06 -0600783 self.assertEqual(len(result.modified), 1)
784 self.assertEqual(
785 result.modified[0].files,
786 [os.path.join(self.tempdir, modified_destination_path)],
787 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700788
Alex Klein1699fab2022-09-08 08:46:06 -0600789 def test_replicate_private_config_multiple_build_configs(self):
790 """An error is thrown if there is more than one build config."""
791 replication_config = ReplicationConfig(
792 file_replication_rules=[
793 FileReplicationRule(
794 source_path=self.private_config_path,
795 destination_path=self.public_config_path,
796 file_type=FILE_TYPE_JSON,
797 replication_type=REPLICATION_TYPE_FILTER,
798 destination_fields=FieldMask(paths=["a"]),
799 ),
800 FileReplicationRule(
801 source_path=self.private_config_path,
802 destination_path=self.public_config_path,
803 file_type=FILE_TYPE_JSON,
804 replication_type=REPLICATION_TYPE_FILTER,
805 destination_fields=FieldMask(paths=["a"]),
806 ),
807 ]
808 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700809
Alex Klein1699fab2022-09-08 08:46:06 -0600810 osutils.WriteFile(
811 self.replication_config_path,
812 json_format.MessageToJson(replication_config),
813 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700814
Alex Klein1699fab2022-09-08 08:46:06 -0600815 refs = [
816 GitRef(
817 path="/chromeos/overlays/overlay-coral-private",
818 ref="main",
819 revision="123",
820 )
821 ]
822 with self.assertRaisesRegex(
823 ValueError,
824 "Expected at most one build_config.json destination path.",
825 ):
826 packages.replicate_private_config(
827 _build_targets=None, refs=refs, chroot=Chroot()
828 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700829
Alex Klein1699fab2022-09-08 08:46:06 -0600830 def test_replicate_private_config_generated_files_incorrect(self):
831 """An error is thrown if generated C files are missing."""
832 self.rc.SetDefaultCmdResult(
833 side_effect=self._write_incorrect_generated_c_files
834 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700835
Alex Klein1699fab2022-09-08 08:46:06 -0600836 refs = [
837 GitRef(
838 path="/chromeos/overlays/overlay-coral-private",
839 ref="main",
840 revision="123",
841 )
842 ]
843 chroot = Chroot()
Andrew Lamb9563a152019-12-04 11:42:18 -0700844
Alex Klein1699fab2022-09-08 08:46:06 -0600845 with self.assertRaisesRegex(
846 packages.GeneratedCrosConfigFilesError,
847 "Expected to find generated C files",
848 ):
849 packages.replicate_private_config(
850 _build_targets=None, refs=refs, chroot=chroot
851 )
Andrew Lamb9563a152019-12-04 11:42:18 -0700852
Alex Klein1699fab2022-09-08 08:46:06 -0600853 def test_replicate_private_config_wrong_number_of_refs(self):
854 """An error is thrown if there is not exactly one ref."""
855 with self.assertRaisesRegex(ValueError, "Expected exactly one ref"):
856 packages.replicate_private_config(
857 _build_targets=None, refs=[], chroot=None
858 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700859
Alex Klein1699fab2022-09-08 08:46:06 -0600860 with self.assertRaisesRegex(ValueError, "Expected exactly one ref"):
861 refs = [
862 GitRef(path="a", ref="main", revision="1"),
863 GitRef(path="a", ref="main", revision="2"),
864 ]
865 packages.replicate_private_config(
866 _build_targets=None, refs=refs, chroot=None
867 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700868
Alex Klein1699fab2022-09-08 08:46:06 -0600869 def test_replicate_private_config_replication_config_missing(self):
870 """An error is thrown if there is not a replication config."""
871 os.remove(self.replication_config_path)
872 with self.assertRaisesRegex(
873 ValueError,
874 "Expected ReplicationConfig missing at %s"
875 % self.replication_config_path,
876 ):
877 refs = [
878 GitRef(
879 path="/chromeos/overlays/overlay-coral-private",
880 ref="main",
881 revision="123",
882 )
883 ]
884 packages.replicate_private_config(
885 _build_targets=None, refs=refs, chroot=None
886 )
Andrew Lambe836f222019-12-09 12:27:38 -0700887
Alex Klein1699fab2022-09-08 08:46:06 -0600888 def test_replicate_private_config_wrong_git_ref_path(self):
Alex Kleinfee86da2023-01-20 18:40:06 -0700889 """Git ref that doesn't point to a private overlay throws error."""
Alex Klein1699fab2022-09-08 08:46:06 -0600890 with self.assertRaisesRegex(
891 ValueError, "ref.path must match the pattern"
892 ):
893 refs = [GitRef(path="a/b/c", ref="main", revision="123")]
894 packages.replicate_private_config(
895 _build_targets=None, refs=refs, chroot=None
896 )
Andrew Lamb2bde9e42019-11-04 13:24:09 -0700897
898
Alex Klein5caab872021-09-10 11:44:37 -0600899class GetBestVisibleTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600900 """get_best_visible tests."""
David Burger1e0fe232019-07-01 14:52:07 -0600901
Alex Klein1699fab2022-09-08 08:46:06 -0600902 def test_empty_atom_fails(self):
903 """Test empty atom raises an error."""
904 with self.assertRaises(AssertionError):
905 packages.get_best_visible("")
Alex Kleinda39c6d2019-09-16 14:36:36 -0600906
907
Alex Klein149fd3b2019-12-16 16:01:05 -0700908class HasPrebuiltTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600909 """has_prebuilt tests."""
Alex Kleinda39c6d2019-09-16 14:36:36 -0600910
Alex Klein1699fab2022-09-08 08:46:06 -0600911 def test_empty_atom_fails(self):
912 """Test an empty atom results in an error."""
913 with self.assertRaises(AssertionError):
914 packages.has_prebuilt("")
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600915
Alex Klein1699fab2022-09-08 08:46:06 -0600916 def test_use_flags(self):
917 """Test use flags get propagated correctly."""
918 # We don't really care about the result, just the env handling.
919 patch = self.PatchObject(portage_util, "HasPrebuilt", return_value=True)
920 # Ignore any flags that may be in the environment.
921 self.PatchObject(os.environ, "get", return_value="")
Alex Klein149fd3b2019-12-16 16:01:05 -0700922
Alex Klein1699fab2022-09-08 08:46:06 -0600923 packages.has_prebuilt("cat/pkg-1.2.3", useflags="useflag")
924 patch.assert_called_with(
925 "cat/pkg-1.2.3", board=None, extra_env={"USE": "useflag"}
926 )
Alex Klein149fd3b2019-12-16 16:01:05 -0700927
Alex Klein1699fab2022-09-08 08:46:06 -0600928 def test_env_use_flags(self):
929 """Test env use flags get propagated correctly with passed useflags."""
930 # We don't really care about the result, just the env handling.
931 patch = self.PatchObject(portage_util, "HasPrebuilt", return_value=True)
932 # Add some flags to the environment.
933 existing_flags = "already set flags"
934 self.PatchObject(os.environ, "get", return_value=existing_flags)
Alex Klein149fd3b2019-12-16 16:01:05 -0700935
Alex Klein1699fab2022-09-08 08:46:06 -0600936 new_flags = "useflag"
937 packages.has_prebuilt("cat/pkg-1.2.3", useflags=new_flags)
938 expected = "%s %s" % (existing_flags, new_flags)
939 patch.assert_called_with(
940 "cat/pkg-1.2.3", board=None, extra_env={"USE": expected}
941 )
Alex Klein149fd3b2019-12-16 16:01:05 -0700942
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600943
944class AndroidVersionsTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -0600945 """Tests getting android versions."""
Michael Mortensen14960d02019-10-18 07:53:59 -0600946
Alex Klein1699fab2022-09-08 08:46:06 -0600947 def setUp(self):
948 package_result = [
949 "chromeos-base/android-container-nyc-4717008-r1",
950 "chromeos-base/update_engine-0.0.3-r3408",
951 ]
952 self.PatchObject(
953 portage_util, "GetPackageDependencies", return_value=package_result
954 )
955 self.board = "board"
956 self.PatchObject(
957 portage_util,
958 "FindEbuildForBoardPackage",
959 return_value="chromeos-base/android-container-nyc",
960 )
961 FakeEnvironment = {
962 "ARM_TARGET": "3-linux-target",
963 }
964 self.PatchObject(
965 osutils, "SourceEnvironment", return_value=FakeEnvironment
966 )
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600967
Alex Kleinfee86da2023-01-20 18:40:06 -0700968 # Clear the LRU cache for the function. We mock the function that
969 # provides the data this function processes to produce its result, so we
970 # need to clear it manually.
Alex Klein1699fab2022-09-08 08:46:06 -0600971 packages.determine_android_package.cache_clear()
Alex Klein68a28712021-11-08 11:08:30 -0700972
Alex Klein1699fab2022-09-08 08:46:06 -0600973 def test_determine_android_version(self):
974 """Tests that a valid android version is returned."""
975 version = packages.determine_android_version(self.board)
976 self.assertEqual(version, "4717008")
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600977
Alex Klein1699fab2022-09-08 08:46:06 -0600978 def test_determine_android_version_when_not_present(self):
Alex Kleinfee86da2023-01-20 18:40:06 -0700979 """Test None is returned for version when android is not present."""
Alex Klein1699fab2022-09-08 08:46:06 -0600980 package_result = ["chromeos-base/update_engine-0.0.3-r3408"]
981 self.PatchObject(
982 portage_util, "GetPackageDependencies", return_value=package_result
983 )
984 version = packages.determine_android_version(self.board)
985 self.assertEqual(version, None)
Michael Mortensenedf76532019-10-16 14:22:37 -0600986
Alex Klein1699fab2022-09-08 08:46:06 -0600987 def test_determine_android_branch(self):
988 """Tests that a valid android branch is returned."""
989 branch = packages.determine_android_branch(self.board)
990 self.assertEqual(branch, "3")
Michael Mortensenb70e8a82019-10-10 18:43:41 -0600991
Alex Klein1699fab2022-09-08 08:46:06 -0600992 def test_determine_android_branch_64bit_targets(self):
Alex Kleinfee86da2023-01-20 18:40:06 -0700993 """Tests a valid android branch is returned with only 64bit targets."""
Alex Klein1699fab2022-09-08 08:46:06 -0600994 self.PatchObject(
995 osutils,
996 "SourceEnvironment",
997 return_value={"ARM64_TARGET": "3-linux-target"},
998 )
999 branch = packages.determine_android_branch(self.board)
1000 self.assertEqual(branch, "3")
Federico 'Morg' Pareschicd9165a2020-05-29 09:45:55 +09001001
Alex Klein1699fab2022-09-08 08:46:06 -06001002 def test_determine_android_branch_when_not_present(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001003 """Tests a None is returned for branch when android is not present."""
Alex Klein1699fab2022-09-08 08:46:06 -06001004 package_result = ["chromeos-base/update_engine-0.0.3-r3408"]
1005 self.PatchObject(
1006 portage_util, "GetPackageDependencies", return_value=package_result
1007 )
1008 branch = packages.determine_android_branch(self.board)
1009 self.assertEqual(branch, None)
Michael Mortensenedf76532019-10-16 14:22:37 -06001010
Alex Klein1699fab2022-09-08 08:46:06 -06001011 def test_determine_android_target(self):
1012 """Tests that a valid android target is returned."""
1013 target = packages.determine_android_target(self.board)
1014 self.assertEqual(target, "cheets")
Michael Mortensenc2615b72019-10-15 08:12:24 -06001015
Alex Klein1699fab2022-09-08 08:46:06 -06001016 def test_determine_android_target_when_not_present(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001017 """Tests a None is returned for target when android is not present."""
Alex Klein1699fab2022-09-08 08:46:06 -06001018 package_result = ["chromeos-base/update_engine-0.0.3-r3408"]
1019 self.PatchObject(
1020 portage_util, "GetPackageDependencies", return_value=package_result
1021 )
1022 target = packages.determine_android_target(self.board)
1023 self.assertEqual(target, None)
Michael Mortensenedf76532019-10-16 14:22:37 -06001024
Alex Klein1699fab2022-09-08 08:46:06 -06001025 def test_determine_android_version_handle_exception(self):
1026 """Tests handling RunCommandError inside determine_android_version."""
Alex Kleinfee86da2023-01-20 18:40:06 -07001027 # Mock what happens when portage returns that bubbles up (via
1028 # RunCommand) inside portage_util.GetPackageDependencies.
Alex Klein1699fab2022-09-08 08:46:06 -06001029 self.PatchObject(
1030 portage_util,
1031 "GetPackageDependencies",
1032 side_effect=cros_build_lib.RunCommandError("error"),
1033 )
1034 target = packages.determine_android_version(self.board)
1035 self.assertEqual(target, None)
Michael Mortensene0f4b542019-10-24 15:30:23 -06001036
Alex Klein1699fab2022-09-08 08:46:06 -06001037 def test_determine_android_package_handle_exception(self):
1038 """Tests handling RunCommandError inside determine_android_package."""
Alex Kleinfee86da2023-01-20 18:40:06 -07001039 # Mock what happens when portage returns that bubbles up (via
1040 # RunCommand) inside portage_util.GetPackageDependencies.
Alex Klein1699fab2022-09-08 08:46:06 -06001041 self.PatchObject(
1042 portage_util,
1043 "GetPackageDependencies",
1044 side_effect=cros_build_lib.RunCommandError("error"),
1045 )
1046 target = packages.determine_android_package(self.board)
1047 self.assertEqual(target, None)
Michael Mortensene0f4b542019-10-24 15:30:23 -06001048
Alex Klein1699fab2022-09-08 08:46:06 -06001049 def test_determine_android_package_callers_handle_exception(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001050 """Tests RunCommandError caught by determine_android_package callers."""
1051 # Mock what happens when portage returns that bubbles up (via
1052 # RunCommand) inside portage_util.GetPackageDependencies.
Alex Klein1699fab2022-09-08 08:46:06 -06001053 self.PatchObject(
1054 portage_util,
1055 "GetPackageDependencies",
1056 side_effect=cros_build_lib.RunCommandError("error"),
1057 )
1058 # Verify that target is None, as expected.
1059 target = packages.determine_android_package(self.board)
1060 self.assertEqual(target, None)
1061 # determine_android_branch calls determine_android_package
1062 branch = packages.determine_android_branch(self.board)
1063 self.assertEqual(branch, None)
1064 # determine_android_target calls determine_android_package
1065 target = packages.determine_android_target(self.board)
1066 self.assertEqual(target, None)
Michael Mortensen9fe740c2019-10-29 14:42:48 -06001067
Michael Mortensene0f4b542019-10-24 15:30:23 -06001068
Alex Klein1699fab2022-09-08 08:46:06 -06001069@pytest.mark.usefixtures("testcase_caplog", "testcase_monkeypatch")
Michael Mortensende716a12020-05-15 11:27:00 -06001070class FindFingerprintsTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001071 """Tests for find_fingerprints."""
Michael Mortensende716a12020-05-15 11:27:00 -06001072
Alex Klein1699fab2022-09-08 08:46:06 -06001073 def setUp(self):
1074 self.board = "test-board"
1075 # Create cheets-fingerprints.txt based on tempdir/src...
1076 self.fingerprint_contents = (
1077 "google/test-board/test-board_cheets"
1078 ":9/R99-12345.0.9999/123456:user/release-keys"
1079 )
1080 fingerprint_path = os.path.join(
1081 self.tempdir,
1082 "src/build/images/test-board/latest/cheets-fingerprint.txt",
1083 )
1084 self.chroot = Chroot(self.tempdir)
1085 osutils.WriteFile(
1086 fingerprint_path, self.fingerprint_contents, makedirs=True
1087 )
Michael Mortensende716a12020-05-15 11:27:00 -06001088
Alex Klein1699fab2022-09-08 08:46:06 -06001089 def test_find_fingerprints_with_test_path(self):
1090 """Tests get_firmware_versions with mocked output."""
1091 self.monkeypatch.setattr(constants, "SOURCE_ROOT", self.tempdir)
1092 build_target = build_target_lib.BuildTarget(self.board)
1093 result = packages.find_fingerprints(build_target)
1094 self.assertEqual(result, [self.fingerprint_contents])
1095 self.assertIn("Reading fingerprint file", self.caplog.text)
Michael Mortensende716a12020-05-15 11:27:00 -06001096
Alex Klein1699fab2022-09-08 08:46:06 -06001097 def test_find_fingerprints(self):
1098 """Tests get_firmware_versions with mocked output."""
1099 # Use board name whose path for fingerprint file does not exist.
1100 # Verify that fingerprint file is not found and None is returned.
1101 build_target = build_target_lib.BuildTarget("wrong-boardname")
1102 self.monkeypatch.setattr(constants, "SOURCE_ROOT", self.tempdir)
1103 result = packages.find_fingerprints(build_target)
1104 self.assertEqual(result, [])
1105 self.assertIn("Fingerprint file not found", self.caplog.text)
Michael Mortensende716a12020-05-15 11:27:00 -06001106
1107
Michael Mortensen59e30872020-05-18 14:12:49 -06001108class GetAllFirmwareVersionsTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001109 """Tests for get_firmware_versions."""
Michael Mortensen59e30872020-05-18 14:12:49 -06001110
Alex Klein1699fab2022-09-08 08:46:06 -06001111 def setUp(self):
1112 self.board = "test-board"
Alex Kleinfee86da2023-01-20 18:40:06 -07001113 # pylint: disable=line-too-long
Alex Klein1699fab2022-09-08 08:46:06 -06001114 self.rc.SetDefaultCmdResult(
1115 stdout="""
Michael Mortensen59e30872020-05-18 14:12:49 -06001116
1117flashrom(8): 68935ee2fcfcffa47af81b966269cd2b */build/reef/usr/sbin/flashrom
1118 ELF 64-bit LSB executable, x86-64, version 1 (SYSV), statically linked, for GNU/Linux 2.6.32, BuildID[sha1]=e102cc98d45300b50088999d53775acbeff407dc, stripped
1119 0.9.9 : bbb2d6a : Jul 28 2017 15:12:34 UTC
1120
1121Model: reef
1122BIOS image: 1b535280fe688ac284d95276492b06f6 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/image.bin
1123BIOS version: Google_Reef.9042.87.1
1124BIOS (RW) image: 0ef265eb8f2d228c09f75b011adbdcbb */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/image.binrw
1125BIOS (RW) version: Google_Reef.9042.110.0
1126EC image: 2e8b4b5fa73cc5dbca4496de97a917a9 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/ec.bin
1127EC version: reef_v1.1.5900-ab1ee51
1128EC (RW) version: reef_v1.1.5909-bd1f0c9
1129
1130Model: pyro
1131BIOS image: 9e62447ebf22a724a4a835018ab6234e */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/pyro/image.bin
1132BIOS version: Google_Pyro.9042.87.1
1133BIOS (RW) image: 1897457303c85de99f3e98b2eaa0eccc */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/pyro/image.binrw
1134BIOS (RW) version: Google_Pyro.9042.110.0
1135EC image: 44b93ed591733519e752e05aa0529eb5 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/pyro/ec.bin
1136EC version: pyro_v1.1.5900-ab1ee51
1137EC (RW) version: pyro_v1.1.5909-bd1f0c9
1138
1139Model: snappy
1140BIOS image: 3ab63ff080596bd7de4e7619f003bb64 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/snappy/image.bin
1141BIOS version: Google_Snappy.9042.110.0
1142EC image: c4db159e84428391d2ee25368c5fe5b6 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/snappy/ec.bin
1143EC version: snappy_v1.1.5909-bd1f0c9
1144
1145Model: sand
1146BIOS image: 387da034a4f0a3f53e278ebfdcc2a412 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/sand/image.bin
1147BIOS version: Google_Sand.9042.110.0
1148EC image: 411562e0589dacec131f5fdfbe95a561 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/sand/ec.bin
1149EC version: sand_v1.1.5909-bd1f0c9
1150
1151Model: electro
1152BIOS image: 1b535280fe688ac284d95276492b06f6 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/image.bin
1153BIOS version: Google_Reef.9042.87.1
1154BIOS (RW) image: 0ef265eb8f2d228c09f75b011adbdcbb */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/image.binrw
1155BIOS (RW) version: Google_Reef.9042.110.0
1156EC image: 2e8b4b5fa73cc5dbca4496de97a917a9 */build/reef/tmp/portage/chromeos-base/chromeos-firmware-reef-0.0.1-r79/temp/tmp7rHApL.pack_firmware-99001/models/reef/ec.bin
1157EC version: reef_v1.1.5900-ab1ee51
1158EC (RW) version: reef_v1.1.5909-bd1f0c9
1159
1160Package Content:
1161612e7bb6ed1fb0a05abf2ebdc834c18b *./updater4.sh
11620eafbee07282315829d0f42135ec7c0c *./gbb_utility
11636074e3ca424cb30a67c378c1d9681f9c *./mosys
116468935ee2fcfcffa47af81b966269cd2b *./flashrom
11650eafbee07282315829d0f42135ec7c0c *./dump_fmap
1166490c95d6123c208d20d84d7c16857c7c *./crosfw.sh
116760899148600b8673ddb711faa55aee40 *./common.sh
11683c3a99346d1ca1273cbcd86c104851ff *./shflags
1169de7ce035e1f82a89f8909d888ee402c0 *./crosutil.sh
1170f9334372bdb9036ba09a6fd9bf30e7a2 *./crossystem
117122257a8d5f0adc1f50a1916c3a4a35dd *./models/reef/ec.bin
1172faf12dbb7cdaf21ce153bdffb67841fd *./models/reef/bios.bin
1173c9bbb417b7921b85a7ed999ee42f550e *./models/reef/setvars.sh
117429823d46f1ec1491ecacd7b830fd2686 *./models/pyro/ec.bin
11752320463aba8b22eb5ea836f094d281b3 *./models/pyro/bios.bin
117681614833ad77c9cd093360ba7bea76b8 *./models/pyro/setvars.sh
1177411562e0589dacec131f5fdfbe95a561 *./models/sand/ec.bin
1178387da034a4f0a3f53e278ebfdcc2a412 *./models/sand/bios.bin
1179fcd8cb0ac0e2ed6be220aaae435d43ff *./models/sand/setvars.sh
1180c4db159e84428391d2ee25368c5fe5b6 *./models/snappy/ec.bin
11813ab63ff080596bd7de4e7619f003bb64 *./models/snappy/bios.bin
1182fe5d699f2e9e4a7de031497953313dbd *./models/snappy/setvars.sh
118379aabd7cd8a215a54234c53d7bb2e6fb *./vpd
Alex Klein1699fab2022-09-08 08:46:06 -06001184"""
1185 )
Alex Kleinfee86da2023-01-20 18:40:06 -07001186 # pylint: enable=line-too-long
Michael Mortensen59e30872020-05-18 14:12:49 -06001187
Alex Klein1699fab2022-09-08 08:46:06 -06001188 def test_get_firmware_versions(self):
1189 """Tests get_firmware_versions with mocked output."""
1190 build_target = build_target_lib.BuildTarget(self.board)
1191 result = packages.get_all_firmware_versions(build_target)
1192 self.assertEqual(len(result), 5)
1193 self.assertEqual(
1194 result["reef"],
1195 packages.FirmwareVersions(
1196 "reef",
1197 "Google_Reef.9042.87.1",
1198 "Google_Reef.9042.110.0",
1199 "reef_v1.1.5900-ab1ee51",
1200 "reef_v1.1.5909-bd1f0c9",
1201 ),
1202 )
1203 self.assertEqual(
1204 result["pyro"],
1205 packages.FirmwareVersions(
1206 "pyro",
1207 "Google_Pyro.9042.87.1",
1208 "Google_Pyro.9042.110.0",
1209 "pyro_v1.1.5900-ab1ee51",
1210 "pyro_v1.1.5909-bd1f0c9",
1211 ),
1212 )
1213 self.assertEqual(
1214 result["snappy"],
1215 packages.FirmwareVersions(
1216 "snappy",
1217 "Google_Snappy.9042.110.0",
1218 None,
1219 "snappy_v1.1.5909-bd1f0c9",
1220 None,
1221 ),
1222 )
1223 self.assertEqual(
1224 result["sand"],
1225 packages.FirmwareVersions(
1226 "sand",
1227 "Google_Sand.9042.110.0",
1228 None,
1229 "sand_v1.1.5909-bd1f0c9",
1230 None,
1231 ),
1232 )
1233 self.assertEqual(
1234 result["electro"],
1235 packages.FirmwareVersions(
1236 "electro",
1237 "Google_Reef.9042.87.1",
1238 "Google_Reef.9042.110.0",
1239 "reef_v1.1.5900-ab1ee51",
1240 "reef_v1.1.5909-bd1f0c9",
1241 ),
1242 )
Michael Mortensen59e30872020-05-18 14:12:49 -06001243
Alex Klein1699fab2022-09-08 08:46:06 -06001244 def test_get_firmware_versions_error(self):
1245 """Tests get_firmware_versions with no output."""
1246 # Throw an exception when running the command.
1247 self.PatchObject(
1248 cros_build_lib,
1249 "run",
1250 side_effect=cros_build_lib.RunCommandError("error"),
1251 )
1252 build_target = build_target_lib.BuildTarget(self.board)
1253 result = packages.get_all_firmware_versions(build_target)
1254 self.assertEqual(result, {})
Benjamin Shai12c767e2022-01-12 15:17:44 +00001255
Michael Mortensen59e30872020-05-18 14:12:49 -06001256
Michael Mortensen71ef5682020-05-07 14:29:24 -06001257class GetFirmwareVersionsTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001258 """Tests for get_firmware_versions."""
Michael Mortensen71ef5682020-05-07 14:29:24 -06001259
Alex Klein1699fab2022-09-08 08:46:06 -06001260 def setUp(self):
1261 self.board = "test-board"
Alex Kleinfee86da2023-01-20 18:40:06 -07001262 # pylint: disable=line-too-long
Alex Klein1699fab2022-09-08 08:46:06 -06001263 self.rc.SetDefaultCmdResult(
1264 stdout="""
Michael Mortensen71ef5682020-05-07 14:29:24 -06001265
1266flashrom(8): a8f99c2e61e7dc09c4b25ef5a76ef692 */build/kevin/usr/sbin/flashrom
1267 ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), statically linked, for GNU/Linux 2.d
1268 0.9.4 : 860875a : Apr 10 2017 23:54:29 UTC
1269
1270BIOS image: 6b5b855a0b8fd1657546d1402c15b206 *chromeos-firmware-kevin-0.0.1/.dist/kevin_fw_8785.178.0.n
1271BIOS version: Google_Kevin.8785.178.0
1272EC image: 1ebfa9518e6cac0558a80b7ab2f5b489 *chromeos-firmware-kevin-0.0.1/.dist/kevin_ec_8785.178.0.n
1273EC version:kevin_v1.10.184-459421c
1274
1275Package Content:
1276a8f99c2e61e7dc09c4b25ef5a76ef692 *./flashrom
12773c3a99346d1ca1273cbcd86c104851ff *./shflags
1278457a8dc8546764affc9700f8da328d23 *./dump_fmap
1279c392980ddb542639edf44a965a59361a *./updater5.sh
1280490c95d6123c208d20d84d7c16857c7c *./crosfw.sh
12816b5b855a0b8fd1657546d1402c15b206 *./bios.bin
12827b5bef0d2da90c23ff2e157250edf0fa *./crosutil.sh
1283d78722e4f1a0dc2d8c3d6b0bc7010ae3 *./crossystem
1284457a8dc8546764affc9700f8da328d23 *./gbb_utility
12851ebfa9518e6cac0558a80b7ab2f5b489 *./ec.bin
1286c98ca54db130886142ad582a58e90ddc *./common.sh
12875ba978bdec0f696f47f0f0de90936880 *./mosys
1288312e8ee6122057f2a246d7bcf1572f49 *./vpd
Alex Klein1699fab2022-09-08 08:46:06 -06001289"""
1290 )
Alex Kleinfee86da2023-01-20 18:40:06 -07001291 # pylint: enable=line-too-long
Michael Mortensen71ef5682020-05-07 14:29:24 -06001292
Alex Klein1699fab2022-09-08 08:46:06 -06001293 def test_get_firmware_versions(self):
1294 """Tests get_firmware_versions with mocked output."""
1295 build_target = build_target_lib.BuildTarget(self.board)
1296 result = packages.get_firmware_versions(build_target)
1297 versions = packages.FirmwareVersions(
1298 None,
1299 "Google_Kevin.8785.178.0",
1300 None,
1301 "kevin_v1.10.184-459421c",
1302 None,
1303 )
1304 self.assertEqual(result, versions)
Michael Mortensen71ef5682020-05-07 14:29:24 -06001305
1306
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001307class DetermineKernelVersionTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001308 """Tests for determine_kernel_version."""
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001309
Alex Klein1699fab2022-09-08 08:46:06 -06001310 def setUp(self):
1311 self.board = "test-board"
1312 self.build_target = build_target_lib.BuildTarget(self.board)
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001313
Alex Klein1699fab2022-09-08 08:46:06 -06001314 def test_determine_kernel_version(self):
1315 """Tests that a valid kernel version is returned."""
Lizzy Presland0b978e62022-09-09 16:55:29 +00001316 kernel_candidates = [
1317 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
Alex Klein1699fab2022-09-08 08:46:06 -06001318 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
Lizzy Presland0b978e62022-09-09 16:55:29 +00001319 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1320 "sys-kernel/upstream-kernel-next-9999",
1321 "sys-kernel/socfpga-kernel-4.20-r34",
Alex Klein1699fab2022-09-08 08:46:06 -06001322 ]
1323 self.PatchObject(
Lizzy Presland0b978e62022-09-09 16:55:29 +00001324 portage_util,
1325 "GetFlattenedDepsForPackage",
1326 return_value=kernel_candidates,
1327 )
1328
1329 installed_pkgs = [
1330 "sys-kernel/linux-firmware-0.0.1-r594",
1331 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1332 "virtual/linux-sources-1-r30",
1333 ]
1334 self.PatchObject(
1335 portage_util,
1336 "GetPackageDependencies",
1337 return_value=installed_pkgs,
Alex Klein1699fab2022-09-08 08:46:06 -06001338 )
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001339
Alex Klein1699fab2022-09-08 08:46:06 -06001340 result = packages.determine_kernel_version(self.build_target)
1341 self.assertEqual(result, "4.4.223-r2209")
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001342
Lizzy Presland0b978e62022-09-09 16:55:29 +00001343 def test_determine_kernel_version_ignores_exact_duplicates(self):
1344 """Tests that multiple results for candidates is ignored."""
1345 # Depgraph is evaluated for version as well as revision, so graph will
1346 # return all results twice.
1347 kernel_candidates = [
1348 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1349 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1350 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1351 "sys-kernel/upstream-kernel-next-9999",
1352 "sys-kernel/socfpga-kernel-4.20-r34",
1353 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1354 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1355 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1356 "sys-kernel/upstream-kernel-next-9999",
1357 "sys-kernel/socfpga-kernel-4.20-r34",
1358 ]
1359 self.PatchObject(
1360 portage_util,
1361 "GetFlattenedDepsForPackage",
1362 return_value=kernel_candidates,
1363 )
1364
1365 installed_pkgs = [
1366 "sys-kernel/linux-firmware-0.0.1-r594",
1367 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1368 "virtual/linux-sources-1-r30",
1369 ]
Alex Klein1699fab2022-09-08 08:46:06 -06001370 self.PatchObject(
1371 portage_util,
1372 "GetPackageDependencies",
Lizzy Presland0b978e62022-09-09 16:55:29 +00001373 return_value=installed_pkgs,
1374 )
1375
1376 result = packages.determine_kernel_version(self.build_target)
1377 self.assertEqual(result, "4.4.223-r2209")
1378
1379 def test_determine_kernel_version_ignores_virtual_package(self):
1380 """Tests that top-level package is ignored as potential kernel pkg."""
1381 # Depgraph results include the named package at level 0 as well as its
1382 # first-order dependencies, so verify that the virtual package is not
1383 # included as a kernel package.
1384 kernel_candidates = [
1385 "virtual/linux-sources-1",
1386 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1387 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1388 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1389 "sys-kernel/upstream-kernel-next-9999",
1390 "sys-kernel/socfpga-kernel-4.20-r34",
1391 "virtual/linux-sources-1-r30",
1392 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1393 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1394 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1395 "sys-kernel/upstream-kernel-next-9999",
1396 "sys-kernel/socfpga-kernel-4.20-r34",
1397 ]
1398 self.PatchObject(
1399 portage_util,
1400 "GetFlattenedDepsForPackage",
1401 return_value=kernel_candidates,
1402 )
1403
1404 installed_pkgs = [
1405 "sys-kernel/linux-firmware-0.0.1-r594",
1406 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1407 "virtual/linux-sources-1-r30",
1408 ]
1409 self.PatchObject(
1410 portage_util,
1411 "GetPackageDependencies",
1412 return_value=installed_pkgs,
1413 )
1414
1415 result = packages.determine_kernel_version(self.build_target)
1416 self.assertEqual(result, "4.4.223-r2209")
1417
1418 def test_determine_kernel_version_too_many(self):
1419 """Tests that an exception is thrown with too many matching packages."""
1420 package_result = [
1421 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1422 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1423 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1424 "sys-kernel/upstream-kernel-next-9999",
1425 "sys-kernel/socfpga-kernel-4.20-r34",
1426 ]
1427 self.PatchObject(
1428 portage_util,
1429 "GetFlattenedDepsForPackage",
1430 return_value=package_result,
1431 )
1432
1433 installed_pkgs = [
1434 "sys-kernel/linux-firmware-0.0.1-r594",
1435 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1436 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1437 "virtual/linux-sources-1-r30",
1438 ]
1439 self.PatchObject(
1440 portage_util,
1441 "GetPackageDependencies",
1442 return_value=installed_pkgs,
1443 )
1444
1445 with self.assertRaises(packages.KernelVersionError):
1446 packages.determine_kernel_version(self.build_target)
1447
1448 def test_determine_kernel_version_no_kernel_match(self):
1449 """Tests that an exception is thrown with 0-sized intersection."""
1450 package_result = [
1451 "sys-kernel/chromeos-kernel-experimental-4.18_rc2-r23",
1452 "sys-kernel/chromeos-kernel-4_4-4.4.223-r2209",
1453 "sys-kernel/chromeos-kernel-5_15-5.15.65-r869",
1454 "sys-kernel/upstream-kernel-next-9999",
1455 ]
1456 self.PatchObject(
1457 portage_util,
1458 "GetFlattenedDepsForPackage",
1459 return_value=package_result,
1460 )
1461
1462 installed_pkgs = [
1463 "sys-kernel/linux-firmware-0.0.1-r594",
1464 "sys-kernel/socfpga-kernel-4.20-r34",
1465 "virtual/linux-sources-1-r30",
1466 ]
1467 self.PatchObject(
1468 portage_util,
1469 "GetPackageDependencies",
1470 return_value=installed_pkgs,
1471 )
1472
1473 with self.assertRaises(packages.KernelVersionError):
1474 packages.determine_kernel_version(self.build_target)
1475
1476 def test_determine_kernel_version_exception(self):
1477 """Tests that portage_util exceptions result in returning empty str."""
1478 self.PatchObject(
1479 portage_util,
1480 "GetFlattenedDepsForPackage",
Alex Klein1699fab2022-09-08 08:46:06 -06001481 side_effect=cros_build_lib.RunCommandError("error"),
1482 )
1483 result = packages.determine_kernel_version(self.build_target)
Lizzy Presland0b978e62022-09-09 16:55:29 +00001484 self.assertEqual(result, "")
Michael Mortensenfbf2b2d2020-05-14 16:33:06 -06001485
Alex Klein627e04c2021-11-10 15:56:47 -07001486
Michael Mortensenc2615b72019-10-15 08:12:24 -06001487class ChromeVersionsTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001488 """Tests getting chrome version."""
Michael Mortensen14960d02019-10-18 07:53:59 -06001489
Alex Klein1699fab2022-09-08 08:46:06 -06001490 def setUp(self):
1491 self.build_target = build_target_lib.BuildTarget("board")
Michael Mortensenc2615b72019-10-15 08:12:24 -06001492
Alex Klein1699fab2022-09-08 08:46:06 -06001493 def test_determine_chrome_version(self):
1494 """Tests that a valid chrome version is returned."""
1495 # Mock PortageqBestVisible to return a valid chrome version string.
1496 r1_cpf = "chromeos-base/chromeos-chrome-78.0.3900.0_rc-r1"
1497 r1_cpv = package_info.SplitCPV(r1_cpf)
1498 self.PatchObject(
1499 portage_util, "PortageqBestVisible", return_value=r1_cpv
1500 )
Michael Mortensenc2615b72019-10-15 08:12:24 -06001501
Alex Klein1699fab2022-09-08 08:46:06 -06001502 chrome_version = packages.determine_chrome_version(self.build_target)
1503 version_numbers = chrome_version.split(".")
1504 self.assertEqual(len(version_numbers), 4)
1505 self.assertEqual(int(version_numbers[0]), 78)
Michael Mortensen9fdb14b2019-10-17 11:17:30 -06001506
Alex Klein1699fab2022-09-08 08:46:06 -06001507 def test_determine_chrome_version_handle_exception(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001508 # Mock what happens when portage throws an exception that bubbles up
1509 # (via RunCommand)inside portage_util.PortageqBestVisible.
Alex Klein1699fab2022-09-08 08:46:06 -06001510 self.PatchObject(
1511 portage_util,
1512 "PortageqBestVisible",
1513 side_effect=cros_build_lib.RunCommandError("error"),
1514 )
1515 target = packages.determine_chrome_version(self.build_target)
1516 self.assertEqual(target, None)
Michael Mortensen9fe740c2019-10-29 14:42:48 -06001517
Michael Mortensen9fdb14b2019-10-17 11:17:30 -06001518
1519class PlatformVersionsTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001520 """Tests getting platform version."""
Michael Mortensen9fdb14b2019-10-17 11:17:30 -06001521
Alex Klein1699fab2022-09-08 08:46:06 -06001522 def test_determine_platform_version(self):
1523 """Test checking that a valid platform version is returned."""
1524 platform_version = packages.determine_platform_version()
1525 # The returned platform version is something like 12603.0.0.
1526 version_string_list = platform_version.split(".")
1527 self.assertEqual(len(version_string_list), 3)
Alex Kleinfee86da2023-01-20 18:40:06 -07001528 # We don't want to check an exact version, but the first number should
1529 # be non-zero.
Alex Klein1699fab2022-09-08 08:46:06 -06001530 self.assertGreaterEqual(int(version_string_list[0]), 1)
Michael Mortensen009cb662019-10-21 11:38:43 -06001531
Alex Klein1699fab2022-09-08 08:46:06 -06001532 def test_determine_milestone_version(self):
1533 """Test checking that a valid milestone version is returned."""
1534 milestone_version = packages.determine_milestone_version()
1535 # Milestone version should be non-zero
1536 self.assertGreaterEqual(int(milestone_version), 1)
Michael Mortensen009cb662019-10-21 11:38:43 -06001537
Alex Klein1699fab2022-09-08 08:46:06 -06001538 def test_determine_full_version(self):
1539 """Test checking that a valid full version is returned."""
1540 full_version = packages.determine_full_version()
1541 pattern = r"^R(\d+)-(\d+.\d+.\d+(-rc\d+)*)"
1542 m = re.match(pattern, full_version)
1543 self.assertTrue(m)
1544 milestone_version = m.group(1)
1545 self.assertGreaterEqual(int(milestone_version), 1)
Michael Mortensen009cb662019-10-21 11:38:43 -06001546
Alex Klein1699fab2022-09-08 08:46:06 -06001547 def test_versions_based_on_mock(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001548 # Create a test version_info object, and then mock VersionInfo.from_repo
Alex Klein1699fab2022-09-08 08:46:06 -06001549 # return it.
1550 test_platform_version = "12575.0.0"
1551 test_chrome_branch = "75"
1552 version_info_mock = chromeos_version.VersionInfo(test_platform_version)
1553 version_info_mock.chrome_branch = test_chrome_branch
1554 self.PatchObject(
1555 chromeos_version.VersionInfo,
1556 "from_repo",
1557 return_value=version_info_mock,
1558 )
1559 test_full_version = (
1560 "R" + test_chrome_branch + "-" + test_platform_version
1561 )
1562 platform_version = packages.determine_platform_version()
1563 milestone_version = packages.determine_milestone_version()
1564 full_version = packages.determine_full_version()
1565 self.assertEqual(platform_version, test_platform_version)
1566 self.assertEqual(milestone_version, test_chrome_branch)
1567 self.assertEqual(full_version, test_full_version)
Chris McDonaldea0312c2020-05-04 23:33:15 -06001568
1569
1570# Each of the columns in the following table is a separate dimension along
1571# which Chrome uprev test cases can vary in behavior. The full test space would
1572# be the Cartesian product of the possible values of each column.
1573# 'CHROME_EBUILD' refers to the relationship between the version of the existing
1574# Chrome ebuild vs. the requested uprev version. 'FOLLOWER_EBUILDS' refers to
1575# the same relationship but for the packages defined in OTHER_CHROME_PACKAGES.
1576# 'EBUILDS MODIFIED' refers to whether any of the existing 9999 ebuilds have
1577# modified contents relative to their corresponding stable ebuilds.
1578#
1579# CHROME_EBUILD FOLLOWER_EBUILDS EBUILDS_MODIFIED
1580#
1581# HIGHER HIGHER YES
1582# SAME SAME NO
1583# LOWER LOWER
1584# DOESN'T EXIST YET
1585
1586# These test cases cover both CHROME & FOLLOWER ebuilds being identically
1587# higher, lower, or the same versions, with no modified ebuilds.
1588UPREV_VERSION_CASES = (
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001589 # Uprev.
Chris McDonaldea0312c2020-05-04 23:33:15 -06001590 pytest.param(
Alex Klein1699fab2022-09-08 08:46:06 -06001591 "80.0.8080.0",
1592 "81.0.8181.0",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001593 # One added and one deleted for chrome and each "other" package.
1594 2 * (1 + len(constants.OTHER_CHROME_PACKAGES)),
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001595 False,
Alex Klein1699fab2022-09-08 08:46:06 -06001596 id="newer_chrome_version",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001597 ),
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001598 # Revbump.
1599 pytest.param(
Alex Klein1699fab2022-09-08 08:46:06 -06001600 "80.0.8080.0",
1601 "80.0.8080.0",
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001602 2,
1603 True,
Alex Klein1699fab2022-09-08 08:46:06 -06001604 id="chrome_revbump",
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001605 ),
Chris McDonaldea0312c2020-05-04 23:33:15 -06001606 # No files should be changed in these cases.
1607 pytest.param(
Alex Klein1699fab2022-09-08 08:46:06 -06001608 "80.0.8080.0",
1609 "80.0.8080.0",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001610 0,
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001611 False,
Alex Klein1699fab2022-09-08 08:46:06 -06001612 id="same_chrome_version",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001613 ),
1614 pytest.param(
Alex Klein1699fab2022-09-08 08:46:06 -06001615 "80.0.8080.0",
1616 "79.0.7979.0",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001617 0,
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001618 False,
Alex Klein1699fab2022-09-08 08:46:06 -06001619 id="older_chrome_version",
Chris McDonaldea0312c2020-05-04 23:33:15 -06001620 ),
1621)
1622
1623
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001624@pytest.mark.parametrize(
Alex Klein1699fab2022-09-08 08:46:06 -06001625 "old_version, new_version, expected_count, modify_unstable",
1626 UPREV_VERSION_CASES,
1627)
1628def test_uprev_chrome_all_files_already_exist(
1629 old_version,
1630 new_version,
1631 expected_count,
1632 modify_unstable,
1633 monkeypatch,
1634 overlay_stack,
1635):
1636 """Test Chrome uprevs work as expected when all packages already exist."""
1637 (overlay,) = overlay_stack(1)
1638 monkeypatch.setattr(uprev_lib, "_CHROME_OVERLAY_PATH", overlay.path)
Chris McDonaldea0312c2020-05-04 23:33:15 -06001639
Alex Klein1699fab2022-09-08 08:46:06 -06001640 unstable_chrome = cr.test.Package(
1641 "chromeos-base", "chromeos-chrome", version="9999", keywords="~*"
1642 )
1643 if modify_unstable:
1644 # Add some field not set in stable.
1645 unstable_chrome.depend = "foo/bar"
Alex Klein0b2ec2d2021-06-23 15:56:45 -06001646
Alex Klein1699fab2022-09-08 08:46:06 -06001647 stable_chrome = cr.test.Package(
1648 "chromeos-base", "chromeos-chrome", version=f"{old_version}_rc-r1"
1649 )
Chris McDonaldea0312c2020-05-04 23:33:15 -06001650
Alex Klein1699fab2022-09-08 08:46:06 -06001651 overlay.add_package(unstable_chrome)
1652 overlay.add_package(stable_chrome)
Chris McDonaldea0312c2020-05-04 23:33:15 -06001653
Alex Klein1699fab2022-09-08 08:46:06 -06001654 for pkg_str in constants.OTHER_CHROME_PACKAGES:
1655 category, pkg_name = pkg_str.split("/")
1656 unstable_pkg = cr.test.Package(
1657 category, pkg_name, version="9999", keywords="~*"
1658 )
1659 stable_pkg = cr.test.Package(
1660 category, pkg_name, version=f"{old_version}_rc-r1"
1661 )
Chris McDonaldea0312c2020-05-04 23:33:15 -06001662
Alex Klein1699fab2022-09-08 08:46:06 -06001663 overlay.add_package(unstable_pkg)
1664 overlay.add_package(stable_pkg)
Chris McDonaldea0312c2020-05-04 23:33:15 -06001665
Alex Klein1699fab2022-09-08 08:46:06 -06001666 git_refs = [
1667 GitRef(
1668 path="/foo", ref=f"refs/tags/{new_version}", revision="stubcommit"
1669 )
1670 ]
1671 res = packages.uprev_chrome_from_ref(None, git_refs, None)
Chris McDonaldea0312c2020-05-04 23:33:15 -06001672
Alex Klein1699fab2022-09-08 08:46:06 -06001673 modified_file_count = sum(len(m.files) for m in res.modified)
1674 assert modified_file_count == expected_count
Michael Mortensen125bb012020-05-21 14:02:10 -06001675
1676
Alex Klein1699fab2022-09-08 08:46:06 -06001677@pytest.mark.usefixtures("testcase_monkeypatch")
Michael Mortensen125bb012020-05-21 14:02:10 -06001678class GetModelsTest(cros_test_lib.RunCommandTempDirTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001679 """Tests for get_models."""
Michael Mortensen125bb012020-05-21 14:02:10 -06001680
Alex Klein1699fab2022-09-08 08:46:06 -06001681 def setUp(self):
1682 self.board = "test-board"
1683 self.rc.SetDefaultCmdResult(stdout="pyro\nreef\nsnappy\n")
1684 self.monkeypatch.setattr(constants, "SOURCE_ROOT", self.tempdir)
1685 build_bin = os.path.join(
1686 self.tempdir, constants.DEFAULT_CHROOT_DIR, "usr", "bin"
1687 )
1688 osutils.Touch(
1689 os.path.join(build_bin, "cros_config_host"), makedirs=True
1690 )
Michael Mortensen125bb012020-05-21 14:02:10 -06001691
Alex Klein1699fab2022-09-08 08:46:06 -06001692 def testGetModels(self):
1693 """Test get_models."""
1694 build_target = build_target_lib.BuildTarget(self.board)
1695 result = packages.get_models(build_target)
1696 self.assertEqual(result, ["pyro", "reef", "snappy"])
Michael Mortensen359c1f32020-05-28 19:35:42 -06001697
1698
1699class GetKeyIdTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001700 """Tests for get_key_id."""
Michael Mortensen359c1f32020-05-28 19:35:42 -06001701
Alex Klein1699fab2022-09-08 08:46:06 -06001702 def setUp(self):
1703 self.board = "test-board"
1704 self.build_target = build_target_lib.BuildTarget(self.board)
Michael Mortensen359c1f32020-05-28 19:35:42 -06001705
Alex Klein1699fab2022-09-08 08:46:06 -06001706 def testGetKeyId(self):
1707 """Test get_key_id when _run_cros_config_host returns a key."""
1708 self.PatchObject(
1709 packages, "_run_cros_config_host", return_value=["key"]
1710 )
1711 result = packages.get_key_id(self.build_target, "model")
1712 self.assertEqual(result, "key")
Michael Mortensen359c1f32020-05-28 19:35:42 -06001713
Alex Klein1699fab2022-09-08 08:46:06 -06001714 def testGetKeyIdNoKey(self):
1715 """Test get_key_id when None should be returned."""
1716 self.PatchObject(
1717 packages, "_run_cros_config_host", return_value=["key1", "key2"]
1718 )
1719 result = packages.get_key_id(self.build_target, "model")
1720 self.assertEqual(result, None)
Ben Reiche779cf42020-12-15 03:21:31 +00001721
1722
Harvey Yang3eee06c2021-03-18 15:47:56 +08001723class GetLatestVersionTest(cros_test_lib.TestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001724 """Tests for get_latest_version_from_refs."""
Ben Reiche779cf42020-12-15 03:21:31 +00001725
Alex Klein1699fab2022-09-08 08:46:06 -06001726 def setUp(self):
1727 self.prefix = "refs/tags/drivefs_"
1728 # The tag ref template.
1729 ref_tpl = self.prefix + "%s"
Ben Reiche779cf42020-12-15 03:21:31 +00001730
Alex Klein1699fab2022-09-08 08:46:06 -06001731 self.latest = "44.0.20"
1732 self.versions = ["42.0.1", self.latest, "44.0.19", "39.0.15"]
1733 self.latest_ref = uprev_lib.GitRef(
1734 "/path", ref_tpl % self.latest, "abc123"
1735 )
1736 self.refs = [
1737 uprev_lib.GitRef("/path", ref_tpl % v, "abc123")
1738 for v in self.versions
1739 ]
Ben Reiche779cf42020-12-15 03:21:31 +00001740
Alex Klein1699fab2022-09-08 08:46:06 -06001741 def test_single_ref(self):
1742 """Test a single ref is supplied."""
1743 # pylint: disable=protected-access
1744 self.assertEqual(
1745 self.latest,
1746 packages._get_latest_version_from_refs(
1747 self.prefix, [self.latest_ref]
1748 ),
1749 )
Ben Reiche779cf42020-12-15 03:21:31 +00001750
Alex Klein1699fab2022-09-08 08:46:06 -06001751 def test_multiple_ref_versions(self):
1752 """Test multiple refs supplied."""
1753 # pylint: disable=protected-access
1754 self.assertEqual(
1755 self.latest,
1756 packages._get_latest_version_from_refs(self.prefix, self.refs),
1757 )
Ben Reiche779cf42020-12-15 03:21:31 +00001758
Alex Klein1699fab2022-09-08 08:46:06 -06001759 def test_no_refs_returns_none(self):
1760 """Test no refs supplied."""
1761 # pylint: disable=protected-access
1762 self.assertEqual(
1763 packages._get_latest_version_from_refs(self.prefix, []), None
1764 )
Harvey Yang9c61e9c2021-03-02 16:32:43 +08001765
Chinglin Yu84818732022-10-03 12:03:43 +08001766 def test_ref_prefix(self):
1767 """Test refs with a different prefix isn't used"""
1768 # pylint: disable=protected-access
1769 # Add refs/tags/foo_100.0.0 to the refs, which should be ignored in
1770 # _get_latest_version_from_refs because the prefix doesn't match, even
1771 # if its version number is larger.
1772 refs = self.refs + [
1773 uprev_lib.GitRef("/path", "refs/tags/foo_100.0.0", "abc123")
1774 ]
1775 self.assertEqual(
1776 self.latest,
1777 packages._get_latest_version_from_refs(self.prefix, refs),
1778 )
1779
Harvey Yang9c61e9c2021-03-02 16:32:43 +08001780
Alex Klein6becabc2020-09-11 14:03:05 -06001781class NeedsChromeSourceTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001782 """Tests for needs_chrome_source."""
Alex Klein6becabc2020-09-11 14:03:05 -06001783
Alex Klein1699fab2022-09-08 08:46:06 -06001784 def _build_graph(self, with_chrome: bool, with_followers: bool):
1785 root = "/build/build_target"
1786 foo_bar = package_info.parse("foo/bar-1")
1787 chrome = package_info.parse(f"{constants.CHROME_CP}-1.2.3.4")
1788 followers = [
1789 package_info.parse(f"{pkg}-1.2.3.4")
1790 for pkg in constants.OTHER_CHROME_PACKAGES
1791 ]
1792 nodes = [dependency_graph.PackageNode(foo_bar, root)]
1793 root_pkgs = ["foo/bar-1"]
1794 if with_chrome:
1795 nodes.append(dependency_graph.PackageNode(chrome, root))
1796 root_pkgs.append(chrome.cpvr)
1797 if with_followers:
1798 nodes.extend(
1799 [dependency_graph.PackageNode(f, root) for f in followers]
1800 )
1801 root_pkgs.extend([f.cpvr for f in followers])
Alex Klein6becabc2020-09-11 14:03:05 -06001802
Alex Klein1699fab2022-09-08 08:46:06 -06001803 return dependency_graph.DependencyGraph(nodes, root, root_pkgs)
Alex Klein6becabc2020-09-11 14:03:05 -06001804
Alex Klein1699fab2022-09-08 08:46:06 -06001805 def test_needs_all(self):
1806 """Verify we need source when we have no prebuilts."""
1807 graph = self._build_graph(with_chrome=True, with_followers=True)
1808 self.PatchObject(
1809 depgraph, "get_sysroot_dependency_graph", return_value=graph
1810 )
1811 self.PatchObject(packages, "has_prebuilt", return_value=False)
1812 self.PatchObject(
1813 packages,
1814 "uprev_chrome",
1815 return_value=uprev_lib.UprevVersionedPackageResult(),
1816 )
Alex Klein6becabc2020-09-11 14:03:05 -06001817
Alex Klein1699fab2022-09-08 08:46:06 -06001818 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001819
Alex Klein1699fab2022-09-08 08:46:06 -06001820 result = packages.needs_chrome_source(build_target)
Alex Klein6becabc2020-09-11 14:03:05 -06001821
Alex Klein1699fab2022-09-08 08:46:06 -06001822 self.assertTrue(result.needs_chrome_source)
1823 self.assertTrue(result.builds_chrome)
1824 self.assertTrue(result.packages)
1825 self.assertEqual(
1826 len(result.packages), len(constants.OTHER_CHROME_PACKAGES) + 1
1827 )
1828 self.assertTrue(result.missing_chrome_prebuilt)
1829 self.assertTrue(result.missing_follower_prebuilt)
1830 self.assertFalse(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001831
Alex Klein1699fab2022-09-08 08:46:06 -06001832 def test_needs_none(self):
Alex Kleinfee86da2023-01-20 18:40:06 -07001833 """Verify not building any chrome packages prevents needing it."""
Alex Klein1699fab2022-09-08 08:46:06 -06001834 graph = self._build_graph(with_chrome=False, with_followers=False)
1835 self.PatchObject(
1836 depgraph, "get_sysroot_dependency_graph", return_value=graph
1837 )
1838 self.PatchObject(packages, "has_prebuilt", return_value=False)
1839 self.PatchObject(
1840 packages,
1841 "uprev_chrome",
1842 return_value=uprev_lib.UprevVersionedPackageResult(),
1843 )
Alex Klein6becabc2020-09-11 14:03:05 -06001844
Alex Klein1699fab2022-09-08 08:46:06 -06001845 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001846
Alex Klein1699fab2022-09-08 08:46:06 -06001847 result = packages.needs_chrome_source(build_target)
Alex Klein6becabc2020-09-11 14:03:05 -06001848
Alex Klein1699fab2022-09-08 08:46:06 -06001849 self.assertFalse(result.needs_chrome_source)
1850 self.assertFalse(result.builds_chrome)
1851 self.assertFalse(result.packages)
1852 self.assertFalse(result.missing_chrome_prebuilt)
1853 self.assertFalse(result.missing_follower_prebuilt)
1854 self.assertFalse(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001855
Alex Klein1699fab2022-09-08 08:46:06 -06001856 def test_needs_chrome_only(self):
1857 """Verify only chrome triggers needs chrome source."""
1858 graph = self._build_graph(with_chrome=True, with_followers=False)
1859 self.PatchObject(
1860 depgraph, "get_sysroot_dependency_graph", return_value=graph
1861 )
1862 self.PatchObject(packages, "has_prebuilt", return_value=False)
1863 self.PatchObject(
1864 packages,
1865 "uprev_chrome",
1866 return_value=uprev_lib.UprevVersionedPackageResult(),
1867 )
Alex Klein6becabc2020-09-11 14:03:05 -06001868
Alex Klein1699fab2022-09-08 08:46:06 -06001869 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001870
Alex Klein1699fab2022-09-08 08:46:06 -06001871 result = packages.needs_chrome_source(build_target)
Alex Klein6becabc2020-09-11 14:03:05 -06001872
Alex Klein1699fab2022-09-08 08:46:06 -06001873 self.assertTrue(result.needs_chrome_source)
1874 self.assertTrue(result.builds_chrome)
1875 self.assertTrue(result.packages)
1876 self.assertEqual(
1877 set([p.atom for p in result.packages]), {constants.CHROME_CP}
1878 )
1879 self.assertTrue(result.missing_chrome_prebuilt)
1880 self.assertFalse(result.missing_follower_prebuilt)
1881 self.assertFalse(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001882
Alex Klein1699fab2022-09-08 08:46:06 -06001883 def test_needs_followers_only(self):
1884 """Verify only chrome followers triggers needs chrome source."""
1885 graph = self._build_graph(with_chrome=False, with_followers=True)
1886 self.PatchObject(
1887 depgraph, "get_sysroot_dependency_graph", return_value=graph
1888 )
1889 self.PatchObject(packages, "has_prebuilt", return_value=False)
1890 self.PatchObject(
1891 packages,
1892 "uprev_chrome",
1893 return_value=uprev_lib.UprevVersionedPackageResult(),
1894 )
Alex Klein6becabc2020-09-11 14:03:05 -06001895
Alex Klein1699fab2022-09-08 08:46:06 -06001896 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001897
Alex Klein1699fab2022-09-08 08:46:06 -06001898 result = packages.needs_chrome_source(build_target)
Alex Klein6becabc2020-09-11 14:03:05 -06001899
Alex Klein1699fab2022-09-08 08:46:06 -06001900 self.assertTrue(result.needs_chrome_source)
1901 self.assertFalse(result.builds_chrome)
1902 self.assertTrue(result.packages)
1903 self.assertEqual(
1904 set([p.atom for p in result.packages]),
1905 set(constants.OTHER_CHROME_PACKAGES),
1906 )
1907 self.assertFalse(result.missing_chrome_prebuilt)
1908 self.assertTrue(result.missing_follower_prebuilt)
1909 self.assertFalse(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001910
Alex Klein1699fab2022-09-08 08:46:06 -06001911 def test_has_prebuilts(self):
1912 """Test prebuilts prevent us from needing chrome source."""
1913 graph = self._build_graph(with_chrome=True, with_followers=True)
1914 self.PatchObject(
1915 depgraph, "get_sysroot_dependency_graph", return_value=graph
1916 )
1917 self.PatchObject(packages, "has_prebuilt", return_value=True)
1918 self.PatchObject(
1919 packages,
1920 "uprev_chrome",
1921 return_value=uprev_lib.UprevVersionedPackageResult(),
1922 )
Alex Klein6becabc2020-09-11 14:03:05 -06001923
Alex Klein1699fab2022-09-08 08:46:06 -06001924 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001925
Alex Klein1699fab2022-09-08 08:46:06 -06001926 result = packages.needs_chrome_source(build_target)
Alex Klein6becabc2020-09-11 14:03:05 -06001927
Alex Klein1699fab2022-09-08 08:46:06 -06001928 self.assertFalse(result.needs_chrome_source)
1929 self.assertTrue(result.builds_chrome)
1930 self.assertFalse(result.packages)
1931 self.assertFalse(result.missing_chrome_prebuilt)
1932 self.assertFalse(result.missing_follower_prebuilt)
1933 self.assertFalse(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001934
Alex Klein1699fab2022-09-08 08:46:06 -06001935 def test_compile_source(self):
1936 """Test compile source ignores prebuilts."""
1937 graph = self._build_graph(with_chrome=True, with_followers=True)
1938 self.PatchObject(
1939 depgraph, "get_sysroot_dependency_graph", return_value=graph
1940 )
1941 self.PatchObject(packages, "has_prebuilt", return_value=True)
1942 self.PatchObject(
1943 packages,
1944 "uprev_chrome",
1945 return_value=uprev_lib.UprevVersionedPackageResult(),
1946 )
Alex Klein6becabc2020-09-11 14:03:05 -06001947
Alex Klein1699fab2022-09-08 08:46:06 -06001948 build_target = build_target_lib.BuildTarget("build_target")
Alex Klein6becabc2020-09-11 14:03:05 -06001949
Alex Klein1699fab2022-09-08 08:46:06 -06001950 result = packages.needs_chrome_source(build_target, compile_source=True)
Alex Klein6becabc2020-09-11 14:03:05 -06001951
Alex Klein1699fab2022-09-08 08:46:06 -06001952 self.assertTrue(result.needs_chrome_source)
1953 self.assertTrue(result.builds_chrome)
1954 self.assertTrue(result.packages)
1955 self.assertEqual(
1956 len(result.packages), len(constants.OTHER_CHROME_PACKAGES) + 1
1957 )
1958 self.assertTrue(result.missing_chrome_prebuilt)
1959 self.assertTrue(result.missing_follower_prebuilt)
1960 self.assertFalse(result.local_uprev)
Alex Kleinde7b76d2021-07-12 12:28:44 -06001961
Alex Klein1699fab2022-09-08 08:46:06 -06001962 def test_local_uprev(self):
1963 """Test compile source ignores prebuilts."""
1964 graph = self._build_graph(with_chrome=True, with_followers=True)
1965 self.PatchObject(
1966 depgraph, "get_sysroot_dependency_graph", return_value=graph
1967 )
1968 self.PatchObject(packages, "has_prebuilt", return_value=False)
Alex Klein75110572021-07-14 10:44:39 -06001969
Alex Klein1699fab2022-09-08 08:46:06 -06001970 uprev_result = uprev_lib.UprevVersionedPackageResult()
1971 uprev_result.add_result("1.2.3.4", ["/tmp/foo"])
1972 self.PatchObject(packages, "uprev_chrome", return_value=uprev_result)
Alex Kleinde7b76d2021-07-12 12:28:44 -06001973
Alex Klein1699fab2022-09-08 08:46:06 -06001974 build_target = build_target_lib.BuildTarget("build_target")
Alex Kleinde7b76d2021-07-12 12:28:44 -06001975
Alex Klein1699fab2022-09-08 08:46:06 -06001976 result = packages.needs_chrome_source(build_target, compile_source=True)
Alex Kleinde7b76d2021-07-12 12:28:44 -06001977
Alex Klein1699fab2022-09-08 08:46:06 -06001978 self.assertTrue(result.needs_chrome_source)
1979 self.assertTrue(result.builds_chrome)
1980 self.assertTrue(result.packages)
1981 self.assertEqual(
1982 len(result.packages), len(constants.OTHER_CHROME_PACKAGES) + 1
1983 )
1984 self.assertTrue(result.missing_chrome_prebuilt)
1985 self.assertTrue(result.missing_follower_prebuilt)
1986 self.assertTrue(result.local_uprev)
Alex Klein6becabc2020-09-11 14:03:05 -06001987
1988
Ben Reich4f3fa1b2020-12-19 08:21:26 +00001989class UprevDrivefsTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06001990 """Tests for uprev_drivefs."""
Ben Reich4f3fa1b2020-12-19 08:21:26 +00001991
Alex Klein1699fab2022-09-08 08:46:06 -06001992 def setUp(self):
1993 self.refs = [
1994 GitRef(
1995 path="/chromeos/platform/drivefs-google3/",
1996 ref="refs/tags/drivefs_45.0.2",
1997 revision="123",
1998 )
1999 ]
2000 self.MOCK_DRIVEFS_EBUILD_PATH = "drivefs.45.0.2-r1.ebuild"
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002001
Alex Klein1699fab2022-09-08 08:46:06 -06002002 def revisionBumpOutcome(self, ebuild_path):
2003 return uprev_lib.UprevResult(
2004 uprev_lib.Outcome.REVISION_BUMP, [ebuild_path]
2005 )
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002006
Alex Klein1699fab2022-09-08 08:46:06 -06002007 def majorBumpOutcome(self, ebuild_path):
2008 return uprev_lib.UprevResult(
2009 uprev_lib.Outcome.VERSION_BUMP, [ebuild_path]
2010 )
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002011
Alex Klein1699fab2022-09-08 08:46:06 -06002012 def sameVersionOutcome(self):
2013 return uprev_lib.UprevResult(uprev_lib.Outcome.SAME_VERSION_EXISTS)
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002014
Alex Klein1699fab2022-09-08 08:46:06 -06002015 def test_latest_version_returns_none(self):
2016 """Test no refs were supplied"""
2017 output = packages.uprev_drivefs(None, [], None)
2018 self.assertFalse(output.uprevved)
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002019
Alex Klein1699fab2022-09-08 08:46:06 -06002020 def test_drivefs_uprev_fails(self):
2021 """Test a single ref is supplied."""
2022 self.PatchObject(
2023 uprev_lib,
2024 "uprev_workon_ebuild_to_version",
2025 side_effect=[None, None],
2026 )
2027 output = packages.uprev_drivefs(None, self.refs, None)
2028 self.assertFalse(output.uprevved)
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002029
Alex Klein1699fab2022-09-08 08:46:06 -06002030 def test_same_version_exists(self):
2031 """Test the same version exists uprev should not happen."""
2032 drivefs_outcome = self.sameVersionOutcome()
2033 self.PatchObject(
2034 uprev_lib,
2035 "uprev_workon_ebuild_to_version",
2036 side_effect=[drivefs_outcome],
2037 )
2038 output = packages.uprev_drivefs(None, self.refs, None)
2039 self.assertFalse(output.uprevved)
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002040
Alex Klein1699fab2022-09-08 08:46:06 -06002041 def test_revision_bump_both_packages(self):
2042 """Test both packages uprev, should succeed."""
2043 drivefs_outcome = self.revisionBumpOutcome(
2044 self.MOCK_DRIVEFS_EBUILD_PATH
2045 )
2046 self.PatchObject(
2047 uprev_lib,
2048 "uprev_workon_ebuild_to_version",
2049 side_effect=[drivefs_outcome],
2050 )
2051 output = packages.uprev_drivefs(None, self.refs, None)
2052 self.assertTrue(output.uprevved)
Ben Reich4f3fa1b2020-12-19 08:21:26 +00002053
Alex Klein1699fab2022-09-08 08:46:06 -06002054 def test_major_bump_both_packages(self):
2055 """Test both packages uprev, should succeed."""
2056 drivefs_outcome = self.majorBumpOutcome(self.MOCK_DRIVEFS_EBUILD_PATH)
2057 self.PatchObject(
2058 uprev_lib,
2059 "uprev_workon_ebuild_to_version",
2060 side_effect=[drivefs_outcome],
2061 )
2062 output = packages.uprev_drivefs(None, self.refs, None)
2063 self.assertTrue(output.uprevved)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002064
2065
Denis Nikitin63613e32022-09-09 22:26:50 -07002066class UprevKernelAfdo(cros_test_lib.RunCommandTempDirTestCase):
2067 """Tests for uprev_kernel_afdo."""
2068
2069 def setUp(self):
2070 # patch_ebuild_vars is tested separately.
2071 self.mock_patch = self.PatchObject(packages, "patch_ebuild_vars")
Denis Nikitin88ad5132022-09-28 12:10:01 -07002072 self.PatchObject(constants, "SOURCE_ROOT", new=self.tempdir)
Denis Nikitin63613e32022-09-09 22:26:50 -07002073 self.metadata_dir = os.path.join(
Denis Nikitin63613e32022-09-09 22:26:50 -07002074 "src",
2075 "third_party",
2076 "toolchain-utils",
2077 "afdo_metadata",
2078 )
Denis Nikitin88ad5132022-09-28 12:10:01 -07002079 osutils.SafeMakedirs(os.path.join(self.tempdir, self.metadata_dir))
Denis Nikitin63613e32022-09-09 22:26:50 -07002080
2081 def test_uprev_kernel_afdo_version(self):
2082 """Test kernel afdo version uprev."""
2083 json_files = {
2084 "kernel_afdo.json": (
2085 "{\n"
2086 ' "chromeos-kernel-5_4": {\n'
2087 ' "name": "R106-12345.0-0123456789"\n'
2088 " }\n"
2089 "}"
2090 ),
2091 "kernel_arm_afdo.json": (
2092 "{\n"
2093 ' "chromeos-kernel-5_15": {\n'
2094 ' "name": "R107-67890.0-0123456789"\n'
2095 " }\n"
2096 "}"
2097 ),
2098 }
2099 for f, contents in json_files.items():
2100 self.WriteTempFile(os.path.join(self.metadata_dir, f), contents)
2101
2102 returned_output = packages.uprev_kernel_afdo()
2103
Denis Nikitin88ad5132022-09-28 12:10:01 -07002104 package_root = os.path.join(
2105 constants.SOURCE_ROOT,
2106 constants.CHROMIUMOS_OVERLAY_DIR,
2107 "sys-kernel",
Denis Nikitin63613e32022-09-09 22:26:50 -07002108 )
2109 expect_result = [
2110 uprev_lib.UprevVersionedPackageModifications(
2111 new_version="R106-12345.0-0123456789",
2112 files=[
2113 os.path.join(
2114 package_root,
2115 "chromeos-kernel-5_4",
2116 "chromeos-kernel-5_4-9999.ebuild",
2117 ),
2118 os.path.join(
2119 package_root, "chromeos-kernel-5_4", "Manifest"
2120 ),
2121 ],
2122 ),
2123 uprev_lib.UprevVersionedPackageModifications(
2124 new_version="R107-67890.0-0123456789",
2125 files=[
2126 os.path.join(
2127 package_root,
2128 "chromeos-kernel-5_15",
2129 "chromeos-kernel-5_15-9999.ebuild",
2130 ),
2131 os.path.join(
2132 package_root, "chromeos-kernel-5_15", "Manifest"
2133 ),
2134 ],
2135 ),
2136 ]
2137 self.assertTrue(returned_output.uprevved)
2138 self.assertEqual(returned_output.modified, expect_result)
2139
2140 def test_uprev_kernel_afdo_empty_json(self):
2141 """Test kernel afdo version unchanged."""
2142 json_files = {
2143 "kernel_afdo.json": "{}",
2144 "kernel_arm_afdo.json": "{}",
2145 }
2146 for f, contents in json_files.items():
2147 self.WriteTempFile(os.path.join(self.metadata_dir, f), contents)
2148
2149 returned_output = packages.uprev_kernel_afdo()
2150 self.assertFalse(returned_output.uprevved)
2151
2152 def test_uprev_kernel_afdo_empty_file(self):
2153 """Test malformed json raises."""
2154 json_files = {
2155 "kernel_afdo.json": "",
2156 "kernel_arm_afdo.json": "",
2157 }
2158 for f, contents in json_files.items():
2159 self.WriteTempFile(os.path.join(self.metadata_dir, f), contents)
2160
2161 with self.assertRaisesRegex(
2162 json.decoder.JSONDecodeError, "Expecting value"
2163 ):
2164 packages.uprev_kernel_afdo()
2165
2166 def test_uprev_kernel_afdo_manifest_raises(self):
2167 """Test manifest update raises."""
2168 json_files = {
2169 "kernel_afdo.json": (
2170 "{\n"
2171 ' "chromeos-kernel-5_4": {\n'
2172 ' "name": "R106-12345.0-0123456789"\n'
2173 " }\n"
2174 "}"
2175 ),
2176 }
2177 for f, contents in json_files.items():
2178 self.WriteTempFile(os.path.join(self.metadata_dir, f), contents)
2179 # run() raises exception.
2180 self.rc.SetDefaultCmdResult(
2181 side_effect=cros_build_lib.RunCommandError("error")
2182 )
2183
2184 with self.assertRaises(uprev_lib.EbuildManifestError):
2185 packages.uprev_kernel_afdo()
2186
2187
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002188# TODO(chenghaoyang): Shouldn't use uprev_workon_ebuild_to_version.
2189class UprevPerfettoTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06002190 """Tests for uprev_perfetto."""
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002191
Alex Klein1699fab2022-09-08 08:46:06 -06002192 def setUp(self):
2193 self.refs = [GitRef(path="/foo", ref="refs/tags/v12.0", revision="123")]
2194 self.MOCK_PERFETTO_EBUILD_PATH = "perfetto-12.0-r1.ebuild"
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002195
Alex Klein1699fab2022-09-08 08:46:06 -06002196 def revisionBumpOutcome(self, ebuild_path):
2197 return uprev_lib.UprevResult(
2198 uprev_lib.Outcome.REVISION_BUMP, [ebuild_path]
2199 )
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002200
Alex Klein1699fab2022-09-08 08:46:06 -06002201 def majorBumpOutcome(self, ebuild_path):
2202 return uprev_lib.UprevResult(
2203 uprev_lib.Outcome.VERSION_BUMP, [ebuild_path]
2204 )
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002205
Alex Klein1699fab2022-09-08 08:46:06 -06002206 def newerVersionOutcome(self):
2207 return uprev_lib.UprevResult(uprev_lib.Outcome.NEWER_VERSION_EXISTS)
Harvey Yang3eee06c2021-03-18 15:47:56 +08002208
Alex Klein1699fab2022-09-08 08:46:06 -06002209 def sameVersionOutcome(self):
2210 return uprev_lib.UprevResult(uprev_lib.Outcome.SAME_VERSION_EXISTS)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002211
Alex Klein1699fab2022-09-08 08:46:06 -06002212 def test_latest_version_returns_none(self):
2213 """Test no refs were supplied"""
2214 output = packages.uprev_perfetto(None, [], None)
2215 self.assertFalse(output.uprevved)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002216
Alex Klein1699fab2022-09-08 08:46:06 -06002217 def test_perfetto_uprev_fails(self):
2218 """Test a single ref is supplied."""
2219 self.PatchObject(
2220 uprev_lib, "uprev_workon_ebuild_to_version", side_effect=[None]
2221 )
2222 output = packages.uprev_perfetto(None, self.refs, None)
2223 self.assertFalse(output.uprevved)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002224
Alex Klein1699fab2022-09-08 08:46:06 -06002225 def test_newer_version_exists(self):
2226 """Test the newer version exists uprev should not happen."""
2227 perfetto_outcome = self.newerVersionOutcome()
2228 self.PatchObject(
2229 uprev_lib,
2230 "uprev_workon_ebuild_to_version",
2231 side_effect=[perfetto_outcome],
2232 )
2233 output = packages.uprev_perfetto(None, self.refs, None)
2234 self.assertFalse(output.uprevved)
Harvey Yang3eee06c2021-03-18 15:47:56 +08002235
Alex Klein1699fab2022-09-08 08:46:06 -06002236 def test_same_version_exists(self):
2237 """Test the same version exists uprev should not happen."""
2238 perfetto_outcome = self.sameVersionOutcome()
2239 self.PatchObject(
2240 uprev_lib,
2241 "uprev_workon_ebuild_to_version",
2242 side_effect=[perfetto_outcome],
2243 )
2244 output = packages.uprev_perfetto(None, self.refs, None)
2245 self.assertFalse(output.uprevved)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002246
Alex Klein1699fab2022-09-08 08:46:06 -06002247 def test_revision_bump_perfetto_package(self):
2248 """Test perfetto package uprev."""
2249 perfetto_outcome = self.revisionBumpOutcome(
2250 self.MOCK_PERFETTO_EBUILD_PATH
2251 )
2252 self.PatchObject(
2253 uprev_lib,
2254 "uprev_workon_ebuild_to_version",
2255 side_effect=[perfetto_outcome],
2256 )
2257 output = packages.uprev_perfetto(None, self.refs, None)
2258 self.assertTrue(output.uprevved)
Harvey Yang9c61e9c2021-03-02 16:32:43 +08002259
Alex Klein1699fab2022-09-08 08:46:06 -06002260 def test_major_bump_perfetto_package(self):
2261 """Test perfetto package uprev."""
2262 perfetto_outcome = self.majorBumpOutcome(self.MOCK_PERFETTO_EBUILD_PATH)
2263 self.PatchObject(
2264 uprev_lib,
2265 "uprev_workon_ebuild_to_version",
2266 side_effect=[perfetto_outcome],
2267 )
2268 output = packages.uprev_perfetto(None, self.refs, None)
2269 self.assertTrue(output.uprevved)
Julio Hurtadof1befec2021-05-05 21:34:26 +00002270
Chinglin Yuad12a512022-10-07 17:26:12 +08002271 def test_revision_bump_trunk(self):
2272 """Test revision bump on receiving non-versioned trunk refs."""
Chinglin Yu5de28a42022-11-11 19:52:21 +08002273 refs = [
2274 GitRef(
2275 path="/foo", ref="refs/heads/main", revision="0123456789abcdef"
2276 )
2277 ]
Chinglin Yuad12a512022-10-07 17:26:12 +08002278 perfetto_outcome = self.revisionBumpOutcome(
2279 self.MOCK_PERFETTO_EBUILD_PATH
2280 )
2281 self.PatchObject(
2282 uprev_lib, "get_stable_ebuild_version", return_value="12.0"
2283 )
2284 self.PatchObject(
2285 uprev_lib,
2286 "uprev_workon_ebuild_to_version",
2287 side_effect=[perfetto_outcome],
2288 )
2289 output = packages.uprev_perfetto(None, refs, None)
2290 self.assertTrue(output.uprevved)
Chinglin Yu5de28a42022-11-11 19:52:21 +08002291 self.assertEqual(output.modified[0].new_version, "12.0-012345678")
Chinglin Yuad12a512022-10-07 17:26:12 +08002292
Alex Klein627e04c2021-11-10 15:56:47 -07002293
Julio Hurtadof1befec2021-05-05 21:34:26 +00002294class UprevLacrosTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06002295 """Tests for uprev_lacros"""
Julio Hurtadof1befec2021-05-05 21:34:26 +00002296
Alex Klein1699fab2022-09-08 08:46:06 -06002297 def setUp(self):
2298 self.refs = [
2299 GitRef(
2300 path="/lacros", ref="refs/heads/main", revision="123.456.789.0"
2301 )
2302 ]
2303 self.MOCK_LACROS_EBUILD_PATH = "chromeos-lacros-123.456.789.0-r1.ebuild"
Julio Hurtadof1befec2021-05-05 21:34:26 +00002304
Alex Klein1699fab2022-09-08 08:46:06 -06002305 def revisionBumpOutcome(self, ebuild_path):
2306 return uprev_lib.UprevResult(
2307 uprev_lib.Outcome.REVISION_BUMP, [ebuild_path]
2308 )
Julio Hurtadof1befec2021-05-05 21:34:26 +00002309
Alex Klein1699fab2022-09-08 08:46:06 -06002310 def majorBumpOutcome(self, ebuild_path):
2311 return uprev_lib.UprevResult(
2312 uprev_lib.Outcome.VERSION_BUMP, [ebuild_path]
2313 )
Julio Hurtadof1befec2021-05-05 21:34:26 +00002314
Alex Klein1699fab2022-09-08 08:46:06 -06002315 def newerVersionOutcome(self, ebuild_path):
2316 return uprev_lib.UprevResult(
2317 uprev_lib.Outcome.NEWER_VERSION_EXISTS, [ebuild_path]
2318 )
Julio Hurtadoa994e002021-07-07 17:57:45 +00002319
Alex Klein1699fab2022-09-08 08:46:06 -06002320 def sameVersionOutcome(self, ebuild_path):
2321 return uprev_lib.UprevResult(
2322 uprev_lib.Outcome.SAME_VERSION_EXISTS, [ebuild_path]
2323 )
Julio Hurtadoa994e002021-07-07 17:57:45 +00002324
Alex Klein1699fab2022-09-08 08:46:06 -06002325 def newEbuildCreatedOutcome(self, ebuild_path):
2326 return uprev_lib.UprevResult(
2327 uprev_lib.Outcome.NEW_EBUILD_CREATED, [ebuild_path]
2328 )
Julio Hurtadof1befec2021-05-05 21:34:26 +00002329
Alex Klein1699fab2022-09-08 08:46:06 -06002330 def test_lacros_uprev_fails(self):
2331 """Test a lacros package uprev with no triggers"""
2332 self.PatchObject(
2333 uprev_lib, "uprev_workon_ebuild_to_version", side_effect=[None]
2334 )
2335 with self.assertRaises(IndexError):
2336 packages.uprev_lacros(None, [], None)
Julio Hurtadof1befec2021-05-05 21:34:26 +00002337
Alex Klein1699fab2022-09-08 08:46:06 -06002338 def test_lacros_uprev_revision_bump(self):
2339 """Test lacros package uprev."""
2340 lacros_outcome = self.revisionBumpOutcome(self.MOCK_LACROS_EBUILD_PATH)
2341 self.PatchObject(
2342 uprev_lib,
2343 "uprev_workon_ebuild_to_version",
2344 side_effect=[lacros_outcome],
2345 )
2346 output = packages.uprev_lacros(None, self.refs, None)
2347 self.assertTrue(output.uprevved)
Julio Hurtadof1befec2021-05-05 21:34:26 +00002348
Alex Klein1699fab2022-09-08 08:46:06 -06002349 def test_lacros_uprev_version_bump(self):
2350 """Test lacros package uprev."""
2351 lacros_outcome = self.majorBumpOutcome(self.MOCK_LACROS_EBUILD_PATH)
2352 self.PatchObject(
2353 uprev_lib,
2354 "uprev_workon_ebuild_to_version",
2355 side_effect=[lacros_outcome],
2356 )
2357 output = packages.uprev_lacros(None, self.refs, None)
2358 self.assertTrue(output.uprevved)
Julio Hurtadof1befec2021-05-05 21:34:26 +00002359
Alex Klein1699fab2022-09-08 08:46:06 -06002360 def test_lacros_uprev_new_ebuild_created(self):
2361 """Test lacros package uprev."""
2362 lacros_outcome = self.newEbuildCreatedOutcome(
2363 self.MOCK_LACROS_EBUILD_PATH
2364 )
2365 self.PatchObject(
2366 uprev_lib,
2367 "uprev_workon_ebuild_to_version",
2368 side_effect=[lacros_outcome],
2369 )
2370 output = packages.uprev_lacros(None, self.refs, None)
2371 self.assertTrue(output.uprevved)
Julio Hurtadoa994e002021-07-07 17:57:45 +00002372
Alex Klein1699fab2022-09-08 08:46:06 -06002373 def test_lacros_uprev_newer_version_exist(self):
2374 """Test the newer version exists uprev should not happen."""
2375 lacros_outcome = self.newerVersionOutcome(self.MOCK_LACROS_EBUILD_PATH)
2376 self.PatchObject(
2377 uprev_lib,
2378 "uprev_workon_ebuild_to_version",
2379 side_effect=[lacros_outcome],
2380 )
2381 output = packages.uprev_lacros(None, self.refs, None)
2382 self.assertFalse(output.uprevved)
Julio Hurtadoa994e002021-07-07 17:57:45 +00002383
Alex Klein1699fab2022-09-08 08:46:06 -06002384 def test_lacros_uprev_same_version_exist(self):
2385 """Test the same version exists uprev should not happen."""
2386 lacros_outcome = self.sameVersionOutcome(self.MOCK_LACROS_EBUILD_PATH)
2387 self.PatchObject(
2388 uprev_lib,
2389 "uprev_workon_ebuild_to_version",
2390 side_effect=[lacros_outcome],
2391 )
2392 output = packages.uprev_lacros(None, self.refs, None)
2393 self.assertFalse(output.uprevved)
Julio Hurtado870ed322021-12-03 18:22:40 +00002394
2395
2396class UprevLacrosInParallelTest(cros_test_lib.MockTestCase):
Alex Klein1699fab2022-09-08 08:46:06 -06002397 """Tests for uprev_lacros"""
Julio Hurtado870ed322021-12-03 18:22:40 +00002398
Alex Klein1699fab2022-09-08 08:46:06 -06002399 def setUp(self):
2400 self.refs = [
2401 GitRef(
2402 path="/lacros", revision="abc123", ref="refs/tags/123.456.789.0"
2403 )
2404 ]
2405 self.MOCK_LACROS_EBUILD_PATH = "chromeos-lacros-123.456.789.0-r1.ebuild"
Julio Hurtado870ed322021-12-03 18:22:40 +00002406
Alex Klein1699fab2022-09-08 08:46:06 -06002407 def revisionBumpOutcome(self, ebuild_path):
2408 return uprev_lib.UprevResult(
2409 uprev_lib.Outcome.REVISION_BUMP, [ebuild_path]
2410 )
Julio Hurtado870ed322021-12-03 18:22:40 +00002411
Alex Klein1699fab2022-09-08 08:46:06 -06002412 def majorBumpOutcome(self, ebuild_path):
2413 return uprev_lib.UprevResult(
2414 uprev_lib.Outcome.VERSION_BUMP, [ebuild_path]
2415 )
Julio Hurtado870ed322021-12-03 18:22:40 +00002416
Alex Klein1699fab2022-09-08 08:46:06 -06002417 def newerVersionOutcome(self, ebuild_path):
2418 return uprev_lib.UprevResult(
2419 uprev_lib.Outcome.NEWER_VERSION_EXISTS, [ebuild_path]
2420 )
Julio Hurtado870ed322021-12-03 18:22:40 +00002421
Alex Klein1699fab2022-09-08 08:46:06 -06002422 def sameVersionOutcome(self, ebuild_path):
2423 return uprev_lib.UprevResult(
2424 uprev_lib.Outcome.SAME_VERSION_EXISTS, [ebuild_path]
2425 )
Julio Hurtado870ed322021-12-03 18:22:40 +00002426
Alex Klein1699fab2022-09-08 08:46:06 -06002427 def newEbuildCreatedOutcome(self, ebuild_path):
2428 return uprev_lib.UprevResult(
2429 uprev_lib.Outcome.NEW_EBUILD_CREATED, [ebuild_path]
2430 )
Julio Hurtado870ed322021-12-03 18:22:40 +00002431
Alex Klein1699fab2022-09-08 08:46:06 -06002432 def test_lacros_uprev_fails(self):
2433 """Test a lacros package uprev with no triggers"""
2434 self.PatchObject(
2435 uprev_lib, "uprev_workon_ebuild_to_version", side_effect=[None]
2436 )
Alex Klein314fb5d2022-10-24 14:56:31 -06002437 with self.assertRaises(uprev_lib.NoRefsError):
Alex Klein1699fab2022-09-08 08:46:06 -06002438 packages.uprev_lacros_in_parallel(None, [], None)
Julio Hurtado870ed322021-12-03 18:22:40 +00002439
Alex Klein1699fab2022-09-08 08:46:06 -06002440 def test_lacros_uprev_revision_bump(self):
2441 """Test lacros package uprev."""
2442 lacros_outcome = self.revisionBumpOutcome(self.MOCK_LACROS_EBUILD_PATH)
2443 self.PatchObject(
2444 uprev_lib,
2445 "uprev_workon_ebuild_to_version",
2446 side_effect=[lacros_outcome],
2447 )
2448 output = packages.uprev_lacros_in_parallel(None, self.refs, None)
2449 self.assertTrue(output.uprevved)
Julio Hurtado870ed322021-12-03 18:22:40 +00002450
Alex Klein1699fab2022-09-08 08:46:06 -06002451 def test_lacros_uprev_version_bump(self):
2452 """Test lacros package uprev."""
2453 lacros_outcome = self.majorBumpOutcome(self.MOCK_LACROS_EBUILD_PATH)
2454 self.PatchObject(
2455 uprev_lib,
2456 "uprev_workon_ebuild_to_version",
2457 side_effect=[lacros_outcome],
2458 )
2459 output = packages.uprev_lacros_in_parallel(None, self.refs, None)
2460 self.assertTrue(output.uprevved)
Julio Hurtado870ed322021-12-03 18:22:40 +00002461
Alex Klein1699fab2022-09-08 08:46:06 -06002462 def test_lacros_uprev_new_ebuild_created(self):
2463 """Test lacros package uprev."""
2464 lacros_outcome = self.newEbuildCreatedOutcome(
2465 self.MOCK_LACROS_EBUILD_PATH
2466 )
2467 self.PatchObject(
2468 uprev_lib,
2469 "uprev_workon_ebuild_to_version",
2470 side_effect=[lacros_outcome],
2471 )
2472 output = packages.uprev_lacros_in_parallel(None, self.refs, None)
2473 self.assertTrue(output.uprevved)
Julio Hurtado870ed322021-12-03 18:22:40 +00002474
Alex Klein1699fab2022-09-08 08:46:06 -06002475 def test_lacros_uprev_newer_version_exist(self):
2476 """Test the newer version exists uprev should not happen."""
2477 lacros_outcome = self.newerVersionOutcome(self.MOCK_LACROS_EBUILD_PATH)
2478 self.PatchObject(
2479 uprev_lib,
2480 "uprev_workon_ebuild_to_version",
2481 side_effect=[lacros_outcome],
2482 )
2483 output = packages.uprev_lacros_in_parallel(None, self.refs, None)
2484 self.assertFalse(output.uprevved)
Julio Hurtado870ed322021-12-03 18:22:40 +00002485
Alex Klein1699fab2022-09-08 08:46:06 -06002486 def test_lacros_uprev_same_version_exist(self):
2487 """Test the same version exists uprev should not happen."""
2488 lacros_outcome = self.sameVersionOutcome(self.MOCK_LACROS_EBUILD_PATH)
2489 self.PatchObject(
2490 uprev_lib,
2491 "uprev_workon_ebuild_to_version",
2492 side_effect=[lacros_outcome],
2493 )
2494 output = packages.uprev_lacros_in_parallel(None, self.refs, None)
2495 self.assertFalse(output.uprevved)