class documentation

Undocumented

Method __init__ Create a workflow environment from a client.
Method auto_time_skipping_disabled Disable any automatic time skipping if this is a time-skipping environment.
Async Method get_current_time Get the current time known to this environment.
Async Method shutdown Shut down this environment.
Async Method sleep Sleep in this environment.
Async Method time_skipping_unlocked Undocumented
Property supports_time_skipping Whether this environment supports time skipping.
Instance Variable _auto_time_skipping Undocumented
Instance Variable _server Undocumented
Instance Variable _supports_time_skipping Undocumented

Inherited from WorkflowEnvironment:

Static Method from_client Create a workflow environment from the given client.
Async Static Method start_local Start a full Temporal server locally, downloading if necessary.
Async Static Method start_time_skipping Start a time skipping workflow environment.
Async Method __aenter__ Noop for async with support.
Async Method __aexit__ For async with support to just call shutdown.
Property client Client to this environment.
Instance Variable _client Undocumented

Create a workflow environment from a client.

Most users would use a static method instead.

@contextmanager
def auto_time_skipping_disabled(self) -> Iterator[None]: (source)

Disable any automatic time skipping if this is a time-skipping environment.

This is a context manager for use via with. Usually in time-skipping environments, waiting on a workflow result causes time to automatically skip until the next event. This can disable that. However, this only applies to results awaited inside this context. This will not disable automatic time skipping on previous results.

This has no effect on non-time-skipping environments.

async def get_current_time(self) -> datetime: (source)

Get the current time known to this environment.

For non-time-skipping environments this is simply the system time. For time-skipping environments this is whatever time has been skipped to.

async def shutdown(self): (source)

Shut down this environment.

async def sleep(self, duration: timedelta | float): (source)

Sleep in this environment.

This awaits a regular asyncio.sleep in regular environments, or manually skips time in time-skipping environments.

Parameters
duration:timedelta | floatAmount of time to sleep.
@asynccontextmanager
async def time_skipping_unlocked(self) -> AsyncIterator[None]: (source)

Undocumented

@property
supports_time_skipping: bool = (source)

Whether this environment supports time skipping.

_auto_time_skipping: bool = (source)

Undocumented

Undocumented

_supports_time_skipping = (source)

Undocumented