Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

errors: print original exception context #33491

Closed
wants to merge 1 commit into from

Conversation

bcoe
Copy link
Contributor

@bcoe bcoe commented May 21, 2020

When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

When --enable-source-maps is set, annotate the top of the stack trace with the original source, rather than the ugly transpiled source:

before:

  if ((obj === null || obj === void 0 ? void 0 : (_obj$a = obj.a) === null || _obj$a === void 0 ? void 0 : _obj$a.b) === 22) throw Error('an exception');

after:

/Users/bencoe/oss/node-1/test/fixtures/source-map/babel-throw-original.js:18
  if (obj?.a?.b === 22) throw Error('an exception');

Open questions

The logic in node_errors.cc is a little magical to me, specifically I'm trying to figure out how it's placing the ^ under the throw, rather than under the Error (which is where the stack trace points).

@addaleax I know you've also worked in this file, any thoughts (maybe this is an issue we don't care about).

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • tests and/or benchmarks are included
  • documentation is changed or added
  • commit message follows commit guidelines

@bcoe bcoe requested review from Trott, addaleax and joyeecheung May 21, 2020 01:19
@nodejs-github-bot nodejs-github-bot added the lib / src Issues and PRs related to general changes in the lib or src directory. label May 21, 2020
@devsnek
Copy link
Member

devsnek commented May 21, 2020

I'm trying to figure out how it's placing the ^ under the throw, rather than under the Error

As a general rule, v8::Message is generated from the location of throw, and the error's stack is generated from the location of the error. The v8::Message might sometimes point to the error location instead if it failed to figure out the throw location.

@bcoe
Copy link
Contributor Author

bcoe commented May 21, 2020

@devsnek do you think we should be clever, and even just grep for the throw and move the pointer accordingly? might work for 80% of cases.

@devsnek
Copy link
Member

devsnek commented May 21, 2020

@bcoe i think its okay to use the error position. alternatively, you could store the message position info on the error in c++ (like how we store decorations) so its available in the js prepareStackTrace callback.

Copy link
Member

@bnoordhuis bnoordhuis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As a general observation, having an environment-wide flag that toggles the behavior doesn't seem like a good idea. Wouldn't you want to distinguish on whether the script contains a source map URL or not?

You can query the v8::Message object to find out if it has one:

const bool has_source_map_url =
    !message->GetScriptOrigin().SourceMapUrl().IsEmpty();

lib/internal/process/per_thread.js Outdated Show resolved Hide resolved
src/env.h Outdated Show resolved Hide resolved
lib/internal/source_map/source_map_cache.js Outdated Show resolved Hide resolved
@bcoe
Copy link
Contributor Author

bcoe commented May 22, 2020

@bnoordhuis const bool has_source_map_url = !message->GetScriptOrigin().SourceMapUrl().IsEmpty(); works great, I didn't have a clue this was a possibility.

It does, however, present the issue that if you haven't run a file with --enable-source-maps, you will not get the context added above your stack trace (as the source-map will still be found by v8).

Should we check both values (whether source maps are enabled, and whether the script has a source map), and only annotate the error in prepareStackTrace for files with source maps?

@bcoe
Copy link
Contributor Author

bcoe commented May 22, 2020

@bnoordhuis using your suggestion as a starting point, we now only apply the new getErrorSource logic, if:

  1. source maps are enabled, and.
  2. the file has a source map.

Copy link
Member

@addaleax addaleax left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@addaleax I know you've also worked in this file, any thoughts (maybe this is an issue we don't care about).

Not really any thoughts beyond that this seems useful and I’m happy to see it :)

@nodejs-github-bot

This comment has been minimized.

@bcoe bcoe force-pushed the stack-trace-context branch from b39c73f to 1e2973b Compare May 22, 2020 22:17
@nodejs-github-bot

This comment has been minimized.

@bcoe bcoe force-pushed the stack-trace-context branch from 1e2973b to 686867c Compare May 22, 2020 22:48
@nodejs-github-bot

This comment has been minimized.

@nodejs-github-bot
Copy link
Collaborator

Copy link
Member

@BridgeAR BridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM. Just left a suggestion to improve unicode support and maybe another test file was meant to be added?

lib/internal/source_map/prepare_stack_trace.js Outdated Show resolved Hide resolved
@bcoe
Copy link
Contributor Author

bcoe commented May 23, 2020

@BridgeAR I opted for using fixture based testing, my thinking being that it's actually a pretty elegant way to assert against the whole stack output.

tldr; those are tabs in source_map_reference_error_tabs.out:

> const text = fs.readFileSync('test/message/source_map_reference_error_tabs.out', 'utf8')
undefined
> text
'*tabs.coffee:26\n' +
  '\talert "I knew it!"\n' +
  '\t^\n' +

@bcoe
Copy link
Contributor Author

bcoe commented May 23, 2020

@BridgeAR can you recommend an error message we could throw that would exercise your unicode improvements, I think this would be a great addition to the test suite.

Well I'm extending on the test suite, any thoughts on a transpiler I haven't used yet 😆

We've used babel, TypeScript, uglify, CoffeeScript, Istanbul.

@BridgeAR
Copy link
Member

@bcoe I mostly use the following characters to verify unicode support:

  • あ - a full width character with a length of one.
  • 🐕 - a full width character with a length of two.
  • 𐐷 - a half width character with the length of two.
  • '\u0301', '0x200D', '\u200E' - zero width characters.

full width = ' ' // Two spaces
half width = ' '
zero width = ''

Using these in the error message should be sufficient.

@bcoe bcoe force-pushed the stack-trace-context branch from 8c8382d to 9ffc7fb Compare May 24, 2020 03:38
@bcoe
Copy link
Contributor Author

bcoe commented May 24, 2020

@BridgeAR take a look 👍

I noticed that it's actually more accurate with source maps than without now (the message displayed for ("あ 🐕 🐕", throw Error("an error")); points to the E with source maps, " " without source maps).

Copy link
Member

@bnoordhuis bnoordhuis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM % comments. Nice work, @bcoe.

lib/internal/source_map/prepare_stack_trace.js Outdated Show resolved Hide resolved
lib/internal/source_map/prepare_stack_trace.js Outdated Show resolved Hide resolved
src/env-inl.h Outdated Show resolved Hide resolved
src/node_errors.cc Outdated Show resolved Hide resolved
@bcoe bcoe force-pushed the stack-trace-context branch 2 times, most recently from dae507e to a0b9de9 Compare May 24, 2020 06:24
Copy link
Member

@BridgeAR BridgeAR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Awesome work! Still LGTM, just left two nits.

lib/internal/source_map/prepare_stack_trace.js Outdated Show resolved Hide resolved
test/message/source_map_throw_icu.js Outdated Show resolved Hide resolved
@bcoe bcoe force-pushed the stack-trace-context branch from d2e50e5 to 08bfea8 Compare May 24, 2020 17:34
@nodejs-github-bot

This comment has been minimized.

@nodejs-github-bot

This comment has been minimized.

When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.
@bcoe bcoe force-pushed the stack-trace-context branch from 08bfea8 to 12cc152 Compare May 24, 2020 23:01
@nodejs-github-bot

This comment has been minimized.

@nodejs-github-bot
Copy link
Collaborator

bcoe added a commit that referenced this pull request May 25, 2020
When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

PR-URL: #33491
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
@bcoe
Copy link
Contributor Author

bcoe commented May 25, 2020

Landed in 458677f

@bcoe bcoe closed this May 25, 2020
@codebytere
Copy link
Member

codebytere commented Jun 18, 2020

@bcoe would you mind opening a manual backport for this into v14.x-staging? it's a conflict in a few files. Feel free to update the label if you don't think it should go back!

bcoe added a commit to bcoe/node-1 that referenced this pull request Mar 10, 2021
When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

PR-URL: nodejs#33491
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
bcoe added a commit to bcoe/node-1 that referenced this pull request Mar 10, 2021
When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

Backport-PR-URL: nodejs#37700
PR-URL: nodejs#33491
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
ruyadorno pushed a commit that referenced this pull request Mar 11, 2021
When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

Backport-PR-URL: #37700
PR-URL: #33491
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
MylesBorins pushed a commit that referenced this pull request Apr 6, 2021
When --enable-source-maps is set, the error context displayed
above the stack trace now shows original source rather than
transpiled.

Backport-PR-URL: #37700
PR-URL: #33491
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
@danielleadams danielleadams mentioned this pull request May 3, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
lib / src Issues and PRs related to general changes in the lib or src directory.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants