blob: 56db4abdc1390fa1b359f4ac70e862d601e1b5c8 [file] [log] [blame]
Alex Kleineb77ffa2019-05-28 14:47:44 -06001# -*- coding: utf-8 -*-
2# Copyright 2019 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""packages controller unit tests."""
7
8from __future__ import print_function
9
10import mock
11
Alex Klein231d2da2019-07-22 16:44:45 -060012from chromite.api import api_config
Alex Kleineb77ffa2019-05-28 14:47:44 -060013from chromite.api.controller import packages as packages_controller
14from chromite.api.gen.chromite.api import binhost_pb2
15from chromite.api.gen.chromite.api import packages_pb2
16from chromite.lib import constants
17from chromite.lib import cros_build_lib
18from chromite.lib import cros_test_lib
David Burger1e0fe232019-07-01 14:52:07 -060019from chromite.lib import portage_util
Alex Kleineb77ffa2019-05-28 14:47:44 -060020from chromite.service import packages as packages_service
21
22
Alex Klein231d2da2019-07-22 16:44:45 -060023class UprevTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin):
Alex Kleineb77ffa2019-05-28 14:47:44 -060024 """Uprev tests."""
25
26 _PUBLIC = binhost_pb2.OVERLAYTYPE_PUBLIC
27 _PRIVATE = binhost_pb2.OVERLAYTYPE_PRIVATE
28 _BOTH = binhost_pb2.OVERLAYTYPE_BOTH
29 _NONE = binhost_pb2.OVERLAYTYPE_NONE
30
31 def setUp(self):
32 self.uprev_patch = self.PatchObject(packages_service, 'uprev_build_targets')
Alex Klein231d2da2019-07-22 16:44:45 -060033 self.response = packages_pb2.UprevPackagesResponse()
Alex Kleineb77ffa2019-05-28 14:47:44 -060034
35 def _GetRequest(self, targets=None, overlay_type=None, output_dir=None):
36 return packages_pb2.UprevPackagesRequest(
37 build_targets=[{'name': name} for name in targets or []],
38 overlay_type=overlay_type,
39 output_dir=output_dir,
40 )
41
Alex Klein231d2da2019-07-22 16:44:45 -060042 def testValidateOnly(self):
43 """Sanity check that a validate only call does not execute any logic."""
44 patch = self.PatchObject(packages_service, 'uprev_build_targets')
45
46 targets = ['foo', 'bar']
47 request = self._GetRequest(targets=targets, overlay_type=self._BOTH)
48 packages_controller.Uprev(request, self.response, self.validate_only_config)
49 patch.assert_not_called()
Alex Kleineb77ffa2019-05-28 14:47:44 -060050
51 def testNoOverlayTypeFails(self):
52 """No overlay type provided should fail."""
53 request = self._GetRequest(targets=['foo'])
Alex Kleineb77ffa2019-05-28 14:47:44 -060054
55 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -060056 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060057
58 def testOverlayTypeNoneFails(self):
59 """Overlay type none means nothing here and should fail."""
60 request = self._GetRequest(targets=['foo'], overlay_type=self._NONE)
Alex Kleineb77ffa2019-05-28 14:47:44 -060061
62 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -060063 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060064
65 def testSuccess(self):
66 """Test overall successful argument handling."""
67 targets = ['foo', 'bar']
68 output_dir = '/tmp/uprev_output_dir'
Alex Klein5dd6b1e2019-07-31 15:45:24 -060069 changed = ['/ebuild-1.0-r1.ebuild', '/ebuild-1.0-r2.ebuild']
Alex Kleineb77ffa2019-05-28 14:47:44 -060070 expected_type = constants.BOTH_OVERLAYS
71 request = self._GetRequest(targets=targets, overlay_type=self._BOTH,
72 output_dir=output_dir)
Alex Klein5dd6b1e2019-07-31 15:45:24 -060073 uprev_patch = self.PatchObject(packages_service, 'uprev_build_targets',
74 return_value=changed)
Alex Kleineb77ffa2019-05-28 14:47:44 -060075
Alex Klein231d2da2019-07-22 16:44:45 -060076 packages_controller.Uprev(request, self.response, self.api_config)
Alex Kleineb77ffa2019-05-28 14:47:44 -060077
78 # Make sure the type is right, verify build targets after.
79 uprev_patch.assert_called_once_with(mock.ANY, expected_type, mock.ANY,
80 output_dir)
81 # First argument (build targets) of the first (only) call.
82 call_targets = uprev_patch.call_args[0][0]
83 self.assertItemsEqual(targets, [t.name for t in call_targets])
David Burger1e0fe232019-07-01 14:52:07 -060084
Alex Klein231d2da2019-07-22 16:44:45 -060085 for ebuild in self.response.modified_ebuilds:
Alex Klein5dd6b1e2019-07-31 15:45:24 -060086 self.assertIn(ebuild.path, changed)
87 changed.remove(ebuild.path)
88 self.assertFalse(changed)
89
David Burger1e0fe232019-07-01 14:52:07 -060090
Alex Klein87531182019-08-12 15:23:37 -060091class UprevVersionedPackageTest(cros_test_lib.MockTestCase,
92 api_config.ApiConfigMixin):
93 """UprevVersionedPackage tests."""
94
95 def setUp(self):
96 self.response = packages_pb2.UprevPackagesResponse()
97
98 def _addVersion(self, request, version):
99 """Helper method to add a full version message to the request."""
100 ref = request.versions.add()
101 ref.repository = '/some/path'
Alex Klein34afcbc2019-08-22 16:14:31 -0600102 ref.ref = 'refs/tags/%s' % version
Alex Klein87531182019-08-12 15:23:37 -0600103 ref.revision = 'abc123'
104
105 def testValidateOnly(self):
106 """Sanity check validate only calls are working properly."""
107 service = self.PatchObject(packages_service, 'uprev_versioned_package')
108
109 request = packages_pb2.UprevVersionedPackageRequest()
110 self._addVersion(request, '1.2.3.4')
111 request.package_info.category = 'chromeos-base'
112 request.package_info.package_name = 'chromeos-chrome'
113
114 packages_controller.UprevVersionedPackage(request, self.response,
115 self.validate_only_config)
116
117 service.assert_not_called()
118
119 def testNoVersions(self):
120 """Test no versions provided."""
121 request = packages_pb2.UprevVersionedPackageRequest()
122 request.package_info.category = 'chromeos-base'
123 request.package_info.package_name = 'chromeos-chrome'
124
125 with self.assertRaises(cros_build_lib.DieSystemExit):
126 packages_controller.UprevVersionedPackage(request, self.response,
127 self.api_config)
128
129 def testNoPackageName(self):
130 """Test no package name provided."""
131 request = packages_pb2.UprevVersionedPackageRequest()
132 self._addVersion(request, '1.2.3.4')
133 request.package_info.category = 'chromeos-base'
134
135 with self.assertRaises(cros_build_lib.DieSystemExit):
136 packages_controller.UprevVersionedPackage(request, self.response,
137 self.api_config)
138
139 def testNoCategory(self):
140 """Test no package category provided."""
141 request = packages_pb2.UprevVersionedPackageRequest()
142 self._addVersion(request, '1.2.3.4')
143 request.package_info.package_name = 'chromeos-chrome'
144
145 with self.assertRaises(cros_build_lib.DieSystemExit):
146 packages_controller.UprevVersionedPackage(request, self.response,
147 self.api_config)
148
149 def testOutputHandling(self):
150 """Test the modified files are getting correctly added to the output."""
Alex Klein34afcbc2019-08-22 16:14:31 -0600151 version = '1.2.3.4'
152 result = packages_service.UprevVersionedPackageResult(
153 version, ['/file/one', '/file/two'])
154 self.PatchObject(
155 packages_service, 'uprev_versioned_package', return_value=result)
Alex Klein87531182019-08-12 15:23:37 -0600156
157 request = packages_pb2.UprevVersionedPackageRequest()
Alex Klein34afcbc2019-08-22 16:14:31 -0600158 self._addVersion(request, version)
Alex Klein87531182019-08-12 15:23:37 -0600159 request.package_info.category = 'chromeos-base'
160 request.package_info.package_name = 'chromeos-chrome'
161
162 packages_controller.UprevVersionedPackage(request, self.response,
163 self.api_config)
164
Alex Klein34afcbc2019-08-22 16:14:31 -0600165 self.assertEqual(version, self.response.version)
Alex Klein87531182019-08-12 15:23:37 -0600166 self.assertItemsEqual(
Alex Klein34afcbc2019-08-22 16:14:31 -0600167 result.modified_ebuilds,
168 [ebuild.path for ebuild in self.response.modified_ebuilds])
Alex Klein87531182019-08-12 15:23:37 -0600169
170
Alex Klein231d2da2019-07-22 16:44:45 -0600171class GetBestVisibleTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin):
David Burger1e0fe232019-07-01 14:52:07 -0600172 """GetBestVisible tests."""
173
Alex Klein231d2da2019-07-22 16:44:45 -0600174 def setUp(self):
175 self.response = packages_pb2.GetBestVisibleResponse()
176
David Burger1e0fe232019-07-01 14:52:07 -0600177 def _GetRequest(self, atom=None):
178 return packages_pb2.GetBestVisibleRequest(
179 atom=atom,
180 )
181
David Burger1e0fe232019-07-01 14:52:07 -0600182 def _MakeCpv(self, category, package, version):
183 unused = {
184 'cp': None,
185 'cpv': None,
186 'cpf': None,
187 'pv': None,
188 'version_no_rev': None,
189 'rev': None,
190 }
191 return portage_util.CPV(
192 category=category,
193 package=package,
194 version=version,
195 **unused
196 )
197
Alex Klein231d2da2019-07-22 16:44:45 -0600198 def testValidateOnly(self):
199 """Sanity check that a validate only call does not execute any logic."""
200 patch = self.PatchObject(packages_service, 'get_best_visible')
201
202 request = self._GetRequest(atom='chromeos-chrome')
203 packages_controller.GetBestVisible(request, self.response,
204 self.validate_only_config)
205 patch.assert_not_called()
206
David Burger1e0fe232019-07-01 14:52:07 -0600207 def testNoAtomFails(self):
208 """No atom provided should fail."""
209 request = self._GetRequest()
David Burger1e0fe232019-07-01 14:52:07 -0600210 with self.assertRaises(cros_build_lib.DieSystemExit):
Alex Klein231d2da2019-07-22 16:44:45 -0600211 packages_controller.GetBestVisible(request, self.response,
212 self.api_config)
David Burger1e0fe232019-07-01 14:52:07 -0600213
214 def testSuccess(self):
215 """Test overall success, argument handling, result forwarding."""
216 cpv = self._MakeCpv('category', 'package', 'version')
217 self.PatchObject(packages_service, 'get_best_visible', return_value=cpv)
218
219 request = self._GetRequest(atom='chromeos-chrome')
David Burger1e0fe232019-07-01 14:52:07 -0600220
Alex Klein231d2da2019-07-22 16:44:45 -0600221 packages_controller.GetBestVisible(request, self.response, self.api_config)
David Burger1e0fe232019-07-01 14:52:07 -0600222
Alex Klein231d2da2019-07-22 16:44:45 -0600223 package_info = self.response.package_info
David Burger1e0fe232019-07-01 14:52:07 -0600224 self.assertEqual(package_info.category, cpv.category)
225 self.assertEqual(package_info.package_name, cpv.package)
226 self.assertEqual(package_info.version, cpv.version)