feat: workflow rollback types + Python SDK (withRollback, saga pattern)#5810
feat: workflow rollback types + Python SDK (withRollback, saga pattern)#5810dmmulroy wants to merge 3 commits intocloudflare:mainfrom
Conversation
|
Can you run "just generate-types" and push the changes files? |
a52b78a to
b0f5322
Compare
CodSpeed Performance ReportMerging this PR will not alter performanceComparing Summary
Footnotes
|
|
@anonrig I keep getting a segfaul trying to run |
|
Looking forward to being able to implement saga pattern in my CF Workflows. In my day job, we utilize Temporal for durable execution which supports this, but I am trying to convince them to switch over. |
Summary
Adds workflow rollback/saga support:
RollbackHandler<T>,RollbackStepConfig,withRollbackmethod,TerminateOptions,rollingBackstatusstep.with_rollback()decorator withundo=,depends=,concurrent=supportTypeScript Types (
types/defines/)Python SDK (
src/pyodide/)API:
step.with_rollback(name, *, undo=None, depends=None, concurrent=False, config=None, undo_config=None)ValueErrorif missing)depends=andconcurrent=Changed Files
types/defines/rpc.d.ts- rollback typestypes/defines/workflows.d.ts- TerminateOptions, rollingBack statussrc/pyodide/internal/workers-api/src/workers/_workers.py- RollbackStep classsrc/pyodide/internal/workers-api/src/workers/__init__.py- exportssrc/workerd/server/tests/python/workflow-rollback/- testsSnapshot Regeneration Needed
Type snapshots need regeneration (
just generate-typessegfaults on macOS).Note
This PR consolidates #5809 (Python SDK) and was written with AI assistance.