Copy
Ask AI
"""
Workflow Serialization
======================
Demonstrates `to_dict()`, `save()`, and `load()` for workflow persistence.
"""
import json
from agno.agent import Agent
from agno.db.sqlite import SqliteDb
from agno.models.openai import OpenAIResponses
from agno.workflow import Workflow
from agno.workflow.step import Step
# ---------------------------------------------------------------------------
# Create Agents
# ---------------------------------------------------------------------------
research_agent = Agent(
name="Research Agent",
model=OpenAIResponses(id="gpt-5.2"),
instructions="Research the topic and gather key findings.",
)
writer_agent = Agent(
name="Writer Agent",
model=OpenAIResponses(id="gpt-5.2"),
instructions="Turn research notes into a concise summary.",
)
# ---------------------------------------------------------------------------
# Define Steps
# ---------------------------------------------------------------------------
research_step = Step(name="Research", agent=research_agent)
write_step = Step(name="Write", agent=writer_agent)
# ---------------------------------------------------------------------------
# Create Workflow
# ---------------------------------------------------------------------------
workflow_db = SqliteDb(
db_file="tmp/workflow_serialization.db", session_table="workflow_serialization"
)
workflow = Workflow(
id="serialization-demo-workflow",
name="Serialization Demo Workflow",
description="Workflow used to demonstrate serialization and persistence APIs.",
db=workflow_db,
steps=[research_step, write_step],
metadata={"owner": "cookbook", "topic": "serialization"},
)
# ---------------------------------------------------------------------------
# Run Workflow
# ---------------------------------------------------------------------------
if __name__ == "__main__":
workflow_dict = workflow.to_dict()
print("Serialized workflow dictionary")
print(json.dumps(workflow_dict, indent=2)[:1200])
version = workflow.save(db=workflow_db, label="serialization-demo")
print(f"\nSaved workflow version: {version}")
loaded_workflow = Workflow.load(
id="serialization-demo-workflow",
db=workflow_db,
label="serialization-demo",
)
if loaded_workflow is None:
print("Failed to load workflow from the database.")
else:
step_names = []
if isinstance(loaded_workflow.steps, list):
step_names = [
step.name for step in loaded_workflow.steps if hasattr(step, "name")
]
print("\nLoaded workflow summary")
print(f" Name: {loaded_workflow.name}")
print(f" Description: {loaded_workflow.description}")
print(f" Steps: {step_names}")
Run the Example
Copy
Ask AI
# Clone and setup repo
git clone https://github.com/agno-agi/agno.git
cd agno/cookbook/04_workflows/06_advanced_concepts/run_control
# Create and activate virtual environment
./scripts/demo_setup.sh
source .venvs/demo/bin/activate
python workflow_serialization.py