LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 1 | # Copyright 2019 The Chromium OS Authors. All rights reserved. |
| 2 | # Use of this source code is governed by a BSD-style license that can be |
| 3 | # found in the LICENSE file. |
| 4 | |
| 5 | """Unittests for Android operations.""" |
| 6 | |
Mike Frysinger | 166fea0 | 2021-02-12 05:30:33 -0500 | [diff] [blame] | 7 | from unittest import mock |
| 8 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 9 | from chromite.api import api_config |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 10 | from chromite.api.controller import android |
| 11 | from chromite.api.gen.chromite.api import android_pb2 |
| 12 | from chromite.api.gen.chromiumos import common_pb2 |
Mike Frysinger | 40ffb53 | 2021-02-12 07:36:08 -0500 | [diff] [blame] | 13 | from chromite.lib import build_target_lib |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 14 | from chromite.lib import constants |
| 15 | from chromite.lib import cros_build_lib |
| 16 | from chromite.lib import cros_test_lib |
| 17 | from chromite.lib import osutils |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 18 | from chromite.service import android as service_android |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 19 | from chromite.service import packages |
| 20 | |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 21 | |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 22 | class GetLatestBuildTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin): |
| 23 | """Unittests for GetLatestBuild.""" |
| 24 | |
| 25 | def setUp(self): |
| 26 | self._mock = self.PatchObject(service_android, 'GetLatestBuild') |
| 27 | self._mock.return_value = ('7123456', {}) |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 28 | self._mock_branch_for_package = self.PatchObject( |
| 29 | service_android, 'GetAndroidBranchForPackage', |
| 30 | return_value='android-branch-for-package') |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 31 | self._output_proto = android_pb2.GetLatestBuildResponse() |
| 32 | |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 33 | def _GetRequest(self, android_build_branch=None, android_package=None): |
| 34 | req = android_pb2.GetLatestBuildRequest() |
| 35 | if android_build_branch is not None: |
| 36 | req.android_build_branch = android_build_branch |
| 37 | if android_package is not None: |
| 38 | req.android_package = android_package |
| 39 | return req |
| 40 | |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 41 | def testValidateOnly(self): |
| 42 | """Test that a validate only call does not execute any logic.""" |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 43 | req = self._GetRequest(android_package='android-package') |
| 44 | android.GetLatestBuild(req, self._output_proto, self.validate_only_config) |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 45 | self._mock.assert_not_called() |
| 46 | |
| 47 | def testMockCall(self): |
| 48 | """Test that a mock call does not execute logic, returns mocked value.""" |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 49 | req = self._GetRequest(android_package='android-package') |
| 50 | android.GetLatestBuild(req, self._output_proto, self.mock_call_config) |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 51 | self._mock.assert_not_called() |
| 52 | self.assertEqual(self._output_proto.android_version, '7123456') |
| 53 | |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 54 | def testFailsIfBranchAndPackageMissing(self): |
| 55 | """Fails if both android_build_branch and android_package are missing.""" |
| 56 | req = self._GetRequest() |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 57 | with self.assertRaises(cros_build_lib.DieSystemExit): |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 58 | android.GetLatestBuild(req, self._output_proto, self.api_config) |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 59 | self._mock.assert_not_called() |
| 60 | |
Shao-Chuan Lee | 6e8784a | 2021-05-13 09:34:46 +0900 | [diff] [blame] | 61 | def testBranchSpecified(self): |
| 62 | """Test calling with Android branch specified.""" |
| 63 | req = self._GetRequest(android_build_branch='android-branch') |
| 64 | android.GetLatestBuild(req, self._output_proto, self.api_config) |
| 65 | self._mock.assert_called_once_with('android-branch') |
| 66 | self._mock_branch_for_package.assert_not_called() |
| 67 | self.assertEqual(self._output_proto.android_version, '7123456') |
| 68 | |
| 69 | def testPackageSpecified(self): |
| 70 | """Test calling with Android package specified.""" |
| 71 | req = self._GetRequest(android_package='android-package') |
| 72 | android.GetLatestBuild(req, self._output_proto, self.api_config) |
| 73 | self._mock.assert_called_once_with('android-branch-for-package') |
| 74 | self._mock_branch_for_package.assert_called_once_with('android-package') |
| 75 | self.assertEqual(self._output_proto.android_version, '7123456') |
| 76 | |
| 77 | def testBranchAndPackageSpecified(self): |
| 78 | """Test calling with both Android branch and package specified.""" |
| 79 | req = self._GetRequest(android_build_branch='android-branch', |
| 80 | android_package='android-package') |
| 81 | android.GetLatestBuild(req, self._output_proto, self.api_config) |
| 82 | self._mock.assert_called_once_with('android-branch') |
| 83 | self._mock_branch_for_package.assert_not_called() |
Shao-Chuan Lee | 01dee22 | 2021-04-09 15:28:08 +0900 | [diff] [blame] | 84 | self.assertEqual(self._output_proto.android_version, '7123456') |
| 85 | |
| 86 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 87 | class MarkStableTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin): |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 88 | """Unittests for MarkStable.""" |
| 89 | |
| 90 | def setUp(self): |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 91 | self.uprev = self.PatchObject(packages, 'uprev_android') |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 92 | |
| 93 | self.input_proto = android_pb2.MarkStableRequest() |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 94 | self.input_proto.package_name = 'android-package-name' |
| 95 | self.input_proto.android_build_branch = 'android_build_branch' |
Shao-Chuan Lee | a4b4f30 | 2021-05-12 14:40:20 +0900 | [diff] [blame] | 96 | self.input_proto.android_version = 'android-version' |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 97 | self.input_proto.build_targets.add().name = 'foo' |
| 98 | self.input_proto.build_targets.add().name = 'bar' |
Shao-Chuan Lee | 85ba7ce | 2021-02-09 13:50:11 +0900 | [diff] [blame] | 99 | self.input_proto.skip_commit = True |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 100 | |
Alex Klein | 26e472b | 2020-03-10 14:35:01 -0600 | [diff] [blame] | 101 | self.build_targets = [build_target_lib.BuildTarget('foo'), |
| 102 | build_target_lib.BuildTarget('bar')] |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 103 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 104 | self.response = android_pb2.MarkStableResponse() |
| 105 | |
| 106 | def testValidateOnly(self): |
| 107 | """Sanity check that a validate only call does not execute any logic.""" |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 108 | android.MarkStable(self.input_proto, self.response, |
| 109 | self.validate_only_config) |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 110 | self.uprev.assert_not_called() |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 111 | |
Michael Mortensen | 2562644 | 2019-11-22 10:06:59 -0700 | [diff] [blame] | 112 | def testMockCall(self): |
| 113 | """Test that a mock call does not execute logic, returns mocked value.""" |
| 114 | android.MarkStable(self.input_proto, self.response, |
| 115 | self.mock_call_config) |
| 116 | self.uprev.assert_not_called() |
| 117 | self.assertEqual(self.response.status, |
| 118 | android_pb2.MARK_STABLE_STATUS_SUCCESS) |
| 119 | self.assertEqual(self.response.android_atom.category, 'category') |
| 120 | self.assertEqual(self.response.android_atom.package_name, |
| 121 | 'android-package-name') |
| 122 | self.assertEqual(self.response.android_atom.version, '1.2') |
| 123 | |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 124 | def testFailsIfPackageNameMissing(self): |
| 125 | """Fails if package_name is missing.""" |
| 126 | self.input_proto.package_name = '' |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 127 | with self.assertRaises(cros_build_lib.DieSystemExit): |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 128 | android.MarkStable(self.input_proto, self.response, self.api_config) |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 129 | self.uprev.assert_not_called() |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 130 | |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 131 | def testCallsCommandCorrectly(self): |
| 132 | """Test that commands.MarkAndroidAsStable is called correctly.""" |
Shao-Chuan Lee | 84bf9a2 | 2021-11-19 17:42:11 +0900 | [diff] [blame] | 133 | self.uprev.return_value = packages.UprevAndroidResult( |
| 134 | revved=True, |
| 135 | android_atom='cat/android-1.2.3') |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 136 | atom = common_pb2.PackageInfo() |
| 137 | atom.category = 'cat' |
| 138 | atom.package_name = 'android' |
| 139 | atom.version = '1.2.3' |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 140 | android.MarkStable(self.input_proto, self.response, self.api_config) |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 141 | self.uprev.assert_called_once_with( |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 142 | android_package=self.input_proto.package_name, |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 143 | chroot=mock.ANY, |
| 144 | build_targets=self.build_targets, |
Shao-Chuan Lee | a4b4f30 | 2021-05-12 14:40:20 +0900 | [diff] [blame] | 145 | android_build_branch=self.input_proto.android_build_branch, |
Shao-Chuan Lee | 85ba7ce | 2021-02-09 13:50:11 +0900 | [diff] [blame] | 146 | android_version=self.input_proto.android_version, |
| 147 | skip_commit=self.input_proto.skip_commit, |
| 148 | ) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 149 | self.assertEqual(self.response.android_atom, atom) |
| 150 | self.assertEqual(self.response.status, |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 151 | android_pb2.MARK_STABLE_STATUS_SUCCESS) |
| 152 | |
| 153 | def testHandlesEarlyExit(self): |
| 154 | """Test that early exit is handled correctly.""" |
Shao-Chuan Lee | 84bf9a2 | 2021-11-19 17:42:11 +0900 | [diff] [blame] | 155 | self.uprev.return_value = packages.UprevAndroidResult(revved=False) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 156 | android.MarkStable(self.input_proto, self.response, self.api_config) |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 157 | self.uprev.assert_called_once_with( |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 158 | android_package=self.input_proto.package_name, |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 159 | chroot=mock.ANY, |
| 160 | build_targets=self.build_targets, |
Shao-Chuan Lee | a4b4f30 | 2021-05-12 14:40:20 +0900 | [diff] [blame] | 161 | android_build_branch=self.input_proto.android_build_branch, |
Shao-Chuan Lee | 85ba7ce | 2021-02-09 13:50:11 +0900 | [diff] [blame] | 162 | android_version=self.input_proto.android_version, |
| 163 | skip_commit=self.input_proto.skip_commit, |
| 164 | ) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 165 | self.assertEqual(self.response.status, |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 166 | android_pb2.MARK_STABLE_STATUS_EARLY_EXIT) |
| 167 | |
| 168 | def testHandlesPinnedUprevError(self): |
| 169 | """Test that pinned error is handled correctly.""" |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 170 | self.uprev.side_effect = packages.AndroidIsPinnedUprevError('pin/xx-1.1') |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 171 | atom = common_pb2.PackageInfo() |
| 172 | atom.category = 'pin' |
| 173 | atom.package_name = 'xx' |
| 174 | atom.version = '1.1' |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 175 | android.MarkStable(self.input_proto, self.response, self.api_config) |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 176 | self.uprev.assert_called_once_with( |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 177 | android_package=self.input_proto.package_name, |
Alex Klein | 4de25e8 | 2019-08-05 15:58:39 -0600 | [diff] [blame] | 178 | chroot=mock.ANY, |
| 179 | build_targets=self.build_targets, |
Shao-Chuan Lee | a4b4f30 | 2021-05-12 14:40:20 +0900 | [diff] [blame] | 180 | android_build_branch=self.input_proto.android_build_branch, |
Shao-Chuan Lee | 85ba7ce | 2021-02-09 13:50:11 +0900 | [diff] [blame] | 181 | android_version=self.input_proto.android_version, |
| 182 | skip_commit=self.input_proto.skip_commit, |
| 183 | ) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 184 | self.assertEqual(self.response.android_atom, atom) |
| 185 | self.assertEqual(self.response.status, |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 186 | android_pb2.MARK_STABLE_STATUS_PINNED) |
| 187 | |
| 188 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 189 | class UnpinVersionTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin): |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 190 | """Unittests for UnpinVersion.""" |
| 191 | |
| 192 | def testCallsUnlink(self): |
| 193 | """SetAndroid calls service with correct args.""" |
| 194 | safeunlink = self.PatchObject(osutils, 'SafeUnlink') |
| 195 | self.PatchObject(constants, '_FindSourceRoot', return_value='SRCROOT') |
| 196 | |
| 197 | # This has the side effect of making sure that input and output proto are |
| 198 | # not actually used. |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 199 | android.UnpinVersion(None, None, self.api_config) |
LaMont Jones | 8a1644f | 2019-04-16 14:30:17 -0600 | [diff] [blame] | 200 | safeunlink.assert_called_once_with(android.ANDROIDPIN_MASK_PATH) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 201 | |
| 202 | def testValidateOnly(self): |
| 203 | """Sanity check that a validate only call does not execute any logic.""" |
| 204 | safeunlink = self.PatchObject(osutils, 'SafeUnlink') |
| 205 | |
| 206 | android.UnpinVersion(None, None, self.validate_only_config) |
| 207 | safeunlink.assert_not_called() |
Michael Mortensen | 2562644 | 2019-11-22 10:06:59 -0700 | [diff] [blame] | 208 | |
| 209 | def testMockCall(self): |
| 210 | """Test that a mock call does not execute logic.""" |
| 211 | safeunlink = self.PatchObject(osutils, 'SafeUnlink') |
| 212 | |
| 213 | android.UnpinVersion(None, None, self.mock_call_config) |
| 214 | safeunlink.assert_not_called() |
| 215 | # android.UnpinVersion does not modify the response. |
Shao-Chuan Lee | ddcca81 | 2021-12-10 15:11:16 +0900 | [diff] [blame] | 216 | |
| 217 | |
| 218 | class WriteLKGBTest(cros_test_lib.MockTestCase, api_config.ApiConfigMixin): |
| 219 | """Unittests for WriteLKGB.""" |
| 220 | |
| 221 | def setUp(self): |
| 222 | self._output_proto = android_pb2.WriteLKGBResponse() |
| 223 | |
| 224 | def testValidateOnly(self): |
| 225 | """Test that a validate only call does not execute any logic.""" |
| 226 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB') |
| 227 | |
| 228 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 229 | android_version='android-version') |
| 230 | android.WriteLKGB(req, self._output_proto, self.validate_only_config) |
| 231 | |
| 232 | mock_write_lkgb.assert_not_called() |
| 233 | |
| 234 | def testMockCall(self): |
| 235 | """Test that a mock call does not execute logic, returns mocked value.""" |
| 236 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB') |
| 237 | |
| 238 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 239 | android_version='android-version') |
| 240 | android.WriteLKGB(req, self._output_proto, self.mock_call_config) |
| 241 | |
| 242 | mock_write_lkgb.assert_not_called() |
| 243 | self.assertSequenceEqual(self._output_proto.modified_files, ['fake_file']) |
| 244 | |
| 245 | def testFailsIfAndroidPackageMissing(self): |
| 246 | """Fails if android_package is missing.""" |
| 247 | req = android_pb2.WriteLKGBRequest(android_version='android-version') |
| 248 | with self.assertRaises(cros_build_lib.DieSystemExit): |
| 249 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 250 | |
| 251 | def testFailsIfAndroidVersionMissing(self): |
| 252 | """Fails if android_version is missing.""" |
| 253 | req = android_pb2.WriteLKGBRequest(android_package='android-package') |
| 254 | with self.assertRaises(cros_build_lib.DieSystemExit): |
| 255 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 256 | |
| 257 | def testSuccess(self): |
| 258 | """Successful request.""" |
| 259 | mock_read_lkgb = self.PatchObject(service_android, 'ReadLKGB', |
| 260 | return_value='old-version') |
| 261 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB', |
| 262 | return_value='mock_file') |
| 263 | self.PatchObject(service_android, 'GetAndroidPackageDir', |
| 264 | return_value='android-package-dir') |
| 265 | |
| 266 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 267 | android_version='android-version') |
| 268 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 269 | |
| 270 | mock_read_lkgb.assert_called_once_with('android-package-dir') |
| 271 | mock_write_lkgb.assert_called_once_with('android-package-dir', |
| 272 | 'android-version') |
| 273 | self.assertSequenceEqual(self._output_proto.modified_files, ['mock_file']) |
| 274 | |
| 275 | def testSameVersion(self): |
| 276 | """Nothing is modified if LKGB is already the same version.""" |
| 277 | mock_read_lkgb = self.PatchObject(service_android, 'ReadLKGB', |
| 278 | return_value='android-version') |
| 279 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB') |
| 280 | self.PatchObject(service_android, 'GetAndroidPackageDir', |
| 281 | return_value='android-package-dir') |
| 282 | |
| 283 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 284 | android_version='android-version') |
| 285 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 286 | |
| 287 | mock_read_lkgb.assert_called_once_with('android-package-dir') |
| 288 | mock_write_lkgb.assert_not_called() |
| 289 | self.assertSequenceEqual(self._output_proto.modified_files, []) |
| 290 | |
| 291 | def testMissingLKGB(self): |
| 292 | """Proceed if LKGB file is currently missing.""" |
| 293 | mock_read_lkgb = self.PatchObject( |
| 294 | service_android, 'ReadLKGB', |
| 295 | side_effect=service_android.MissingLKGBError()) |
| 296 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB', |
| 297 | return_value='mock_file') |
| 298 | self.PatchObject(service_android, 'GetAndroidPackageDir', |
| 299 | return_value='android-package-dir') |
| 300 | |
| 301 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 302 | android_version='android-version') |
| 303 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 304 | |
| 305 | mock_read_lkgb.assert_called_once_with('android-package-dir') |
| 306 | mock_write_lkgb.assert_called_once_with('android-package-dir', |
| 307 | 'android-version') |
| 308 | self.assertSequenceEqual(self._output_proto.modified_files, ['mock_file']) |
| 309 | |
| 310 | def testInvalidLKGB(self): |
| 311 | """Proceed if LKGB file currently contains invalid content.""" |
| 312 | mock_read_lkgb = self.PatchObject( |
| 313 | service_android, 'ReadLKGB', |
| 314 | side_effect=service_android.InvalidLKGBError()) |
| 315 | mock_write_lkgb = self.PatchObject(service_android, 'WriteLKGB', |
| 316 | return_value='mock_file') |
| 317 | self.PatchObject(service_android, 'GetAndroidPackageDir', |
| 318 | return_value='android-package-dir') |
| 319 | |
| 320 | req = android_pb2.WriteLKGBRequest(android_package='android-package', |
| 321 | android_version='android-version') |
| 322 | android.WriteLKGB(req, self._output_proto, self.api_config) |
| 323 | |
| 324 | mock_read_lkgb.assert_called_once_with('android-package-dir') |
| 325 | mock_write_lkgb.assert_called_once_with('android-package-dir', |
| 326 | 'android-version') |
| 327 | self.assertSequenceEqual(self._output_proto.modified_files, ['mock_file']) |