From 5a6ea2f30684a8c2beeb467504ab90dc1b0ed31e Mon Sep 17 00:00:00 2001 From: Daniel Roe Date: Tue, 21 Jan 2025 10:22:08 +0000 Subject: [PATCH 1/2] chore: improve debugging plugins --- debug/plugins/timings-babel.mjs | 18 +++++++++--------- debug/plugins/timings-unbuild.ts | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/debug/plugins/timings-babel.mjs b/debug/plugins/timings-babel.mjs index 75d8b64ab1..3c5a56236d 100644 --- a/debug/plugins/timings-babel.mjs +++ b/debug/plugins/timings-babel.mjs @@ -60,7 +60,7 @@ function onExit () { const topFunctionsTotalTime = timings .sort((a, b) => b[1] - a[1]) - .slice(0, 10) + .slice(0, 20) .map(([name, time]) => ({ name, time: Number(Number(time).toFixed(2)), @@ -69,7 +69,7 @@ function onExit () { })) // eslint-disable-next-line no-console - console.log('Top 10 functions by total time:') + console.log('Top 20 functions by total time:') // eslint-disable-next-line no-console console.table(topFunctionsTotalTime) @@ -79,7 +79,7 @@ function onExit () { .map(([name, time]) => [name, time / (globalThis.___calls[name] || 1)]) // @ts-expect-error .sort((a, b) => b[1] - a[1]) - .slice(0, 10) + .slice(0, 20) .map(([name, time]) => ({ name, time: Number(Number(time).toFixed(2)), @@ -88,7 +88,7 @@ function onExit () { })) // eslint-disable-next-line no-console - console.log('Top 10 functions by average time:') + console.log('Top 20 functions by average time:') // eslint-disable-next-line no-console console.table(topFunctionsAverageTime) } @@ -98,20 +98,20 @@ export const trailing = `process.on("exit", ${onExit.toString()})` /** @param {string} functionName */ export function generateInitCode (functionName) { return ` - ___calls.${functionName} = (___calls.${functionName} || 0) + 1; - ___timings.${functionName} ||= 0; + ___calls[${JSON.stringify(functionName)}] = (___calls[${JSON.stringify(functionName)}] || 0) + 1; + ___timings[${JSON.stringify(functionName)}] ||= 0; const ___now = Date.now();` } /** @param {string} functionName */ export function generateFinallyCode (functionName) { return ` - ___timings.${functionName} += Date.now() - ___now; + ___timings[${JSON.stringify(functionName)}] += Date.now() - ___now; try { const ___callee = ___captureStackTrace()[1]?.function; if (___callee) { - ___callers.${functionName} ||= {}; - ___callers.${functionName}[' ' + ___callee] = (___callers.${functionName}[' ' + ___callee] || 0) + 1; + ___callers[${JSON.stringify(functionName)}] ||= {}; + ___callers[${JSON.stringify(functionName)}][' ' + ___callee] = (___callers[${JSON.stringify(functionName)}][' ' + ___callee] || 0) + 1; } } catch {}` } diff --git a/debug/plugins/timings-unbuild.ts b/debug/plugins/timings-unbuild.ts index 8916305b4e..09574dd347 100644 --- a/debug/plugins/timings-unbuild.ts +++ b/debug/plugins/timings-unbuild.ts @@ -29,7 +29,7 @@ export function AnnotateFunctionTimingsPlugin () { walk(ast as Node, { enter (node) { if (node.type === 'FunctionDeclaration' && node.id && node.id.name) { - const functionName = node.id.name + const functionName = node.id.name ? `${node.id.name} (${id.match(/\/packages\/([^/]+)\//)?.[1]})` : '' const start = (node.body as Node & { start: number, end: number }).start const end = (node.body as Node & { start: number, end: number }).end From f458153d9fda237724c61b1714c56c23221961e1 Mon Sep 17 00:00:00 2001 From: Daniel Roe Date: Tue, 21 Jan 2025 10:24:43 +0000 Subject: [PATCH 2/2] test: update bundle size assertion --- test/bundle.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/bundle.test.ts b/test/bundle.test.ts index 18b1aa3faa..43bf31d6df 100644 --- a/test/bundle.test.ts +++ b/test/bundle.test.ts @@ -127,7 +127,7 @@ describe.skipIf(process.env.SKIP_BUNDLE_SIZE === 'true' || process.env.ECOSYSTEM const serverDir = join(pagesRootDir, '.output/server') const serverStats = await analyzeSizes(['**/*.mjs', '!node_modules'], serverDir) - expect.soft(roundToKilobytes(serverStats.totalBytes)).toMatchInlineSnapshot(`"303k"`) + expect.soft(roundToKilobytes(serverStats.totalBytes)).toMatchInlineSnapshot(`"302k"`) const modules = await analyzeSizes(['node_modules/**/*'], serverDir) expect.soft(roundToKilobytes(modules.totalBytes)).toMatchInlineSnapshot(`"1398k"`)