mirror of
https://github.com/pinojs/pino.git
synced 2025-12-08 20:36:13 +00:00
* 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
37 lines
1.0 KiB
JavaScript
37 lines
1.0 KiB
JavaScript
'use strict'
|
|
|
|
const test = require('node:test')
|
|
const assert = require('node:assert')
|
|
const { PassThrough } = require('node:stream')
|
|
|
|
const { sink, once } = require('./helper')
|
|
const pino = require('../')
|
|
|
|
test('Proxy and stream objects', async () => {
|
|
const s = new PassThrough()
|
|
s.resume()
|
|
s.write('', () => {})
|
|
const obj = { s, p: new Proxy({}, { get () { throw new Error('kaboom') } }) }
|
|
const stream = sink()
|
|
const instance = pino(stream)
|
|
instance.info({ obj })
|
|
|
|
const result = await once(stream, 'data')
|
|
|
|
assert.equal(result.obj, '[unable to serialize, circular reference is too complex to analyze]')
|
|
})
|
|
|
|
test('Proxy and stream objects', async () => {
|
|
const s = new PassThrough()
|
|
s.resume()
|
|
s.write('', () => {})
|
|
const obj = { s, p: new Proxy({}, { get () { throw new Error('kaboom') } }) }
|
|
const stream = sink()
|
|
const instance = pino(stream)
|
|
instance.info(obj)
|
|
|
|
const result = await once(stream, 'data')
|
|
|
|
assert.equal(result.p, '[unable to serialize, circular reference is too complex to analyze]')
|
|
})
|