mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-03-11 14:40:52 -07:00
83 lines
2.9 KiB
TypeScript
83 lines
2.9 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { describe, it, expect, vi, afterEach } from 'vitest';
|
|
import { debugLogger } from './debugLogger.js';
|
|
|
|
describe('DebugLogger', () => {
|
|
afterEach(() => {
|
|
vi.restoreAllMocks();
|
|
});
|
|
|
|
it('should call console.log with the correct arguments', () => {
|
|
const spy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
const message = 'This is a log message';
|
|
const data = { key: 'value' };
|
|
debugLogger.log(message, data);
|
|
expect(spy).toHaveBeenCalledWith(message, data);
|
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('should call console.warn with the correct arguments', () => {
|
|
const spy = vi.spyOn(console, 'warn').mockImplementation(() => {});
|
|
const message = 'This is a warning message';
|
|
const data = [1, 2, 3];
|
|
debugLogger.warn(message, data);
|
|
expect(spy).toHaveBeenCalledWith(message, data);
|
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('should call console.error with the correct arguments', () => {
|
|
const spy = vi.spyOn(console, 'error').mockImplementation(() => {});
|
|
const message = 'This is an error message';
|
|
const error = new Error('Something went wrong');
|
|
debugLogger.error(message, error);
|
|
expect(spy).toHaveBeenCalledWith(message, error);
|
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('should call console.debug with the correct arguments', () => {
|
|
const spy = vi.spyOn(console, 'debug').mockImplementation(() => {});
|
|
const message = 'This is a debug message';
|
|
const obj = { a: { b: 'c' } };
|
|
debugLogger.debug(message, obj);
|
|
expect(spy).toHaveBeenCalledWith(message, obj);
|
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('should handle multiple arguments correctly for all methods', () => {
|
|
const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
|
|
const errorSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
|
|
const debugSpy = vi.spyOn(console, 'debug').mockImplementation(() => {});
|
|
|
|
debugLogger.log('one', 2, true);
|
|
expect(logSpy).toHaveBeenCalledWith('one', 2, true);
|
|
|
|
debugLogger.warn('one', 2, false);
|
|
expect(warnSpy).toHaveBeenCalledWith('one', 2, false);
|
|
|
|
debugLogger.error('one', 2, null);
|
|
expect(errorSpy).toHaveBeenCalledWith('one', 2, null);
|
|
|
|
debugLogger.debug('one', 2, undefined);
|
|
expect(debugSpy).toHaveBeenCalledWith('one', 2, undefined);
|
|
});
|
|
|
|
it('should handle calls with no arguments', () => {
|
|
const logSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
|
|
|
|
debugLogger.log();
|
|
expect(logSpy).toHaveBeenCalledWith();
|
|
expect(logSpy).toHaveBeenCalledTimes(1);
|
|
|
|
debugLogger.warn();
|
|
expect(warnSpy).toHaveBeenCalledWith();
|
|
expect(warnSpy).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|