From 483e3d5e4b006d65ebeacef06b8bfacbd475c9d0 Mon Sep 17 00:00:00 2001 From: Chengzhong Wu Date: Thu, 9 Jan 2025 14:06:31 +0000 Subject: [PATCH] src: fix undefined script name in error source PR-URL: https://github.com/nodejs/node/pull/56502 Reviewed-By: Joyee Cheung Reviewed-By: James M Snell --- src/node_errors.cc | 9 +++++++-- test/fixtures/errors/throw_in_eval_anonymous.js | 9 +++++++++ test/fixtures/errors/throw_in_eval_anonymous.snapshot | 8 ++++++++ test/fixtures/errors/throw_in_eval_named.js | 9 +++++++++ test/fixtures/errors/throw_in_eval_named.snapshot | 8 ++++++++ test/parallel/test-node-output-errors.mjs | 2 ++ 6 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 test/fixtures/errors/throw_in_eval_anonymous.js create mode 100644 test/fixtures/errors/throw_in_eval_anonymous.snapshot create mode 100644 test/fixtures/errors/throw_in_eval_named.js create mode 100644 test/fixtures/errors/throw_in_eval_named.snapshot diff --git a/src/node_errors.cc b/src/node_errors.cc index 65f95c3157add2..609601328f7f5f 100644 --- a/src/node_errors.cc +++ b/src/node_errors.cc @@ -136,8 +136,13 @@ static std::string GetErrorSource(Isolate* isolate, // Print (filename):(line number): (message). ScriptOrigin origin = message->GetScriptOrigin(); - node::Utf8Value filename(isolate, message->GetScriptResourceName()); - const char* filename_string = *filename; + std::string filename_string; + if (message->GetScriptResourceName()->IsUndefined()) { + filename_string = ""; + } else { + node::Utf8Value filename(isolate, message->GetScriptResourceName()); + filename_string = filename.ToString(); + } int linenum = message->GetLineNumber(context).FromJust(); int script_start = (linenum - origin.LineOffset()) == 1 diff --git a/test/fixtures/errors/throw_in_eval_anonymous.js b/test/fixtures/errors/throw_in_eval_anonymous.js new file mode 100644 index 00000000000000..aa9ab6a05803bb --- /dev/null +++ b/test/fixtures/errors/throw_in_eval_anonymous.js @@ -0,0 +1,9 @@ +'use strict'; +require('../../common'); + +Error.stackTraceLimit = 1; +eval(` + + throw new Error('error in anonymous script'); + +`) diff --git a/test/fixtures/errors/throw_in_eval_anonymous.snapshot b/test/fixtures/errors/throw_in_eval_anonymous.snapshot new file mode 100644 index 00000000000000..e6f731f4d99cd7 --- /dev/null +++ b/test/fixtures/errors/throw_in_eval_anonymous.snapshot @@ -0,0 +1,8 @@ +:* + throw new Error('error in anonymous script'); + ^ + +Error: error in anonymous script + at eval (eval at (*throw_in_eval_anonymous.js:*:*), :*:*) + +Node.js * diff --git a/test/fixtures/errors/throw_in_eval_named.js b/test/fixtures/errors/throw_in_eval_named.js new file mode 100644 index 00000000000000..0d33fcf4d05dd5 --- /dev/null +++ b/test/fixtures/errors/throw_in_eval_named.js @@ -0,0 +1,9 @@ +'use strict'; +require('../../common'); + +Error.stackTraceLimit = 1; +eval(` + + throw new Error('error in named script'); + +//# sourceURL=evalscript.js`) diff --git a/test/fixtures/errors/throw_in_eval_named.snapshot b/test/fixtures/errors/throw_in_eval_named.snapshot new file mode 100644 index 00000000000000..3be4c3584735fb --- /dev/null +++ b/test/fixtures/errors/throw_in_eval_named.snapshot @@ -0,0 +1,8 @@ +evalscript.js:* + throw new Error('error in named script'); + ^ + +Error: error in named script + at eval (evalscript.js:*:*) + +Node.js * diff --git a/test/parallel/test-node-output-errors.mjs b/test/parallel/test-node-output-errors.mjs index 1f93330834ea64..3d913475d8d2a0 100644 --- a/test/parallel/test-node-output-errors.mjs +++ b/test/parallel/test-node-output-errors.mjs @@ -63,6 +63,8 @@ describe('errors output', { concurrency: !process.env.TEST_PARALLEL }, () => { { name: 'errors/if-error-has-good-stack.js', transform: errTransform }, { name: 'errors/throw_custom_error.js', transform: errTransform }, { name: 'errors/throw_error_with_getter_throw.js', transform: errTransform }, + { name: 'errors/throw_in_eval_anonymous.js', transform: errTransform }, + { name: 'errors/throw_in_eval_named.js', transform: errTransform }, { name: 'errors/throw_in_line_with_tabs.js', transform: errTransform }, { name: 'errors/throw_non_error.js', transform: errTransform }, { name: 'errors/throw_null.js', transform: errTransform },