pino/test/is-level-enabled.test.js
James Sumners 41d1706410
Convert tests to node:test (#2299)
* Convert tests to node:test

* broken-pipe.test.js

* browser-is-level-enabled.test.js

* complex-objects.test.js

* crlf.test.js

* custom-levels.test.js

* error.test.js

* error-key.test.js

* escaping.test.js

* exit.test.js

* formatters.test.js

* hooks.test.js

* http.test.js

* is-level-enabled.test.js

* levels.test.js

* metadata.test.js

* mixin.test.js

* mixin-merge-strategy.test.js

* multistream.test.js

* redact.test.js

* serializers.test.js

* stdout-protection.test.js

* syncfalse.test.js

* timestamp.test.js

* timestamp-nano.test.js

* transport-stream.test.js

* esm/*

* internals/version.test.js

* transport/big.test.js

* transport/bundlers-support.test.js

* transport/caller.test.js

* transport/core.test.js

* transport/core.transpiled.test.js

* transport/module-link.test.js

* transport/pipeline.test.js

* transport/repl.test.js

* transport/sync-false.test.js

* transport/sync-true.test.js

* transport/targets.test.js

* transport/uses-pino-config.test.js

* clean helper

* finalize

* restore transport/core.test.js

* address feedback

* skip broken-pipe in CITGM

* remove unused package

* remove duplicate test file
2025-10-03 06:12:54 -04:00

180 lines
6.0 KiB
JavaScript

'use strict'
const { describe, test } = require('node:test')
const assert = require('node:assert')
const pino = require('../')
const descLevels = {
trace: 60,
debug: 50,
info: 40,
warn: 30,
error: 20,
fatal: 10
}
const ascLevels = {
trace: 10,
debug: 20,
info: 30,
warn: 40,
error: 50,
fatal: 60
}
describe('Default levels suite', () => {
test('can check if current level enabled', async () => {
const log = pino({ level: 'debug' })
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if level enabled after level set', async () => {
const log = pino()
assert.equal(false, log.isLevelEnabled('debug'))
log.level = 'debug'
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if higher level enabled', async () => {
const log = pino({ level: 'debug' })
assert.equal(true, log.isLevelEnabled('error'))
})
test('can check if lower level is disabled', async () => {
const log = pino({ level: 'error' })
assert.equal(false, log.isLevelEnabled('trace'))
})
test('ASC: can check if child has current level enabled', async () => {
const log = pino().child({}, { level: 'debug' })
assert.equal(true, log.isLevelEnabled('debug'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
test('can check if custom level is enabled', async () => {
const log = pino({
customLevels: { foo: 35 },
level: 'debug'
})
assert.equal(true, log.isLevelEnabled('foo'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
})
describe('Ascending levels suite', () => {
const customLevels = ascLevels
const levelComparison = 'ASC'
test('can check if current level enabled', async () => {
const log = pino({ level: 'debug', levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if level enabled after level set', async () => {
const log = pino({ levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(false, log.isLevelEnabled('debug'))
log.level = 'debug'
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if higher level enabled', async () => {
const log = pino({ level: 'debug', levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(true, log.isLevelEnabled('error'))
})
test('can check if lower level is disabled', async () => {
const log = pino({ level: 'error', customLevels, useOnlyCustomLevels: true })
assert.equal(false, log.isLevelEnabled('trace'))
})
test('can check if child has current level enabled', async () => {
const log = pino().child({ levelComparison, customLevels, useOnlyCustomLevels: true }, { level: 'debug' })
assert.equal(true, log.isLevelEnabled('debug'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
test('can check if custom level is enabled', async () => {
const log = pino({
levelComparison,
useOnlyCustomLevels: true,
customLevels: { foo: 35, ...customLevels },
level: 'debug'
})
assert.equal(true, log.isLevelEnabled('foo'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
})
describe('Descending levels suite', () => {
const customLevels = descLevels
const levelComparison = 'DESC'
test('can check if current level enabled', async () => {
const log = pino({ level: 'debug', levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if level enabled after level set', async () => {
const log = pino({ levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(false, log.isLevelEnabled('debug'))
log.level = 'debug'
assert.equal(true, log.isLevelEnabled('debug'))
})
test('can check if higher level enabled', async () => {
const log = pino({ level: 'debug', levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(true, log.isLevelEnabled('error'))
})
test('can check if lower level is disabled', async () => {
const log = pino({ level: 'error', levelComparison, customLevels, useOnlyCustomLevels: true })
assert.equal(false, log.isLevelEnabled('trace'))
})
test('can check if child has current level enabled', async () => {
const log = pino({ levelComparison, customLevels, useOnlyCustomLevels: true }).child({}, { level: 'debug' })
assert.equal(true, log.isLevelEnabled('debug'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
test('can check if custom level is enabled', async () => {
const log = pino({
levelComparison,
customLevels: { foo: 35, ...customLevels },
useOnlyCustomLevels: true,
level: 'debug'
})
assert.equal(true, log.isLevelEnabled('foo'))
assert.equal(true, log.isLevelEnabled('error'))
assert.equal(false, log.isLevelEnabled('trace'))
})
})
describe('Custom levels comparison', () => {
test('Custom comparison returns true cause level is enabled', async () => {
const log = pino({ level: 'error', levelComparison: () => true })
assert.equal(true, log.isLevelEnabled('debug'))
})
test('Custom comparison returns false cause level is disabled', async () => {
const log = pino({ level: 'error', levelComparison: () => false })
assert.equal(false, log.isLevelEnabled('debug'))
})
test('Custom comparison returns true cause child level is enabled', async () => {
const log = pino({ levelComparison: () => true }).child({ level: 'error' })
assert.equal(true, log.isLevelEnabled('debug'))
})
test('Custom comparison returns false cause child level is disabled', async () => {
const log = pino({ levelComparison: () => false }).child({ level: 'error' })
assert.equal(false, log.isLevelEnabled('debug'))
})
})