Skip to main content
Glama

Backlog MCP Server

getPullRequestComments.test.ts3.64 kB
import { getPullRequestCommentsTool } from './getPullRequestComments.js'; import { jest, describe, it, expect } from '@jest/globals'; import type { Backlog } from 'backlog-js'; import { createTranslationHelper } from '../createTranslationHelper.js'; describe('getPullRequestCommentsTool', () => { const mockBacklog: Partial<Backlog> = { getPullRequestComments: jest.fn<() => Promise<any>>().mockResolvedValue([ { id: 1, content: 'This looks good to me!', changeLog: [], createdUser: { id: 1, userId: 'user1', name: 'User One', }, created: '2023-01-01T00:00:00Z', updated: '2023-01-01T00:00:00Z', stars: [], notifications: [], }, { id: 2, content: 'I found a small issue in the code.', changeLog: [], createdUser: { id: 2, userId: 'user2', name: 'User Two', }, created: '2023-01-02T00:00:00Z', updated: '2023-01-02T00:00:00Z', stars: [], notifications: [], }, ]), }; const mockTranslationHelper = createTranslationHelper(); const tool = getPullRequestCommentsTool( mockBacklog as Backlog, mockTranslationHelper ); it('returns pull request comments', async () => { const result = await tool.handler({ projectKey: 'TEST', repoName: 'test-repo', // Changed number: 1, }); if (!Array.isArray(result)) { throw new Error('Unexpected non array result'); } expect(result).toHaveLength(2); expect(result[0]).toHaveProperty('content', 'This looks good to me!'); expect(result[1]).toHaveProperty( 'content', 'I found a small issue in the code.' ); }); it('calls backlog.getPullRequestComments with correct params when using repoName', async () => { const params = { projectKey: 'TEST', repoName: 'test-repo', // Changed number: 1, minId: 100, maxId: 200, count: 20, order: 'desc' as const, }; await tool.handler(params); expect(mockBacklog.getPullRequestComments).toHaveBeenCalledWith( 'TEST', 'test-repo', 1, { minId: 100, maxId: 200, count: 20, order: 'desc', } ); }); it('calls backlog.getPullRequestComments with correct params when using projectId and repoName', async () => { const params = { projectId: 100, repoName: 'test-repo', // Changed number: 1, }; await tool.handler(params); expect(mockBacklog.getPullRequestComments).toHaveBeenCalledWith( 100, 'test-repo', 1, {} ); }); it('calls backlog.getPullRequestComments with correct params when using projectId and repoId', async () => { const params = { projectId: 100, repoId: 200, // Added repoId number: 1, }; await tool.handler(params); expect(mockBacklog.getPullRequestComments).toHaveBeenCalledWith( 100, '200', 1, {} ); }); it('throws an error if neither projectId nor projectKey is provided', async () => { const params = { // projectId and projectKey are missing repoName: 'test-repo', number: 1, }; await expect(tool.handler(params as any)).rejects.toThrow(Error); }); it('throws an error if neither repoId nor repoName is provided', async () => { const params = { projectKey: 'TEST', // repoId and repoName are missing number: 1, }; await expect(tool.handler(params as any)).rejects.toThrow(Error); }); });

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/nulab/backlog-mcp-server'

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