blob: 5b6d2499d6bbb63b562abaec294f68c6f0a54bed [file] [log] [blame]
Sam Chiu81bdc652018-06-29 18:45:08 +08001# Copyright 2018 - The Android Open Source Project
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14r"""Custom Exceptions for acloud."""
15
Sam Chiu7de3b232018-12-06 19:45:52 +080016HTTP_NOT_FOUND_CODE = 404
17
18
19class DriverError(Exception):
20 """Base Android Gce driver exception."""
21
22
23class ConfigError(DriverError):
24 """Error related to config."""
25
26
27class CommandArgError(DriverError):
28 """Error related to command line args."""
29
30
31class GceOperationTimeoutError(DriverError):
32 """Error raised when a GCE operation timedout."""
33
34
herbertxue7a501212019-08-29 15:37:13 +080035class GetGceZoneError(DriverError):
36 """Can't get GCE zones info."""
37
38
Sam Chiu7de3b232018-12-06 19:45:52 +080039class HttpError(DriverError):
40 """Error related to http requests."""
41
42 def __init__(self, code, message):
43 self.code = code
herbertxue8525bf12021-01-27 11:34:31 +080044 super().__init__(message)
Sam Chiu7de3b232018-12-06 19:45:52 +080045
46 @staticmethod
47 def CreateFromHttpError(http_error):
48 """Create from an apiclient.errors.HttpError.
49
50 Parse the error code from apiclient.errors.HttpError
51 and create an instance of HttpError from this module
52 that has the error code.
53
54 Args:
55 http_error: An apiclient.errors.HttpError instance.
56
57 Returns:
58 An HttpError instance from this module.
59 """
60 return HttpError(http_error.resp.status, str(http_error))
61
62
63class ResourceNotFoundError(HttpError):
64 """Error raised when a resource is not found."""
65
66
67class InvalidVirtualDeviceIpError(DriverError):
68 """Invalid virtual device's IP is set.
69
70 Raise this when the virtual device's IP of an AVD instance is invalid.
71 """
72
73
74class HasRetriableRequestsError(DriverError):
75 """Raised when some retriable requests fail in a batch execution."""
76
77
78class AuthenticationError(DriverError):
79 """Raised when authentication fails."""
80
81
82class DeviceBootError(DriverError):
83 """To catch device boot errors."""
84
85
herbertxue8525bf12021-01-27 11:34:31 +080086class DownloadArtifactError(DriverError):
87 """To catch download artifact errors."""
88
89
Sam Chiu7de3b232018-12-06 19:45:52 +080090class NoSubnetwork(DriverError):
91 """When there is no subnetwork for the GCE."""
92
93
94class DeviceConnectionError(DriverError):
95 """To catch device connection errors."""
96
97
herbertxue6ef54a52019-05-02 11:38:58 +080098class PortOccupied(DriverError):
99 """Raised when open port fail."""
100
101
Sam Chiu7de3b232018-12-06 19:45:52 +0800102class DeviceBootTimeoutError(DeviceBootError):
103 """Raised when an AVD defice failed to boot within timeout."""
104
Sam Chiu81bdc652018-06-29 18:45:08 +0800105
106class SetupError(Exception):
107 """Base Setup cmd exception."""
108
109
Sam Chiu7de3b232018-12-06 19:45:52 +0800110class OSTypeError(SetupError):
111 """Error related to OS type."""
112
113
114class NoGoogleSDKDetected(SetupError):
115 """Can't find the SDK path."""
116
117
herbertxued69dc512019-05-30 15:37:15 +0800118class NoBillingError(SetupError):
119 """Billing account isn't enabled."""
120
121
Sam Chiu81bdc652018-06-29 18:45:08 +0800122class PackageInstallError(SetupError):
123 """Error related to package installation."""
124
125
126class RequiredPackageNotInstalledError(SetupError):
127 """Error related to required package not installed."""
128
129
130class UnableToLocatePkgOnRepositoryError(SetupError):
131 """Error related to unable to locate package."""
132
133
134class NotSupportedPlatformError(SetupError):
135 """Error related to user using a not supported os."""
herbertxue34776bb2018-07-03 21:57:48 +0800136
137
herbertxue36b19b22020-06-02 17:38:26 +0800138class NotSupportedFieldName(SetupError):
139 """Unsupported field name for user config."""
140
141
herbertxue2625b042018-08-16 23:28:20 +0800142class CreateError(Exception):
143 """Base Create cmd exception."""
144
145
Kevin Chenge2580452018-10-05 16:33:56 -0700146class GetAndroidBuildEnvVarError(CreateError):
147 """Can't get Android Build set environment variables."""
herbertxue2625b042018-08-16 23:28:20 +0800148
149
150class CheckPathError(CreateError):
151 """Path does not exist."""
Kevin Cheng3ce4b452018-08-23 14:47:22 -0700152
153
herbertxue66c1b952020-01-01 14:38:06 +0800154class CheckGCEZonesQuotaError(CreateError):
155 """There is no zone have enough quota."""
156
157
Kevin Cheng3ce4b452018-08-23 14:47:22 -0700158class UnsupportedInstanceImageType(CreateError):
159 """Unsupported create action for given instance/image type."""
herbertxue79585f42018-08-28 18:36:45 +0800160
161
herbertxuefd15dfd2018-12-04 11:26:27 +0800162class UnsupportedFlavor(CreateError):
163 """Unsupported create action for given flavor name."""
164
165
herbertxue6ef54a52019-05-02 11:38:58 +0800166class UnsupportedMultiAdbPort(CreateError):
167 """Unsupported create action for multi AVDs and specify adb port."""
168
169
herbertxue23b2a962019-07-24 22:39:20 +0800170class UnsupportedCreateArgs(CreateError):
171 """Unsupported create arg for a specified AVD type."""
172
173
herbertxue79585f42018-08-28 18:36:45 +0800174class GetBuildIDError(CreateError):
175 """Can't get build id from Android Build."""
herbertxueb617e8a2018-08-22 10:02:19 +0800176
177
Sam Chiuc64f3432018-08-17 11:19:06 +0800178class NotSupportedHWPropertyError(CreateError):
179 """An error to wrap a non-supported property issue."""
180
181
182class MalformedDictStringError(CreateError):
183 """Error related to unable to convert string to dict."""
184
185
186class InvalidHWPropertyError(CreateError):
187 """An error to wrap a malformed hw property issue."""
cylan1e996c52018-10-01 16:19:50 +0800188
189
190class GetLocalImageError(CreateError):
191 """Can't find the local image."""
192
193
herbertxuecf046032020-09-29 15:23:07 +0800194class GetRemoteImageError(CreateError):
195 """An error to download the remote image."""
196
197
cylan1e996c52018-10-01 16:19:50 +0800198class GetCvdLocalHostPackageError(CreateError):
199 """Can't find the lost host package."""
chojoycecd004bc2018-09-13 10:39:00 +0800200
201
Hsin-Yi Chen7ba49962019-09-25 18:58:56 +0800202class GetSdkRepoPackageError(CreateError):
203 """Can't find the local SDK repository package for goldfish."""
204
205
chojoycecd004bc2018-09-13 10:39:00 +0800206class NoCuttlefishCommonInstalled(SetupError):
207 """Can't find cuttlefish_common lib."""
208
209
herbertxuee5b98ae2019-06-19 09:26:17 +0800210class ImgDoesNotExist(CreateError):
211 """Image does not exist."""
chojoycecd004bc2018-09-13 10:39:00 +0800212
213
214class UnsupportedCompressionFileType(SetupError):
215 """Don't support the compression file type."""
Sam Chiuafbc6582018-09-04 20:47:13 +0800216
217
218class LaunchCVDFail(CreateError):
219 """Cuttlefish AVD launch failed."""
cylan66713722018-10-06 01:38:26 +0800220
221
Hsin-Yi Chen2a609332019-10-07 19:39:52 +0800222class SubprocessFail(CreateError):
223 """Subprocess failed."""
Hsin-Yi Chen7ba49962019-09-25 18:58:56 +0800224
225
cylan66713722018-10-06 01:38:26 +0800226class NoExecuteCmd(CreateError):
227 """Can't find execute bin command."""
cylan4569dca2018-11-02 12:12:53 +0800228
229
230class ReconnectError(Exception):
231 """Base reconnect cmd exception."""
232
233
234class NoInstancesFound(ReconnectError):
235 """No instances found."""
chojoyceefafc022018-11-08 17:22:16 +0800236
237
238class FunctionTimeoutError(Exception):
239 """Timeout error of decorator function."""
Sam Chiu96172ae2019-01-31 14:30:30 +0800240
241
242class ZipImageError(Exception):
243 """Zip image error."""
cylan694a5d02019-05-11 19:18:31 +0800244
245
246class UnknownAvdType(Exception):
herbertxue61bfd972019-09-24 15:51:52 +0800247 """Unknown AVD type."""
248
cylana49c1762019-09-02 12:14:07 +0800249
250class UnknownType(Exception):
herbertxue61bfd972019-09-24 15:51:52 +0800251 """Unknown type."""
Sam Chiu59120542019-08-15 09:32:32 +0800252
253
254class AdbDisconnectFailed(Exception):
255 """Adb still be alive after disconnect instance."""
256
257
258class UnsupportedLocalInstanceId(Exception):
259 """Unsupported local instance id."""
Sam Chiu34e752e2019-08-16 18:15:36 +0800260
261
262class InvalidInstanceDir(Exception):
263 """Invalid instance dir."""