Skip to main content

CheckpointWorkerManager

Struct CheckpointWorkerManager 

Source
pub struct CheckpointWorkerManager { /* private fields */ }
Expand description

Manages the checkpoint server thread lifecycle.

Implementations§

Source§

impl CheckpointWorkerManager

Source

pub fn get_instance( params: Option<CheckpointWorkerParams>, ) -> Result<Arc<CheckpointWorkerManager>, TestError>

Get or create the singleton instance.

If the singleton already exists and params is Some with values that differ from the existing instance’s configuration, an error is returned. Pass None to accept whatever configuration the existing instance has.

Source

pub fn reset_instance_for_testing()

Reset the singleton instance (for testing).

Note: This method should be called from a non-async context or at the start of a test before any async operations. If called from within an async context, it will skip the graceful shutdown and just clear the instance.

Source

pub async fn send_api_request( &self, api_type: ApiType, payload: String, ) -> Result<WorkerApiResponse, TestError>

Send an API request to the checkpoint server and wait for response.

Source

pub async fn shutdown(self) -> Result<(), TestError>

Gracefully shut down the checkpoint server.

Source

pub fn shutdown_sync(self) -> Result<(), TestError>

Synchronous shutdown (for use in Drop or non-async contexts).

Source

pub fn params(&self) -> &CheckpointWorkerParams

Get the configuration parameters.

Source§

impl CheckpointWorkerManager

Source

pub async fn send_callback_success( &self, callback_id: &str, result: &str, ) -> Result<(), DurableError>

Send a callback success response.

Source

pub async fn send_callback_failure( &self, callback_id: &str, error: &ErrorObject, ) -> Result<(), DurableError>

Send a callback failure response.

Source

pub async fn send_callback_heartbeat( &self, callback_id: &str, ) -> Result<(), DurableError>

Send a callback heartbeat.

Source

pub async fn get_nodejs_history_events( &self, execution_id: &str, ) -> Result<Vec<NodeJsHistoryEvent>, DurableError>

Get Node.js-compatible history events for an execution.

Returns events in the Node.js SDK compatible format, suitable for cross-SDK history comparison. These events use PascalCase field names and include detailed event-specific information.

§Arguments
  • execution_id - The execution ID to get history events for
§Returns

A vector of Node.js-compatible history events.

Trait Implementations§

Source§

impl DurableServiceClient for CheckpointWorkerManager

Source§

fn checkpoint<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, durable_execution_arn: &'life1 str, checkpoint_token: &'life2 str, operations: Vec<OperationUpdate>, ) -> Pin<Box<dyn Future<Output = Result<CheckpointResponse, DurableError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Sends a batch of checkpoint operations to the service. Read more
Source§

fn get_operations<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, durable_execution_arn: &'life1 str, _next_marker: &'life2 str, ) -> Pin<Box<dyn Future<Output = Result<GetOperationsResponse, DurableError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Retrieves additional operations for pagination. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

Source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more