2022-08-18 21:39:34 +02:00
|
|
|
import { readFile } from 'fs/promises';
|
|
|
|
import { join } from 'path';
|
2023-02-05 21:00:32 +01:00
|
|
|
import pino from 'pino';
|
2022-08-18 21:39:34 +02:00
|
|
|
import { setTimeout } from 'timers/promises';
|
2024-12-07 22:35:48 +01:00
|
|
|
import { describe, expect, test } from 'vitest';
|
2021-10-27 16:53:02 +02:00
|
|
|
|
2022-08-18 21:39:34 +02:00
|
|
|
import { fileUtils } from '@verdaccio/core';
|
2021-10-27 16:53:02 +02:00
|
|
|
|
2022-08-18 21:39:34 +02:00
|
|
|
import { prepareSetup } from '../src';
|
|
|
|
|
|
|
|
async function readLogFile(path: string) {
|
|
|
|
await setTimeout(1000, 'resolved');
|
|
|
|
return readFile(path, 'utf8');
|
|
|
|
}
|
2020-04-13 14:34:26 +02:00
|
|
|
|
2022-08-18 21:39:34 +02:00
|
|
|
async function createLogFile() {
|
2024-11-16 04:43:12 -05:00
|
|
|
const folder = await fileUtils.createTempFolder('logger');
|
2022-08-18 21:39:34 +02:00
|
|
|
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 21:00:32 +01:00
|
|
|
const logger = prepareSetup({ type: 'file', path: file, colors: false }, pino);
|
2022-08-18 21:39:34 +02: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);
|
2024-06-01 12:35:06 -07:00
|
|
|
expect(content).toBe('info --- testing test\nerror--- this should logged\n');
|
2022-08-18 21:39:34 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should include all logging level', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 21:00:32 +01:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{ type: 'file', level: 'trace', path: file, colors: false },
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 21:39:34 +02: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(
|
2024-06-01 12:35:06 -07:00
|
|
|
'info --- testing test\ndebug--- this should not be logged\ntrace--- this should not be logged\nerror--- this should logged\n'
|
2022-08-18 21:39:34 +02:00
|
|
|
);
|
|
|
|
});
|
2020-08-13 23:27:00 +02:00
|
|
|
});
|
2021-09-19 23:50:46 +05:30
|
|
|
|
2022-08-18 21:39:34 +02:00
|
|
|
describe('json format', () => {
|
|
|
|
test('should log into a file with json format', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 21:00:32 +01:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
...defaultOptions,
|
|
|
|
format: 'json',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'info',
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 21:39:34 +02: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 23:50:46 +05:30
|
|
|
});
|
|
|
|
|
2022-08-18 21:39:34 +02:00
|
|
|
describe('pretty format', () => {
|
|
|
|
test('should log into a file with pretty', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 21:00:32 +01:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
format: 'pretty',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'trace',
|
|
|
|
colors: false,
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 21:39:34 +02:00
|
|
|
logger.info(
|
|
|
|
{ packageName: 'test' },
|
|
|
|
`publishing or updating a new version for @{packageName}`
|
|
|
|
);
|
|
|
|
const content = await readLogFile(file);
|
2024-06-01 12:35:06 -07:00
|
|
|
expect(content).toEqual('info --- publishing or updating a new version for test\n');
|
2022-08-18 21:39:34 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should log into a file with pretty-timestamped', async () => {
|
|
|
|
const file = await createLogFile();
|
2023-02-05 21:00:32 +01:00
|
|
|
const logger = prepareSetup(
|
|
|
|
{
|
|
|
|
format: 'pretty-timestamped',
|
|
|
|
type: 'file',
|
|
|
|
path: file,
|
|
|
|
level: 'trace',
|
|
|
|
colors: false,
|
|
|
|
},
|
|
|
|
pino
|
|
|
|
);
|
2022-08-18 21:39:34 +02: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
|
2024-06-01 12:35:06 -07:00
|
|
|
expect(content).toMatch('info --- publishing or updating a new version for test\n');
|
2022-08-18 21:39:34 +02:00
|
|
|
});
|
2021-09-19 23:50:46 +05:30
|
|
|
});
|
2020-04-13 14:34:26 +02:00
|
|
|
});
|