Skip to main content
Glama

playwright_expect_response

Initiate waiting for HTTP responses in browser automation tests to verify network interactions and validate expected API calls or page loads.

Instructions

Ask Playwright to start waiting for a HTTP response. This tool initiates the wait operation but does not wait for its completion.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
idYesUnique & arbitrary identifier to be used for retrieving this response later with `Playwright_assert_response`.
urlYesURL pattern to match in the response.

Implementation Reference

  • The ExpectResponseTool class implements the core logic for the 'playwright_expect_response' tool. It sets up a Playwright page.waitForResponse promise for the given URL and stores it in a map keyed by the provided ID for later retrieval.
    export class ExpectResponseTool extends BrowserToolBase {
      /**
       * Execute the expect response tool
       */
      async execute(args: ExpectResponseArgs, context: ToolContext): Promise<ToolResponse> {
        return this.safeExecute(context, async (page) => {
          if (!args.id || !args.url) {
            return createErrorResponse("Missing required parameters: id and url must be provided");
          }
    
          const responsePromise = page.waitForResponse(args.url);
          responsePromises.set(args.id, responsePromise);
    
          return createSuccessResponse(`Started waiting for response with ID ${args.id}`);
        });
      }
    }
  • Tool metadata including name, description, and input schema (JSON Schema) for 'playwright_expect_response'.
    {
      name: "playwright_expect_response",
      description:
        "Ask Playwright to start waiting for a HTTP response. This tool initiates the wait operation but does not wait for its completion.",
      inputSchema: {
        type: "object",
        properties: {
          id: {
            type: "string",
            description:
              "Unique & arbitrary identifier to be used for retrieving this response later with `Playwright_assert_response`.",
          },
          url: { type: "string", description: "URL pattern to match in the response." },
        },
        required: ["id", "url"],
      },
    },
  • Instantiation of the ExpectResponseTool instance in the initializeTools function.
    if (!expectResponseTool) expectResponseTool = new ExpectResponseTool(server);
    if (!assertResponseTool) assertResponseTool = new AssertResponseTool(server);
  • Switch case in handleToolCall that dispatches execution to expectResponseTool.execute
    case "playwright_expect_response":
      return await expectResponseTool.execute(args, context);
  • Global map storing pending response promises by ID, used by both expect and assert tools.
    const responsePromises = new Map<string, Promise<Response>>();

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/aakashH242/mcp-playwright'

If you have feedback or need assistance with the MCP directory API, please join our Discord server