From 489785d5d4ba9d52050512e6a1c3039c8e19f523 Mon Sep 17 00:00:00 2001 From: Vladimir Date: Wed, 19 Jun 2024 21:37:05 +0200 Subject: [PATCH] refactor(browser): prefer pretty-print for objects (#5928) --- packages/browser/src/client/tester/logger.ts | 45 ++++++++++---------- test/browser/specs/runner.test.ts | 12 +++++- 2 files changed, 32 insertions(+), 25 deletions(-) diff --git a/packages/browser/src/client/tester/logger.ts b/packages/browser/src/client/tester/logger.ts index c7dcee45ae37..f493588c8a5c 100644 --- a/packages/browser/src/client/tester/logger.ts +++ b/packages/browser/src/client/tester/logger.ts @@ -1,4 +1,4 @@ -import { format, inspect, stringify } from 'vitest/utils' +import { format, stringify } from 'vitest/utils' import { getConfig } from '../utils' import { rpc } from './rpc' @@ -21,8 +21,11 @@ export function setupConsoleLogSpy() { countReset, } = console const formatInput = (input: unknown) => { - if (input instanceof Node) { - return stringify(input) + if (typeof input === 'object') { + return stringify(input, undefined, { + printBasicPrototype: false, + escapeString: false, + }) } return format(input) } @@ -52,18 +55,14 @@ export function setupConsoleLogSpy() { size: content.length, }) } - const stdout - = (base: (...args: unknown[]) => void) => - (...args: unknown[]) => { - sendLog('stdout', processLog(args)) - return base(...args) - } - const stderr - = (base: (...args: unknown[]) => void) => - (...args: unknown[]) => { - sendLog('stderr', processLog(args)) - return base(...args) - } + const stdout = (base: (...args: unknown[]) => void) => (...args: unknown[]) => { + base(...args) + sendLog('stdout', processLog(args)) + } + const stderr = (base: (...args: unknown[]) => void) => (...args: unknown[]) => { + base(...args) + sendLog('stderr', processLog(args)) + } console.log = stdout(log) console.debug = stdout(debug) console.info = stdout(info) @@ -72,16 +71,17 @@ export function setupConsoleLogSpy() { console.warn = stderr(warn) console.dir = (item, options) => { - sendLog('stdout', inspect(item, options)) - return dir(item, options) + dir(item, options) + sendLog('stdout', formatInput(item)) } console.dirxml = (...args) => { + dirxml(...args) sendLog('stdout', processLog(args)) - return dirxml(...args) } console.trace = (...args: unknown[]) => { + trace(...args) const content = processLog(args) const error = new Error('$$Trace') const stack = (error.stack || '') @@ -89,14 +89,13 @@ export function setupConsoleLogSpy() { .slice(error.stack?.includes('$$Trace') ? 2 : 1) .join('\n') sendLog('stderr', `${content}\n${stack}`, true) - return trace(...args) } const timeLabels: Record = {} console.time = (label = 'default') => { - const now = performance.now() time(label) + const now = performance.now() timeLabels[label] = now } @@ -111,8 +110,8 @@ export function setupConsoleLogSpy() { } console.timeEnd = (label = 'default') => { - const end = performance.now() timeEnd(label) + const end = performance.now() const start = timeLabels[label] if (!(label in timeLabels)) { sendLog('stderr', `Timer "${label}" does not exist`) @@ -126,14 +125,14 @@ export function setupConsoleLogSpy() { const countLabels: Record = {} console.count = (label = 'default') => { + count(label) const counter = (countLabels[label] ?? 0) + 1 countLabels[label] = counter sendLog('stdout', `${label}: ${counter}`) - return count(label) } console.countReset = (label = 'default') => { + countReset(label) countLabels[label] = 0 - return countReset(label) } } diff --git a/test/browser/specs/runner.test.ts b/test/browser/specs/runner.test.ts index f139c09b2589..3fcc77469f10 100644 --- a/test/browser/specs/runner.test.ts +++ b/test/browser/specs/runner.test.ts @@ -43,8 +43,16 @@ describe('running browser tests', async () => { expect(stdout).toContain('hello from console.log') expect(stdout).toContain('hello from console.info') expect(stdout).toContain('hello from console.debug') - expect(stdout).toContain('{ hello: \'from dir\' }') - expect(stdout).toContain('{ hello: \'from dirxml\' }') + expect(stdout).toContain(` +{ + "hello": "from dir", +} + `.trim()) + expect(stdout).toContain(` +{ + "hello": "from dirxml", +} + `.trim()) expect(stdout).toContain('dom
') expect(stdout).toContain('default: 1') expect(stdout).toContain('default: 2')