Skip to main content
Glama
pbandreddy

BlazeMeter MCP Server

by pbandreddy

get_test_run_aggregate_data

Retrieve aggregate report data for a specific test run on the BlazeMeter MCP Server to analyze performance metrics and results efficiently.

Instructions

Get the aggregate report data for a specified test run (master).

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
masterIdYesThe ID of the test run (master) to retrieve the aggregate report data for.

Implementation Reference

  • The handler function `executeFunction` that fetches and returns the aggregate report data from the BlazeMeter API for the given `masterId`.
    const executeFunction = async ({ masterId }) => { const baseUrl = process.env.BASE_URL; // loaded from .env const username = process.env.BZM_USERNAME; // loaded from .env const password = process.env.BZM_PASSWORD; // loaded from .env try { // Construct the URL for the aggregate report data const url = new URL(`${baseUrl}/api/v4/masters/${masterId}/reports/aggregatereport/data`); // Set up headers for the request const headers = { 'Authorization': 'Basic ' + Buffer.from(`${username}:${password}`).toString('base64'), 'Accept': 'application/json' }; // Perform the fetch request const response = await fetch(url.toString(), { method: 'GET', headers }); // Check if the response was successful if (!response.ok) { let errorData; try { errorData = await response.json(); } catch (jsonErr) { errorData = await response.text(); } throw new Error(`HTTP ${response.status} ${response.statusText}: ${typeof errorData === 'string' ? errorData : JSON.stringify(errorData)}`); } // Parse and return the response data const data = await response.json(); return data; } catch (error) { if (error instanceof Error) { return { error: error.message }; } else { return { error: 'Unknown error occurred while getting aggregate report data.' }; } } };
  • The JSON schema defining the input parameters for the tool, requiring a `masterId` string.
    parameters: { type: 'object', properties: { masterId: { type: 'string', description: 'The ID of the test run (master) to retrieve the aggregate report data for.' } }, required: ['masterId'] }
  • The `apiTool` object that defines the tool's name, description, schema, and references the handler function. This is exported and loaded dynamically during tool discovery.
    const apiTool = { function: executeFunction, definition: { type: 'function', function: { name: 'get_test_run_aggregate_data', description: 'Get the aggregate report data for a specified test run (master).', parameters: { type: 'object', properties: { masterId: { type: 'string', description: 'The ID of the test run (master) to retrieve the aggregate report data for.' } }, required: ['masterId'] } } } }; export { apiTool };
  • tools/paths.js:6-6 (registration)
    The path to the tool's file is included in the `toolPaths` array, which is used by the tool discovery mechanism to dynamically import and register the tool.
    'blazemeter/new-collection/get-test-run-aggregate-data.js',
  • lib/tools.js:7-16 (registration)
    The `discoverTools` function dynamically imports and registers all tools listed in `toolPaths`, spreading the `apiTool` from each module.
    export async function discoverTools() { const toolPromises = toolPaths.map(async (file) => { const module = await import(`../tools/${file}`); return { ...module.apiTool, path: file, }; }); return Promise.all(toolPromises); }

Other Tools

Related Tools

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/pbandreddy/blazemeter-mcp-server'

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