pub struct Checkpoint {
pub timestamp: String,
pub current_node: String,
pub completed_nodes: Vec<String>,
pub node_retries: HashMap<String, u32>,
pub node_statuses: HashMap<String, StageStatus>,
pub context: ContextSnapshot,
pub log: Vec<LogEntry>,
}Expand description
Serializable checkpoint for a pipeline run.
Fields§
§timestamp: StringISO 8601 timestamp of when this checkpoint was created.
current_node: StringCurrent node ID being executed (or last completed).
completed_nodes: Vec<String>Set of completed node IDs.
node_retries: HashMap<String, u32>Retry counts per node.
node_statuses: HashMap<String, StageStatus>Status of each visited node.
context: ContextSnapshotContext snapshot at checkpoint time.
log: Vec<LogEntry>Execution log entries.
Implementations§
Source§impl Checkpoint
impl Checkpoint
Sourcepub fn new(current_node: &str, context: ContextSnapshot) -> Self
pub fn new(current_node: &str, context: ContextSnapshot) -> Self
Create a new checkpoint at the given node.
Sourcepub fn mark_completed(&mut self, node_id: &str, status: StageStatus)
pub fn mark_completed(&mut self, node_id: &str, status: StageStatus)
Mark a node as completed.
Sourcepub fn increment_retry(&mut self, node_id: &str) -> u32
pub fn increment_retry(&mut self, node_id: &str) -> u32
Increment retry count for a node.
Sourcepub fn retry_count(&self, node_id: &str) -> u32
pub fn retry_count(&self, node_id: &str) -> u32
Get retry count for a node.
Trait Implementations§
Source§impl Clone for Checkpoint
impl Clone for Checkpoint
Source§fn clone(&self) -> Checkpoint
fn clone(&self) -> Checkpoint
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for Checkpoint
impl Debug for Checkpoint
Source§impl<'de> Deserialize<'de> for Checkpoint
impl<'de> Deserialize<'de> for Checkpoint
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for Checkpoint
impl RefUnwindSafe for Checkpoint
impl Send for Checkpoint
impl Sync for Checkpoint
impl Unpin for Checkpoint
impl UnsafeUnpin for Checkpoint
impl UnwindSafe for Checkpoint
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more