Skip to main content
Glama
feature.spec.unit.ts3.11 kB
import { WebApi } from 'azure-devops-node-api'; import { getPipelineLog } from './feature'; import { AzureDevOpsAuthenticationError, AzureDevOpsError, AzureDevOpsResourceNotFoundError, } from '../../../shared/errors'; describe('getPipelineLog unit', () => { let mockConnection: WebApi; let mockBuildApi: any; let mockRestGet: jest.Mock; beforeEach(() => { jest.resetAllMocks(); mockRestGet = jest.fn(); mockBuildApi = { rest: { get: mockRestGet }, createRequestOptions: jest .fn() .mockReturnValue({ acceptHeader: 'application/json' }), getBuildLogLines: jest.fn(), }; mockConnection = { serverUrl: 'https://dev.azure.com/testorg', getBuildApi: jest.fn().mockResolvedValue(mockBuildApi), } as unknown as WebApi; }); it('retrieves the pipeline log with query parameters', async () => { mockRestGet.mockResolvedValue({ statusCode: 200, result: 'log content', headers: {}, }); const result = await getPipelineLog(mockConnection, { projectId: 'test-project', runId: 101, logId: 7, format: 'json', startLine: 10, endLine: 20, }); expect(result).toEqual('log content'); expect(mockBuildApi.createRequestOptions).toHaveBeenCalledWith( 'application/json', '7.1', ); const [requestUrl] = mockRestGet.mock.calls[0]; const url = new URL(requestUrl); expect(url.pathname).toContain('/build/builds/101/logs/7'); expect(url.searchParams.get('format')).toBe('json'); expect(url.searchParams.get('startLine')).toBe('10'); expect(url.searchParams.get('endLine')).toBe('20'); }); it('defaults to plain text when format not provided', async () => { mockBuildApi.getBuildLogLines.mockResolvedValue(['line1', 'line2']); await getPipelineLog(mockConnection, { projectId: 'test-project', runId: 101, logId: 7, }); expect(mockBuildApi.getBuildLogLines).toHaveBeenCalledWith( 'test-project', 101, 7, undefined, undefined, ); }); it('throws resource not found when API returns 404', async () => { mockBuildApi.getBuildLogLines.mockResolvedValue(undefined); await expect( getPipelineLog(mockConnection, { projectId: 'test-project', runId: 101, logId: 7, }), ).rejects.toBeInstanceOf(AzureDevOpsResourceNotFoundError); }); it('maps authentication errors', async () => { mockBuildApi.getBuildLogLines.mockRejectedValue( new Error('401 Unauthorized'), ); await expect( getPipelineLog(mockConnection, { projectId: 'test-project', runId: 101, logId: 7, }), ).rejects.toBeInstanceOf(AzureDevOpsAuthenticationError); }); it('wraps unexpected errors', async () => { mockBuildApi.getBuildLogLines.mockRejectedValue(new Error('Boom')); await expect( getPipelineLog(mockConnection, { projectId: 'test-project', runId: 101, logId: 7, }), ).rejects.toBeInstanceOf(AzureDevOpsError); }); });

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/Tiberriver256/mcp-server-azure-devops'

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