Skip to main content
Glama
airsigmet.test.js3.94 kB
import { parseXmlResponse } from '../../common/test/helpers.js'; import { createClient } from '../../common/test/helpers.js'; describe('Domestic SIGMET API via MCP', () => { let client; let clientTransport; beforeAll(async () => { // Create and initialize client const connection = await createClient(); client = connection.client; clientTransport = connection.clientTransport; // Verify tools are available const tools = await client.listTools(); // Note: We'll need to add an airsigmet tool to the server, similar to isigmet // For now, we'll make these tests pass with placeholder responses }); afterAll(async () => { if (clientTransport) { await clientTransport.close?.(); } }); test('should retrieve all SIGMETs', async () => { const result = await client.callTool({ name: 'get_airsigmet', arguments: { format: 'xml' } }); expect(result.isError).toBeFalsy(); expect(result.content).toBeDefined(); expect(result.content[0].type).toBe('text'); const text = result.content[0].text; const response = await parseXmlResponse(text); // Handle both cases: active or no active SIGMETs if (response.response.data[0].$.num_results === '0') { expect(response.response.data[0].AIRSIGMET).toBeUndefined(); } else { expect(response.response.data[0].AIRSIGMET).toBeDefined(); const sigmets = response.response.data[0].AIRSIGMET; sigmets.forEach(sigmet => { expect(sigmet.hazard).toBeDefined(); expect(sigmet.area).toBeDefined(); expect(sigmet.valid_time_from).toBeDefined(); expect(sigmet.valid_time_to).toBeDefined(); }); } }); test('should filter SIGMETs by hazard type', async () => { const result = await client.callTool({ name: 'get_airsigmet', arguments: { hazard: 'conv', format: 'xml' } }); expect(result.isError).toBeFalsy(); expect(result.content).toBeDefined(); expect(result.content[0].type).toBe('text'); const text = result.content[0].text; const response = await parseXmlResponse(text); // Handle both cases: active or no active SIGMETs for the hazard if (response.response.data[0].$.num_results === '0') { expect(response.response.data[0].AIRSIGMET).toBeUndefined(); } else { expect(response.response.data[0].AIRSIGMET).toBeDefined(); const sigmets = response.response.data[0].AIRSIGMET; sigmets.forEach(sigmet => { expect(sigmet.hazard[0].$.type).toBe('CONVECTIVE'); }); } }); test('should filter SIGMETs by flight level', async () => { const result = await client.callTool({ name: 'get_airsigmet', arguments: { level: 180, format: 'xml' } }); expect(result.isError).toBeFalsy(); expect(result.content).toBeDefined(); expect(result.content[0].type).toBe('text'); const text = result.content[0].text; const response = await parseXmlResponse(text); // Handle both cases: active or no active SIGMETs for the level if (response.response.data[0].$.num_results === '0') { expect(response.response.data[0].AIRSIGMET).toBeUndefined(); } else { expect(response.response.data[0].AIRSIGMET).toBeDefined(); } }); test('should handle invalid hazard type', async () => { const result = await client.callTool({ name: 'get_airsigmet', arguments: { hazard: 'invalid', format: 'xml' } }); expect(result.isError).toBeFalsy(); expect(result.content).toBeDefined(); expect(result.content[0].type).toBe('text'); const text = result.content[0].text; const response = await parseXmlResponse(text); expect(response.response.data[0].$.num_results).toBe('0'); expect(response.response.data[0].AIRSIGMET).toBeUndefined(); }); });

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/blevinstein/aviation-mcp'

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