Skip to main content

orca_core/
error.rs

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}