Testing your Agents
Because Agents run on Cloudflare Workers and Durable Objects, they can be tested using the same tools and techniques as Workers and Durable Objects.
Before you write your first test, install the necessary packages:
npm install vitest@~3.0.0 --save-dev --save-exactnpm install @cloudflare/vitest-pool-workers --save-devEnsure that your vitest.config.js file is identical to the following:
import { defineWorkersConfig } from "@cloudflare/vitest-pool-workers/config";
export default defineWorkersConfig({  test: {    poolOptions: {      workers: {        wrangler: { configPath: "./wrangler.toml" },      },    },  },});Add a durableObjects configuration to vitest.config.js with the name of your Agent class:
import { defineWorkersConfig } from "@cloudflare/vitest-pool-workers/config";
export default defineWorkersConfig({  test: {    poolOptions: {      workers: {        main: "./src/index.ts",        miniflare: {          durableObjects: {            NAME: "MyAgent",          },        },      },    },  },});Tests use the vitest framework. A basic test suite for your Agent can validate how your Agent responds to requests, but can also unit test your Agent's methods and state.
import {  env,  createExecutionContext,  waitOnExecutionContext,  SELF,} from "cloudflare:test";import { describe, it, expect } from "vitest";import worker from "../src";import { Env } from "../src";
interface ProvidedEnv extends Env {}
describe("make a request to my Agent", () => {  // Unit testing approach  it("responds with state", async () => {    // Provide a valid URL that your Worker can use to route to your Agent    // If you are using routeAgentRequest, this will be /agent/:agent/:name    const request = new Request<unknown, IncomingRequestCfProperties>(      "http://example.com/agent/my-agent/agent-123",    );    const ctx = createExecutionContext();    const response = await worker.fetch(request, env, ctx);    await waitOnExecutionContext(ctx);    expect(await response.text()).toMatchObject({ hello: "from your agent" });  });
  it("also responds with state", async () => {    const request = new Request("http://example.com/agent/my-agent/agent-123");    const response = await SELF.fetch(request);    expect(await response.text()).toMatchObject({ hello: "from your agent" });  });});Running tests is done using the vitest CLI:
$ npm run test# or run vitest directly$ npx vitest  MyAgent    ✓ should return a greeting (1 ms)
Test Files  1 passed (1)Review the documentation on testing for additional examples and test configuration.
You can also run an Agent locally using the wrangler CLI:
$ npx wrangler devYour Worker and resources are simulated locally via Miniflare. For more information, see: https://developers.cloudflare.com/workers/testing/local-development.
Your worker has access to the following bindings:- Durable Objects:  - MyAgent: MyAgent  Starting local server...[wrangler:inf] Ready on http://localhost:53645This spins up a local development server that runs the same runtime as Cloudflare Workers, and allows you to iterate on your Agent's code and test it locally without deploying it.
Visit the wrangler dev ↗ docs to review the CLI flags and configuration options.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark
-