diff --git a/lib/internal/repl/utils.js b/lib/internal/repl/utils.js index ce0caf6d2a3eb7..27e1011ec9daf6 100644 --- a/lib/internal/repl/utils.js +++ b/lib/internal/repl/utils.js @@ -436,9 +436,9 @@ function setupPreview(repl, contextSymbol, bufferSymbol, active) { // Line breaks are very rare and probably only occur in case of error // messages with line breaks. - const lineBreakPos = StringPrototypeIndexOf(inspected, '\n'); - if (lineBreakPos !== -1) { - inspected = `${StringPrototypeSlice(inspected, 0, lineBreakPos)}`; + const lineBreakMatch = RegExpPrototypeExec(/[\r\n\v]/, inspected); + if (lineBreakMatch !== null) { + inspected = `${StringPrototypeSlice(inspected, 0, lineBreakMatch.index)}`; } const result = repl.useColors ? diff --git a/test/parallel/test-repl-preview-newlines.js b/test/parallel/test-repl-preview-newlines.js new file mode 100644 index 00000000000000..02d294032acd13 --- /dev/null +++ b/test/parallel/test-repl-preview-newlines.js @@ -0,0 +1,29 @@ +'use strict'; + +const common = require('../common'); +const ArrayStream = require('../common/arraystream'); +const assert = require('assert'); +const repl = require('repl'); + +common.skipIfInspectorDisabled(); + +const inputStream = new ArrayStream(); +const outputStream = new ArrayStream(); +repl.start({ + input: inputStream, + output: outputStream, + useGlobal: false, + terminal: true, + useColors: true +}); + +let output = ''; +outputStream.write = (chunk) => output += chunk; + +for (const char of ['\\n', '\\v', '\\r']) { + inputStream.emit('data', `"${char}"()`); + // Make sure the output is on a single line + assert.strictEqual(output, `"${char}"()\n\x1B[90mTypeError: "\x1B[39m\x1B[9G\x1B[1A`); + inputStream.run(['']); + output = ''; +}