2022-08-18 14:39:34 -05:00
|
|
|
import { readFile } from 'fs/promises';
|
|
|
|
import { join } from 'path';
|
2023-02-05 15:00:32 -05:00
|
|
|
import pino from 'pino';
|
2022-08-18 14:39:34 -05:00
|
|
|
import { setTimeout } from 'timers/promises';
|
2021-10-27 09:53:02 -05:00
|
|
|
|
2022-08-18 14:39:34 -05:00
|
|
|
import { fileUtils } from '@verdaccio/core';
|
2021-10-27 09:53:02 -05:00
|
|
|
|
2022-08-18 14:39:34 -05:00
|
|
|
import { prepareSetup } from '../src';
|
|
|
|
|
|
|
|
async function readLogFile(path: string) {
|
|
|
|
await setTimeout(1000, 'resolved');
|
|
|
|
return readFile(path, 'utf8');
|
|
|
|
}
|
2020-04-13 07:34:26 -05:00
|
|
|
|
2022-08-18 14:39:34 -05:00
|
|
|
async function createLogFile() {
|
|
|
|
const folder = await fileUtils.createTempFolder('logger-1');
|
|
|
|
const file = join(folder, 'logger.log');
|
|
|
|
return file;
|
|
|
|
}
|
|
|
|
|
|
|
|
const defaultOptions = {
|
|
|
|
format: 'json',
|
|
|
|
level: 'http',
|
|
|
|
colors: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('logger test', () => {
|
|
|
|
describe('basic', () => {
|
|
|
|
test('should include default level', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 15:00:32 -05:00
|
|
|
const logger = prepareSetup({ type: 'file', path: file, colors: false }, pino);
|
2022-08-18 14:39:34 -05:00
|
|
|
logger.info({ packageName: 'test' }, `testing @{packageName}`);
|
|
|
|
// Note: this should not be logged
|
|
|
|
logger.debug(`this should not be logged`);
|
|
|
|
// Note: this should not be logged
|
|
|
|
logger.trace(`this should not be logged`);
|
|
|
|
logger.error(`this should logged`);
|
|
|
|
const content = await readLogFile(file);
|
|
|
|
expect(content).toBe('info --- testing test \nerror--- this should logged \n');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should include all logging level', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 15:00:32 -05:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{ type: 'file', level: 'trace', path: file, colors: false },
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 14:39:34 -05:00
|
|
|
logger.info({ packageName: 'test' }, `testing @{packageName}`);
|
|
|
|
logger.debug(`this should not be logged`);
|
|
|
|
logger.trace(`this should not be logged`);
|
|
|
|
logger.error(`this should logged`);
|
|
|
|
const content = await readLogFile(file);
|
|
|
|
expect(content).toBe(
|
|
|
|
'info --- testing test \ndebug--- this should not be logged \ntrace--- this should not be logged \nerror--- this should logged \n'
|
|
|
|
);
|
|
|
|
});
|
2020-08-13 16:27:00 -05:00
|
|
|
});
|
2021-09-19 13:20:46 -05:00
|
|
|
|
2022-08-18 14:39:34 -05:00
|
|
|
describe('json format', () => {
|
|
|
|
test('should log into a file with json format', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 15:00:32 -05:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
...defaultOptions,
|
|
|
|
format: 'json',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'info',
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 14:39:34 -05:00
|
|
|
logger.info(
|
|
|
|
{ packageName: 'test' },
|
|
|
|
`publishing or updating a new version for @{packageName}`
|
|
|
|
);
|
|
|
|
const content = await readLogFile(file);
|
|
|
|
expect(JSON.parse(content)).toEqual(
|
|
|
|
expect.objectContaining({
|
|
|
|
level: 30,
|
|
|
|
msg: 'publishing or updating a new version for test',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
2021-09-19 13:20:46 -05:00
|
|
|
});
|
|
|
|
|
2022-08-18 14:39:34 -05:00
|
|
|
describe('pretty format', () => {
|
|
|
|
test('should log into a file with pretty', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 15:00:32 -05:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
format: 'pretty',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'trace',
|
|
|
|
colors: false,
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 14:39:34 -05:00
|
|
|
logger.info(
|
|
|
|
{ packageName: 'test' },
|
|
|
|
`publishing or updating a new version for @{packageName}`
|
|
|
|
);
|
|
|
|
const content = await readLogFile(file);
|
|
|
|
expect(content).toEqual('info --- publishing or updating a new version for test \n');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should log into a file with pretty-timestamped', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 15:00:32 -05:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
format: 'pretty-timestamped',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'trace',
|
|
|
|
colors: false,
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 14:39:34 -05:00
|
|
|
logger.info(
|
|
|
|
{ packageName: 'test' },
|
|
|
|
`publishing or updating a new version for @{packageName}`
|
|
|
|
);
|
|
|
|
const content = await readLogFile(file);
|
|
|
|
// TODO: we might want mock time for testing
|
|
|
|
expect(content).toMatch('info --- publishing or updating a new version for test \n');
|
|
|
|
});
|
2021-09-19 13:20:46 -05:00
|
|
|
});
|
2020-04-13 07:34:26 -05:00
|
|
|
});
|