summaryrefslogtreecommitdiff
path: root/test/parallel
diff options
context:
space:
mode:
authorLance Ball <lball@redhat.com>2017-09-11 18:24:21 -0400
committerLance Ball <lball@redhat.com>2017-10-11 14:51:41 -0400
commitc5f54b1fad19a35dc00322181650545d2961ccc4 (patch)
tree95fa0b5657b1aed4a77003ccfea0d61b98d973c7 /test/parallel
parent07f1efc2aeb68d993c8e132e3c3c52881c7f6670 (diff)
downloadandroid-node-v8-c5f54b1fad19a35dc00322181650545d2961ccc4.tar.gz
android-node-v8-c5f54b1fad19a35dc00322181650545d2961ccc4.tar.bz2
android-node-v8-c5f54b1fad19a35dc00322181650545d2961ccc4.zip
repl: remove internal frames from runtime errors
When a user executes code in the REPLServer which generates an exception, there is no need to display the REPLServer internal stack frames. PR-URL: https://github.com/nodejs/node/pull/15351 Reviewed-By: Prince John Wesley <princejohnwesley@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Refs: https://github.com/nodejs/node/pull/9601
Diffstat (limited to 'test/parallel')
-rw-r--r--test/parallel/test-repl-pretty-custom-stack.js70
-rw-r--r--test/parallel/test-repl-pretty-stack.js55
-rw-r--r--test/parallel/test-repl.js2
3 files changed, 126 insertions, 1 deletions
diff --git a/test/parallel/test-repl-pretty-custom-stack.js b/test/parallel/test-repl-pretty-custom-stack.js
new file mode 100644
index 0000000000..be102c1d67
--- /dev/null
+++ b/test/parallel/test-repl-pretty-custom-stack.js
@@ -0,0 +1,70 @@
+'use strict';
+const common = require('../common');
+const fixtures = require('../common/fixtures');
+const assert = require('assert');
+const repl = require('repl');
+
+
+function run({ command, expected }) {
+ let accum = '';
+
+ const inputStream = new common.ArrayStream();
+ const outputStream = new common.ArrayStream();
+
+ outputStream.write = (data) => accum += data.replace('\r', '');
+
+ const r = repl.start({
+ prompt: '',
+ input: inputStream,
+ output: outputStream,
+ terminal: false,
+ useColors: false
+ });
+
+ r.write(`${command}\n`);
+ assert.strictEqual(accum, expected);
+ r.close();
+}
+
+const origPrepareStackTrace = Error.prepareStackTrace;
+Error.prepareStackTrace = (err, stack) => {
+ if (err instanceof SyntaxError)
+ return err.toString();
+ stack.push(err);
+ return stack.reverse().join('--->\n');
+};
+
+process.on('uncaughtException', (e) => {
+ Error.prepareStackTrace = origPrepareStackTrace;
+ throw e;
+});
+
+process.on('exit', () => (Error.prepareStackTrace = origPrepareStackTrace));
+
+const tests = [
+ {
+ // test .load for a file that throws
+ command: `.load ${fixtures.path('repl-pretty-stack.js')}`,
+ expected: 'Error: Whoops!--->\nrepl:9:24--->\nd (repl:12:3)--->\nc ' +
+ '(repl:9:3)--->\nb (repl:6:3)--->\na (repl:3:3)\n'
+ },
+ {
+ command: 'let x y;',
+ expected: 'let x y;\n ^\n\nSyntaxError: Unexpected identifier\n'
+ },
+ {
+ command: 'throw new Error(\'Whoops!\')',
+ expected: 'Error: Whoops!\n'
+ },
+ {
+ command: 'foo = bar;',
+ expected: 'ReferenceError: bar is not defined\n'
+ },
+ // test anonymous IIFE
+ {
+ command: '(function() { throw new Error(\'Whoops!\'); })()',
+ expected: 'Error: Whoops!--->\nrepl:1:21\n'
+ }
+];
+
+tests.forEach(run);
diff --git a/test/parallel/test-repl-pretty-stack.js b/test/parallel/test-repl-pretty-stack.js
new file mode 100644
index 0000000000..0fc6b3ada0
--- /dev/null
+++ b/test/parallel/test-repl-pretty-stack.js
@@ -0,0 +1,55 @@
+'use strict';
+const common = require('../common');
+const fixtures = require('../common/fixtures');
+const assert = require('assert');
+const repl = require('repl');
+
+
+function run({ command, expected }) {
+ let accum = '';
+
+ const inputStream = new common.ArrayStream();
+ const outputStream = new common.ArrayStream();
+
+ outputStream.write = (data) => accum += data.replace('\r', '');
+
+ const r = repl.start({
+ prompt: '',
+ input: inputStream,
+ output: outputStream,
+ terminal: false,
+ useColors: false
+ });
+
+ r.write(`${command}\n`);
+ assert.strictEqual(accum, expected);
+ r.close();
+}
+
+const tests = [
+ {
+ // test .load for a file that throws
+ command: `.load ${fixtures.path('repl-pretty-stack.js')}`,
+ expected: 'Error: Whoops!\n at repl:9:24\n at d (repl:12:3)\n ' +
+ 'at c (repl:9:3)\n at b (repl:6:3)\n at a (repl:3:3)\n'
+ },
+ {
+ command: 'let x y;',
+ expected: 'let x y;\n ^\n\nSyntaxError: Unexpected identifier\n\n'
+ },
+ {
+ command: 'throw new Error(\'Whoops!\')',
+ expected: 'Error: Whoops!\n'
+ },
+ {
+ command: 'foo = bar;',
+ expected: 'ReferenceError: bar is not defined\n'
+ },
+ // test anonymous IIFE
+ {
+ command: '(function() { throw new Error(\'Whoops!\'); })()',
+ expected: 'Error: Whoops!\n at repl:1:21\n'
+ }
+];
+
+tests.forEach(run);
diff --git a/test/parallel/test-repl.js b/test/parallel/test-repl.js
index 6df856a20e..54ad848b5b 100644
--- a/test/parallel/test-repl.js
+++ b/test/parallel/test-repl.js
@@ -71,7 +71,7 @@ function clean_up() {
function strict_mode_error_test() {
send_expect([
{ client: client_unix, send: 'ref = 1',
- expect: /^ReferenceError:\sref\sis\snot\sdefined\n\s+at\srepl:1:5/ },
+ expect: /^ReferenceError:\sref\sis\snot\sdefined\nnode via Unix socket> $/ },
]);
}