Skip to content

Commit

Permalink
refactor: error handling
Browse files Browse the repository at this point in the history
  • Loading branch information
discord9 committed May 14, 2024
1 parent 8488889 commit e971f69
Show file tree
Hide file tree
Showing 5 changed files with 165 additions and 136 deletions.
13 changes: 13 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions src/flow/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ futures = "0.3"
# it is the same with upstream repo
async-trait.workspace = true
common-meta.workspace = true
enum-as-inner = "0.6.0"
greptime-proto.workspace = true
hydroflow = { git = "https://github.com/GreptimeTeam/hydroflow.git", branch = "main" }
itertools.workspace = true
Expand Down
7 changes: 1 addition & 6 deletions src/flow/src/adapter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,8 @@
pub(crate) mod error;
pub(crate) mod node_context;

pub(crate) use node_context::FlownodeContext;
pub(crate) use node_context::{FlowId, FlownodeContext, TableName};

mod worker;

pub const PER_REQ_MAX_ROW_CNT: usize = 8192;

// TODO: refactor common types for flow to a separate module
/// FlowId is a unique identifier for a flow task
pub type FlowId = u64;
pub type TableName = [String; 3];
29 changes: 25 additions & 4 deletions src/flow/src/adapter/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ use datatypes::value::Value;
use servers::define_into_tonic_status;
use snafu::{Location, Snafu};

use crate::adapter::FlowId;
use crate::expr::EvalError;

/// This error is used to represent all possible errors that can occur in the flow module.
Expand All @@ -39,7 +40,11 @@ pub enum Error {
},

#[snafu(display("Internal error"))]
Internal { location: Location, reason: String },
Internal {
reason: String,
#[snafu(implicit)]
location: Location,
},

/// TODO(discord9): add detailed location of column
#[snafu(display("Failed to eval stream"))]
Expand Down Expand Up @@ -71,6 +76,20 @@ pub enum Error {
location: Location,
},

#[snafu(display("Flow not found, id={id}"))]
FlowNotFound {
id: FlowId,
#[snafu(implicit)]
location: Location,
},

#[snafu(display("Flow already exist, id={id}"))]
FlowAlreadyExist {
id: FlowId,
#[snafu(implicit)]
location: Location,
},

#[snafu(display("Failed to join task"))]
JoinTask {
#[snafu(source)]
Expand Down Expand Up @@ -168,10 +187,12 @@ impl ErrorExt for Error {
Self::Eval { .. } | &Self::JoinTask { .. } | &Self::Datafusion { .. } => {
StatusCode::Internal
}
&Self::TableAlreadyExist { .. } => StatusCode::TableAlreadyExists,
Self::TableNotFound { .. } | Self::TableNotFoundMeta { .. } => {
StatusCode::TableNotFound
&Self::TableAlreadyExist { .. } | Self::FlowAlreadyExist { .. } => {
StatusCode::TableAlreadyExists
}
Self::TableNotFound { .. }
| Self::TableNotFoundMeta { .. }
| Self::FlowNotFound { .. } => StatusCode::TableNotFound,
Self::InvalidQueryPlan { .. }
| Self::InvalidQuerySubstrait { .. }
| Self::InvalidQueryProst { .. }
Expand Down
Loading

0 comments on commit e971f69

Please sign in to comment.