persona-community-5/.pnpm-store/v3/files/45/6f3069ca8364afc72fc93d05aceeddfa26881d14236eed135b0cf9bd1eb6a3afddd288c3d9c263f7782df9e4c8a558612db8ee7cd8472593503f1ef42d300f
rdev-worker a1d0d1bf1c
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
build: /implement-feature community-ui --requirements 'Build the React commu...
2026-02-24 08:22:30 +00:00

48 lines
1.3 KiB
Plaintext

import * as colorette from 'colorette';
import { logger, colorize } from '../logger';
describe('Logger in nodejs', () => {
let spyingStderr: jest.SpyInstance;
beforeEach(() => {
spyingStderr = jest.spyOn(process.stderr, 'write').mockImplementation();
});
afterEach(() => {
spyingStderr.mockRestore();
});
it('should call "process.stderr.write" for error severity', () => {
logger.error('error');
expect(spyingStderr).toBeCalledTimes(1);
expect(spyingStderr).toBeCalledWith(colorette.red('error'));
});
it('should call "process.stderr.write" for warn severity', () => {
logger.warn('warn');
expect(spyingStderr).toBeCalledTimes(1);
expect(spyingStderr).toBeCalledWith(colorette.yellow('warn'));
});
it('should call "process.stderr.write" for info severity', () => {
logger.info('info');
expect(spyingStderr).toBeCalledTimes(1);
expect(spyingStderr).toBeCalledWith('info');
});
});
describe('colorize in nodejs', () => {
it('should call original colorette lib', () => {
const color = 'cyan';
const spyingCyan = jest.spyOn(colorette, color);
const colorized = colorize.cyan(color);
expect(spyingCyan).toBeCalledWith(color);
expect(colorized).toEqual(colorette[color](color));
});
});