-
Notifications
You must be signed in to change notification settings - Fork 849
Expand file tree
/
Copy pathexceptions.py
More file actions
134 lines (89 loc) · 3.06 KB
/
exceptions.py
File metadata and controls
134 lines (89 loc) · 3.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
from enum import Enum
class TimeoutType(str, Enum):
"""
The type of timeout that occurred.
- ``SANDBOX``: The sandbox itself timed out (e.g., idle timeout expired).
- ``REQUEST``: The HTTP request timed out (exceeded ``request_timeout``).
- ``EXECUTION``: A long-running operation timed out (exceeded ``timeout`` for command execution, watch, etc.).
"""
SANDBOX = "sandbox"
REQUEST = "request"
EXECUTION = "execution"
def format_sandbox_timeout_exception(message: str):
return TimeoutException(
f"{message}: This error is likely due to sandbox timeout. You can modify the sandbox timeout by passing 'timeout' when starting the sandbox or calling '.set_timeout' on the sandbox with the desired timeout.",
type=TimeoutType.SANDBOX,
)
def format_request_timeout_error() -> Exception:
return TimeoutException(
"Request timed out — the 'request_timeout' option can be used to increase this timeout",
type=TimeoutType.REQUEST,
)
def format_execution_timeout_error() -> Exception:
return TimeoutException(
"Execution timed out — the 'timeout' option can be used to increase this timeout",
type=TimeoutType.EXECUTION,
)
class SandboxException(Exception):
"""
Base class for all sandbox errors.
Raised when a general sandbox exception occurs.
"""
pass
class TimeoutException(SandboxException):
"""
Raised when a timeout occurs.
The ``type`` attribute indicates the kind of timeout:
- :attr:`TimeoutType.SANDBOX` — the sandbox itself timed out (idle timeout, etc.).
- :attr:`TimeoutType.REQUEST` — the HTTP request exceeded ``request_timeout``.
- :attr:`TimeoutType.EXECUTION` — a long-running operation exceeded its ``timeout``.
"""
def __init__(self, message: str = "Timeout", type: TimeoutType = TimeoutType.SANDBOX):
super().__init__(message)
self.type = type
class InvalidArgumentException(SandboxException):
"""
Raised when an invalid argument is provided.
"""
pass
class NotEnoughSpaceException(SandboxException):
"""
Raised when there is not enough disk space.
"""
pass
class NotFoundException(SandboxException):
"""
Raised when a resource is not found.
"""
pass
class AuthenticationException(Exception):
"""
Raised when authentication fails.
"""
pass
class GitAuthException(AuthenticationException):
"""
Raised when git authentication fails.
"""
pass
class GitUpstreamException(SandboxException):
"""
Raised when git upstream tracking is missing.
"""
pass
class TemplateException(SandboxException):
"""
Exception raised when the template uses old envd version. It isn't compatible with the new SDK.
"""
class RateLimitException(SandboxException):
"""
Raised when the API rate limit is exceeded.
"""
class BuildException(Exception):
"""
Raised when the build fails.
"""
class FileUploadException(BuildException):
"""
Raised when the file upload fails.
"""