1use thiserror::Error;
2
3#[derive(Error, Debug)]
4pub enum OrcaError {
5 #[error("config error: {0}")]
6 Config(String),
7
8 #[error("runtime error: {0}")]
9 Runtime(String),
10
11 #[error("workload '{name}' not found")]
12 WorkloadNotFound { name: String },
13
14 #[error("node '{id}' not found")]
15 NodeNotFound { id: String },
16
17 #[error("scheduler error: {0}")]
18 Scheduler(String),
19
20 #[error("consensus error: {0}")]
21 Consensus(String),
22
23 #[error("proxy error: {0}")]
24 Proxy(String),
25
26 #[error("secret '{key}' not found")]
27 SecretNotFound { key: String },
28
29 #[error(transparent)]
30 Io(#[from] std::io::Error),
31
32 #[error(transparent)]
33 Other(#[from] anyhow::Error),
34}
35
36pub type Result<T> = std::result::Result<T, OrcaError>;
37
38#[cfg(test)]
39mod tests {
40 use super::*;
41
42 #[test]
43 fn config_error_display() {
44 let e = OrcaError::Config("missing field".into());
45 assert_eq!(e.to_string(), "config error: missing field");
46 }
47
48 #[test]
49 fn workload_not_found_display() {
50 let e = OrcaError::WorkloadNotFound { name: "web".into() };
51 assert_eq!(e.to_string(), "workload 'web' not found");
52 }
53
54 #[test]
55 fn runtime_error_display() {
56 let e = OrcaError::Runtime("container crashed".into());
57 assert_eq!(e.to_string(), "runtime error: container crashed");
58 }
59}