Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/temporalio/samples-python
Samples for working with the Temporal Python SDK
https://github.com/temporalio/samples-python
Last synced: 2 months ago
JSON representation
Samples for working with the Temporal Python SDK
- Host: GitHub
- URL: https://github.com/temporalio/samples-python
- Owner: temporalio
- License: mit
- Created: 2022-02-01T21:31:45.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-09-16T19:34:10.000Z (4 months ago)
- Last Synced: 2024-09-17T01:39:51.823Z (4 months ago)
- Language: Python
- Size: 819 KB
- Stars: 119
- Watchers: 9
- Forks: 53
- Open Issues: 41
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-temporal - `temporalio/samples-python`
README
# Temporal Python SDK Samples
This is the set of Python samples for the [Python SDK](https://github.com/temporalio/sdk-python).
## Usage
Prerequisites:
* Python >= 3.8
* [Poetry](https://python-poetry.org)
* [Temporal CLI installed](https://docs.temporal.io/cli#install)
* [Local Temporal server running](https://docs.temporal.io/cli/server#start-dev)With this repository cloned, run the following at the root of the directory:
poetry install
That loads all required dependencies. Then to run a sample, usually you just run it in Python. For example:
poetry run python hello/hello_activity.py
Some examples require extra dependencies. See each sample's directory for specific instructions.
## Samples
* [hello](hello) - All of the basic features.
* [hello_activity](hello/hello_activity.py) - Execute an activity from a workflow.
* [hello_activity_choice](hello/hello_activity_choice.py) - Execute certain activities inside a workflow based on
dynamic input.
* [hello_activity_method](hello/hello_activity_method.py) - Demonstrate an activity that is an instance method on a
class and can access class state.
* [hello_activity_multiprocess](hello/hello_activity_multiprocess.py) - Execute a synchronous activity on a process
pool.
* [hello_activity_retry](hello/hello_activity_retry.py) - Demonstrate activity retry by failing until a certain number
of attempts.
* [hello_activity_threaded](hello/hello_activity_threaded.py) - Execute a synchronous activity on a thread pool.
* [hello_async_activity_completion](hello/hello_async_activity_completion.py) - Complete an activity outside of the
function that was called.
* [hello_cancellation](hello/hello_cancellation.py) - Manually react to cancellation inside workflows and activities.
* [hello_child_workflow](hello/hello_child_workflow.py) - Execute a child workflow from a workflow.
* [hello_continue_as_new](hello/hello_continue_as_new.py) - Use continue as new to restart a workflow.
* [hello_cron](hello/hello_cron.py) - Execute a workflow once a minute.
* [hello_exception](hello/hello_exception.py) - Execute an activity that raises an error out of the workflow and out
of the program.
* [hello_local_activity](hello/hello_local_activity.py) - Execute a local activity from a workflow.
* [hello_mtls](hello/hello_mtls.py) - Accept URL, namespace, and certificate info as CLI args and use mTLS for
connecting to server.
* [hello_parallel_activity](hello/hello_parallel_activity.py) - Execute multiple activities at once.
* [hello_query](hello/hello_query.py) - Invoke queries on a workflow.
* [hello_search_attributes](hello/hello_search_attributes.py) - Start workflow with search attributes then change
while running.
* [hello_signal](hello/hello_signal.py) - Send signals to a workflow.* [activity_worker](activity_worker) - Use Python activities from a workflow in another language.
* [bedrock](bedrock) - Orchestrate a chatbot with Amazon Bedrock.
* [cloud_export_to_parquet](cloud_export_to_parquet) - Set up schedule workflow to process exported files on an hourly basis
* [context_propagation](context_propagation) - Context propagation through workflows/activities via interceptor.
* [custom_converter](custom_converter) - Use a custom payload converter to handle custom types.
* [custom_decorator](custom_decorator) - Custom decorator to auto-heartbeat a long-running activity.
* [dsl](dsl) - DSL workflow that executes steps defined in a YAML file.
* [encryption](encryption) - Apply end-to-end encryption for all input/output.
* [gevent_async](gevent_async) - Combine gevent and Temporal.
* [langchain](langchain) - Orchestrate workflows for LangChain.
* [message-passing introduction](message_passing/introduction/) - Introduction to queries, signals, and updates.
* [open_telemetry](open_telemetry) - Trace workflows with OpenTelemetry.
* [patching](patching) - Alter workflows safely with `patch` and `deprecate_patch`.
* [polling](polling) - Recommended implementation of an activity that needs to periodically poll an external resource waiting its successful completion.
* [prometheus](prometheus) - Configure Prometheus metrics on clients/workers.
* [pydantic_converter](pydantic_converter) - Data converter for using Pydantic models.
* [safe_message_handlers](message_passing/safe_message_handlers/) - Safely handling updates and signals.
* [schedules](schedules) - Demonstrates a Workflow Execution that occurs according to a schedule.
* [sentry](sentry) - Report errors to Sentry.
* [worker_specific_task_queues](worker_specific_task_queues) - Use unique task queues to ensure activities run on specific workers.
* [worker_versioning](worker_versioning) - Use the Worker Versioning feature to more easily version your workflows & other code.## Test
Running the tests requires `poe` to be installed.
python -m pip install poethepoet
Once you have `poe` installed you can run:
poe test