Skip to main content
Glama

n8n-MCP

by 88-888
logger.test.tsβ€’4.97 kB
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest'; import { Logger, LogLevel } from '../src/utils/logger'; describe('Logger', () => { let logger: Logger; let consoleErrorSpy: ReturnType<typeof vi.spyOn>; let consoleWarnSpy: ReturnType<typeof vi.spyOn>; let consoleLogSpy: ReturnType<typeof vi.spyOn>; let originalDebug: string | undefined; beforeEach(() => { // Save original DEBUG value and enable debug for logger tests originalDebug = process.env.DEBUG; process.env.DEBUG = 'true'; // Create spies before creating logger consoleErrorSpy = vi.spyOn(console, 'error').mockImplementation(() => {}); consoleWarnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {}); consoleLogSpy = vi.spyOn(console, 'log').mockImplementation(() => {}); // Create logger after spies and env setup logger = new Logger({ timestamp: false, prefix: 'test' }); }); afterEach(() => { // Restore all mocks first vi.restoreAllMocks(); // Restore original DEBUG value with more robust handling try { if (originalDebug === undefined) { // Use Reflect.deleteProperty for safer deletion Reflect.deleteProperty(process.env, 'DEBUG'); } else { process.env.DEBUG = originalDebug; } } catch (error) { // If deletion fails, set to empty string as fallback process.env.DEBUG = ''; } }); describe('log levels', () => { it('should only log errors when level is ERROR', () => { logger.setLevel(LogLevel.ERROR); logger.error('error message'); logger.warn('warn message'); logger.info('info message'); logger.debug('debug message'); expect(consoleErrorSpy).toHaveBeenCalledTimes(1); expect(consoleWarnSpy).toHaveBeenCalledTimes(0); expect(consoleLogSpy).toHaveBeenCalledTimes(0); }); it('should log errors and warnings when level is WARN', () => { logger.setLevel(LogLevel.WARN); logger.error('error message'); logger.warn('warn message'); logger.info('info message'); logger.debug('debug message'); expect(consoleErrorSpy).toHaveBeenCalledTimes(1); expect(consoleWarnSpy).toHaveBeenCalledTimes(1); expect(consoleLogSpy).toHaveBeenCalledTimes(0); }); it('should log all except debug when level is INFO', () => { logger.setLevel(LogLevel.INFO); logger.error('error message'); logger.warn('warn message'); logger.info('info message'); logger.debug('debug message'); expect(consoleErrorSpy).toHaveBeenCalledTimes(1); expect(consoleWarnSpy).toHaveBeenCalledTimes(1); expect(consoleLogSpy).toHaveBeenCalledTimes(1); }); it('should log everything when level is DEBUG', () => { logger.setLevel(LogLevel.DEBUG); logger.error('error message'); logger.warn('warn message'); logger.info('info message'); logger.debug('debug message'); expect(consoleErrorSpy).toHaveBeenCalledTimes(1); expect(consoleWarnSpy).toHaveBeenCalledTimes(1); expect(consoleLogSpy).toHaveBeenCalledTimes(2); // info + debug }); }); describe('message formatting', () => { it('should include prefix in messages', () => { logger.info('test message'); expect(consoleLogSpy).toHaveBeenCalledWith('[test] [INFO] test message'); }); it('should include timestamp when enabled', () => { // Need to create a new logger instance, but ensure DEBUG is set first const timestampLogger = new Logger({ timestamp: true, prefix: 'test' }); const dateSpy = vi.spyOn(Date.prototype, 'toISOString').mockReturnValue('2024-01-01T00:00:00.000Z'); timestampLogger.info('test message'); expect(consoleLogSpy).toHaveBeenCalledWith('[2024-01-01T00:00:00.000Z] [test] [INFO] test message'); dateSpy.mockRestore(); }); it('should pass additional arguments', () => { const obj = { foo: 'bar' }; logger.info('test message', obj, 123); expect(consoleLogSpy).toHaveBeenCalledWith('[test] [INFO] test message', obj, 123); }); }); describe('parseLogLevel', () => { it('should parse log level strings correctly', () => { expect(Logger.parseLogLevel('error')).toBe(LogLevel.ERROR); expect(Logger.parseLogLevel('ERROR')).toBe(LogLevel.ERROR); expect(Logger.parseLogLevel('warn')).toBe(LogLevel.WARN); expect(Logger.parseLogLevel('info')).toBe(LogLevel.INFO); expect(Logger.parseLogLevel('debug')).toBe(LogLevel.DEBUG); expect(Logger.parseLogLevel('unknown')).toBe(LogLevel.INFO); }); }); describe('singleton instance', () => { it('should return the same instance', () => { const instance1 = Logger.getInstance(); const instance2 = Logger.getInstance(); expect(instance1).toBe(instance2); }); }); });

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/88-888/n8n-mcp'

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