diff --git a/packages/build/src/plugins/system_log.ts b/packages/build/src/plugins/system_log.ts index fa90a81f74..caad1bc840 100644 --- a/packages/build/src/plugins/system_log.ts +++ b/packages/build/src/plugins/system_log.ts @@ -15,22 +15,20 @@ export const captureStandardError = ( } } - let receivedChunks = false + let buffer = '' const listener = (chunk: Buffer) => { - if (!receivedChunks) { - receivedChunks = true - - systemLog(`Plugin failed to initialize during the "${eventName}" phase`) - } - - systemLog(chunk.toString().trimEnd()) + buffer += chunk.toString() } childProcess.stderr?.on('data', listener) const cleanup = () => { childProcess.stderr?.removeListener('data', listener) + + if (buffer.length !== 0) { + systemLog(`Plugin failed to initialize during the "${eventName}" phase: ${buffer.trim()}`) + } } return cleanup diff --git a/packages/build/tests/plugins/tests.js b/packages/build/tests/plugins/tests.js index 630b1f6d6f..9bea23fe4c 100644 --- a/packages/build/tests/plugins/tests.js +++ b/packages/build/tests/plugins/tests.js @@ -360,10 +360,8 @@ test('Plugin errors that occur during the loading phase are piped to system logs if (platform !== 'win32') { const systemLog = await fs.readFile(systemLogFile.path, { encoding: 'utf8' }) - const lines = systemLog.split('\n') - t.is(lines[0].trim(), 'Plugin failed to initialize during the "load" phase') - t.is(lines[1].trim(), 'An error message thrown by Node.js') + t.is(systemLog.trim(), `Plugin failed to initialize during the "load" phase: An error message thrown by Node.js`) } t.snapshot(normalizeOutput(output))