mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-15 17:16:25 +00:00
92 lines
2.4 KiB
TypeScript
92 lines
2.4 KiB
TypeScript
import chalk from 'chalk';
|
|
import * as prettyStdout from './pretty-stdout';
|
|
import { BunyanRecord } from './utils';
|
|
|
|
jest.mock('chalk', () =>
|
|
['bgRed', 'blue', 'gray', 'green', 'magenta', 'red'].reduce(
|
|
(r, c) => Object.defineProperty(r, c, { value: (s: string) => s }),
|
|
{}
|
|
)
|
|
);
|
|
|
|
describe('logger/pretty-stdout', () => {
|
|
describe('getMeta(rec)', () => {
|
|
it('returns empty string if null rec', () => {
|
|
expect(prettyStdout.getMeta(null as any)).toEqual('');
|
|
});
|
|
it('returns empty string if empty rec', () => {
|
|
expect(prettyStdout.getMeta({} as any)).toEqual('');
|
|
});
|
|
it('returns empty string if no meta fields', () => {
|
|
const rec = {
|
|
foo: 'bar',
|
|
};
|
|
expect(prettyStdout.getMeta(rec as any)).toEqual('');
|
|
});
|
|
it('supports single meta', () => {
|
|
const rec = {
|
|
foo: 'bar',
|
|
repository: 'a/b',
|
|
};
|
|
expect(prettyStdout.getMeta(rec as any)).toEqual(
|
|
chalk.gray(' (repository=a/b)')
|
|
);
|
|
});
|
|
it('supports multi meta', () => {
|
|
const rec = {
|
|
foo: 'bar',
|
|
branch: 'c',
|
|
repository: 'a/b',
|
|
module: 'test',
|
|
};
|
|
expect(prettyStdout.getMeta(rec as any)).toEqual(
|
|
chalk.gray(' (repository=a/b, branch=c) [test]')
|
|
);
|
|
});
|
|
});
|
|
describe('getDetails(rec)', () => {
|
|
it('returns empty string if null rec', () => {
|
|
expect(prettyStdout.getDetails(null as any)).toEqual('');
|
|
});
|
|
it('returns empty string if empty rec', () => {
|
|
expect(prettyStdout.getDetails({} as any)).toEqual('');
|
|
});
|
|
it('returns empty string if all are meta fields', () => {
|
|
const rec = {
|
|
branch: 'bar',
|
|
v: 0,
|
|
};
|
|
expect(prettyStdout.getDetails(rec as any)).toEqual('');
|
|
});
|
|
it('supports a config', () => {
|
|
const rec = {
|
|
v: 0,
|
|
config: {
|
|
a: 'b',
|
|
d: ['e', 'f'],
|
|
},
|
|
};
|
|
expect(prettyStdout.getDetails(rec as any)).toMatchSnapshot();
|
|
});
|
|
});
|
|
describe('formatRecord(rec)', () => {
|
|
beforeEach(() => {
|
|
process.env.FORCE_COLOR = '1';
|
|
});
|
|
afterEach(() => {
|
|
delete process.env.FORCE_COLOR;
|
|
});
|
|
it('formats record', () => {
|
|
const rec: BunyanRecord = {
|
|
level: 10,
|
|
msg: 'test message',
|
|
v: 0,
|
|
config: {
|
|
a: 'b',
|
|
d: ['e', 'f'],
|
|
},
|
|
};
|
|
expect(prettyStdout.formatRecord(rec)).toMatchSnapshot();
|
|
});
|
|
});
|
|
});
|