Files
Eduard van Valkenburg 6acab3d1d6 Python: [BREAKING] Standardize model selection on model (#4999)
* Refactor Anthropic model option and provider clients

Rename the Anthropic client model option from model_id to model, add provider-specific Anthropic wrappers for Foundry, Bedrock, and Vertex, and expose them through the Anthropic, Foundry, Amazon, and Google namespaces. Update core option handling, docs, samples, and tests accordingly.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Fix Anthropic skills sample typing

Cast the Anthropic beta client to Any in the skills sample so the pre-commit sample pyright check no longer fails on beta skills and files endpoints that are not exposed by the current SDK stubs.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* undo sample mypy

* Retry CI after transient external failures

Retrigger PR validation after an unrelated Copilot review workflow SAML failure and a transient external tau2 git fetch failure in the Windows Python test setup.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Address review feedback on model option merging

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Address Anthropic compatibility review feedback

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* moved all to `model`

* fixes for azure ai search

* Python: standardize remaining sample env var names

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* Python: fix foundry-local pyright compatibility

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>

* updated env vars in cicd

---------

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
6acab3d1d6 · 2026-04-01 19:00:18 +00:00
History
..

Multi-Agent Sample

This sample demonstrates how to use the Durable Extension for Agent Framework to create an Azure Functions app that hosts multiple AI agents and provides direct HTTP API access for interactive conversations with each agent.

Key Concepts Demonstrated

  • Using the Microsoft Agent Framework to define multiple AI agents with unique names and instructions.
  • Registering multiple agents with the Function app and running them using HTTP.
  • Conversation management (via session IDs) for isolated interactions per agent.
  • Two different methods for registering agents: list-based initialization and incremental addition.

Prerequisites

Complete the common environment preparation steps described in ../README.md, including installing Azure Functions Core Tools, starting Azurite, configuring Azure OpenAI settings, and installing this sample's requirements.

Running the Sample

With the environment setup and function app running, you can test the sample by sending HTTP requests to the different agent endpoints.

You can use the demo.http file to send messages to the agents, or a command line tool like curl as shown below:

Note: Each endpoint waits for the agent response by default. To receive an immediate HTTP 202 instead, set the x-ms-wait-for-response header or include "wait_for_response": false in the request body.

Test the Weather Agent

Bash (Linux/macOS/WSL): Weather agent request:

curl -X POST http://localhost:7071/api/agents/WeatherAgent/run \
    -H "Content-Type: application/json" \
    -d '{"message": "What is the weather in Seattle?"}'

Expected HTTP 202 payload:

{
  "status": "accepted",
  "response": "Agent request accepted",
  "message": "What is the weather in Seattle?",
  "thread_id": "<guid>",
  "correlation_id": "<guid>"
}

Math agent request:

curl -X POST http://localhost:7071/api/agents/MathAgent/run \
    -H "Content-Type: application/json" \
    -d '{"message": "Calculate a 20% tip on a $50 bill"}'

Expected HTTP 202 payload:

{
  "status": "accepted",
  "response": "Agent request accepted",
  "message": "Calculate a 20% tip on a $50 bill",
  "thread_id": "<guid>",
  "correlation_id": "<guid>"
}

Health check (optional):

curl http://localhost:7071/api/health

Expected response:

{
  "status": "healthy",
  "agents": [
    {"name": "WeatherAgent", "type": "Agent"},
    {"name": "MathAgent", "type": "Agent"}
  ],
  "agent_count": 2
}

Code Structure

The sample demonstrates two ways to register multiple agents:

Option 1: Pass list of agents during initialization

app = AgentFunctionApp(agents=[weather_agent, math_agent])

Option 2: Add agents incrementally (commented in sample)

app = AgentFunctionApp()
app.add_agent(weather_agent)
app.add_agent(math_agent)

Each agent automatically gets:

  • POST /api/agents/{agent_name}/run - Send messages to the agent