pub struct RunSummaryBuilder {
pub recent_event_limit: usize,
}Expand description
Builder for RunSummary.
Fields§
§recent_event_limit: usizeMaximum number of events copied from the journal.
Implementations§
Source§impl RunSummaryBuilder
impl RunSummaryBuilder
Sourcepub fn new(recent_event_limit: usize) -> Self
pub fn new(recent_event_limit: usize) -> Self
Creates a run summary builder.
§Arguments
recent_event_limit: Maximum number of recent journal events copied.
§Returns
Returns a RunSummaryBuilder.
§Examples
let builder = rust_supervisor::summary::builder::RunSummaryBuilder::new(8);
assert_eq!(builder.recent_event_limit, 8);Examples found in repository?
38fn main() {
39 // Build the child identifier.
40 let child_id = ChildId::new("market_feed");
41 // Build the child path.
42 let child_path = SupervisorPath::root().join("market_feed");
43 // Build a typed task failure.
44 let failure = TaskFailure::new(
45 // Set the failure kind.
46 TaskFailureKind::Timeout,
47 // Set the low-cardinality failure category.
48 "external_dependency",
49 // Set the diagnostic failure message.
50 "market feed heartbeat timed out",
51 // Finish the typed task failure.
52 );
53 // Build the restart policy decision.
54 let policy = PolicyDecision::new(
55 // Set the decision label.
56 "RestartAfter",
57 // Set the restart delay.
58 Some(500),
59 // Set the diagnostic decision reason.
60 Some("heartbeat timeout is restartable".to_owned()),
61 // Finish the policy decision.
62 );
63
64 // Create the fixed-capacity event journal.
65 let mut journal = EventJournal::new(8);
66 // Push the running event.
67 journal.push(event(
68 // Set the event sequence.
69 1,
70 // Clone the child identifier.
71 child_id.clone(),
72 // Set the child display name.
73 "Market Feed",
74 // Build the running event payload.
75 What::ChildRunning {
76 // Attach the state transition.
77 transition: Some(StateTransition::new("Starting", "Running")),
78 // Finish the running event payload.
79 },
80 // Attach no policy decision.
81 None,
82 // Finish the running event.
83 ));
84 // Push the failed event.
85 journal.push(event(
86 // Set the event sequence.
87 2,
88 // Clone the child identifier.
89 child_id.clone(),
90 // Set the child display name.
91 "Market Feed",
92 // Build the failed event payload.
93 What::ChildFailed {
94 // Attach the typed failure.
95 failure: failure.clone(),
96 // Finish the failed event payload.
97 },
98 // Attach the restart policy decision.
99 Some(policy.clone()),
100 // Finish the failed event.
101 ));
102 // Push the backoff event.
103 journal.push(event(
104 // Set the event sequence.
105 3,
106 // Clone the child identifier.
107 child_id.clone(),
108 // Set the child display name.
109 "Market Feed",
110 // Build the backoff payload.
111 What::BackoffScheduled { delay_ms: 500 },
112 // Attach the restart policy decision.
113 Some(policy.clone()),
114 // Finish the backoff event.
115 ));
116 // Push the restarted event.
117 journal.push(event(
118 // Set the event sequence.
119 4,
120 // Clone the child identifier.
121 child_id.clone(),
122 // Set the child display name.
123 "Market Feed",
124 // Build the restarted payload.
125 What::ChildRestarted { restart_count: 1 },
126 // Attach the restart policy decision.
127 Some(policy.clone()),
128 // Finish the restarted event.
129 ));
130
131 // Build the final child state.
132 let child = ChildState::declared(child_path, child_id, "Market Feed")
133 // Set the child lifecycle state.
134 .with_lifecycle_state(ChildLifecycleState::Running, EventSequence::new(1))
135 // Record the latest failure.
136 .record_failure(failure, EventSequence::new(2))
137 // Record the latest policy decision.
138 .with_policy_decision(policy, 1);
139 // Build the final supervisor state.
140 let final_state = SupervisorState::new(SupervisorPath::root(), EventSequence::new(4), 1)
141 // Add the child state.
142 .with_child(child)
143 // Mark shutdown as completed for the replay.
144 .with_shutdown_state(ShutdownState::Completed)
145 // Attach the last journal sequence.
146 .with_journal_sequence(EventSequence::new(4));
147 // Build the diagnostic run summary.
148 let summary = RunSummaryBuilder::new(8).build(
149 // Read recent events from the journal.
150 &journal,
151 // Attach the final current state.
152 final_state,
153 // Attach the shutdown cause.
154 Some("diagnostic replay complete".to_owned()),
155 // Finish the summary construction.
156 );
157 // Create the metrics facade.
158 let metrics = MetricsFacade::new();
159
160 // Print summary counters.
161 println!(
162 // Provide the output template.
163 "summary restart_count={} failure_count={} recent_events={}",
164 // Print the restart count.
165 summary.restart_count,
166 // Print the failure count.
167 summary.failure_count,
168 // Print the recent event count.
169 summary.recent_events.len(),
170 // Finish summary output.
171 );
172 // Iterate over recent journal events.
173 for event in journal.recent(8) {
174 // Print event names and derived metrics.
175 println!(
176 // Provide the output template.
177 "event={} metrics={:?}",
178 // Print the event name.
179 event.what.name(),
180 // Print metrics derived from the event.
181 metrics.samples_for_event(&event),
182 // Finish event output.
183 );
184 // Finish the journal replay loop.
185 }
186 // End the diagnostic replay example.
187}Sourcepub fn build(
&self,
journal: &EventJournal,
final_state: SupervisorState,
shutdown_cause: Option<String>,
) -> RunSummary
pub fn build( &self, journal: &EventJournal, final_state: SupervisorState, shutdown_cause: Option<String>, ) -> RunSummary
Builds a run summary from journal and final state.
§Arguments
journal: Event journal that contains recent lifecycle facts.final_state: Final current state for the run.shutdown_cause: Optional shutdown cause.
§Returns
Returns a RunSummary derived from the inputs.
Examples found in repository?
38fn main() {
39 // Build the child identifier.
40 let child_id = ChildId::new("market_feed");
41 // Build the child path.
42 let child_path = SupervisorPath::root().join("market_feed");
43 // Build a typed task failure.
44 let failure = TaskFailure::new(
45 // Set the failure kind.
46 TaskFailureKind::Timeout,
47 // Set the low-cardinality failure category.
48 "external_dependency",
49 // Set the diagnostic failure message.
50 "market feed heartbeat timed out",
51 // Finish the typed task failure.
52 );
53 // Build the restart policy decision.
54 let policy = PolicyDecision::new(
55 // Set the decision label.
56 "RestartAfter",
57 // Set the restart delay.
58 Some(500),
59 // Set the diagnostic decision reason.
60 Some("heartbeat timeout is restartable".to_owned()),
61 // Finish the policy decision.
62 );
63
64 // Create the fixed-capacity event journal.
65 let mut journal = EventJournal::new(8);
66 // Push the running event.
67 journal.push(event(
68 // Set the event sequence.
69 1,
70 // Clone the child identifier.
71 child_id.clone(),
72 // Set the child display name.
73 "Market Feed",
74 // Build the running event payload.
75 What::ChildRunning {
76 // Attach the state transition.
77 transition: Some(StateTransition::new("Starting", "Running")),
78 // Finish the running event payload.
79 },
80 // Attach no policy decision.
81 None,
82 // Finish the running event.
83 ));
84 // Push the failed event.
85 journal.push(event(
86 // Set the event sequence.
87 2,
88 // Clone the child identifier.
89 child_id.clone(),
90 // Set the child display name.
91 "Market Feed",
92 // Build the failed event payload.
93 What::ChildFailed {
94 // Attach the typed failure.
95 failure: failure.clone(),
96 // Finish the failed event payload.
97 },
98 // Attach the restart policy decision.
99 Some(policy.clone()),
100 // Finish the failed event.
101 ));
102 // Push the backoff event.
103 journal.push(event(
104 // Set the event sequence.
105 3,
106 // Clone the child identifier.
107 child_id.clone(),
108 // Set the child display name.
109 "Market Feed",
110 // Build the backoff payload.
111 What::BackoffScheduled { delay_ms: 500 },
112 // Attach the restart policy decision.
113 Some(policy.clone()),
114 // Finish the backoff event.
115 ));
116 // Push the restarted event.
117 journal.push(event(
118 // Set the event sequence.
119 4,
120 // Clone the child identifier.
121 child_id.clone(),
122 // Set the child display name.
123 "Market Feed",
124 // Build the restarted payload.
125 What::ChildRestarted { restart_count: 1 },
126 // Attach the restart policy decision.
127 Some(policy.clone()),
128 // Finish the restarted event.
129 ));
130
131 // Build the final child state.
132 let child = ChildState::declared(child_path, child_id, "Market Feed")
133 // Set the child lifecycle state.
134 .with_lifecycle_state(ChildLifecycleState::Running, EventSequence::new(1))
135 // Record the latest failure.
136 .record_failure(failure, EventSequence::new(2))
137 // Record the latest policy decision.
138 .with_policy_decision(policy, 1);
139 // Build the final supervisor state.
140 let final_state = SupervisorState::new(SupervisorPath::root(), EventSequence::new(4), 1)
141 // Add the child state.
142 .with_child(child)
143 // Mark shutdown as completed for the replay.
144 .with_shutdown_state(ShutdownState::Completed)
145 // Attach the last journal sequence.
146 .with_journal_sequence(EventSequence::new(4));
147 // Build the diagnostic run summary.
148 let summary = RunSummaryBuilder::new(8).build(
149 // Read recent events from the journal.
150 &journal,
151 // Attach the final current state.
152 final_state,
153 // Attach the shutdown cause.
154 Some("diagnostic replay complete".to_owned()),
155 // Finish the summary construction.
156 );
157 // Create the metrics facade.
158 let metrics = MetricsFacade::new();
159
160 // Print summary counters.
161 println!(
162 // Provide the output template.
163 "summary restart_count={} failure_count={} recent_events={}",
164 // Print the restart count.
165 summary.restart_count,
166 // Print the failure count.
167 summary.failure_count,
168 // Print the recent event count.
169 summary.recent_events.len(),
170 // Finish summary output.
171 );
172 // Iterate over recent journal events.
173 for event in journal.recent(8) {
174 // Print event names and derived metrics.
175 println!(
176 // Provide the output template.
177 "event={} metrics={:?}",
178 // Print the event name.
179 event.what.name(),
180 // Print metrics derived from the event.
181 metrics.samples_for_event(&event),
182 // Finish event output.
183 );
184 // Finish the journal replay loop.
185 }
186 // End the diagnostic replay example.
187}Trait Implementations§
Source§impl Clone for RunSummaryBuilder
impl Clone for RunSummaryBuilder
Source§fn clone(&self) -> RunSummaryBuilder
fn clone(&self) -> RunSummaryBuilder
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for RunSummaryBuilder
impl Debug for RunSummaryBuilder
Auto Trait Implementations§
impl Freeze for RunSummaryBuilder
impl RefUnwindSafe for RunSummaryBuilder
impl Send for RunSummaryBuilder
impl Sync for RunSummaryBuilder
impl Unpin for RunSummaryBuilder
impl UnsafeUnpin for RunSummaryBuilder
impl UnwindSafe for RunSummaryBuilder
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
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> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);