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

Don’t patch Error.prepareStackTrace if --enable-source-maps is used. #5403

Merged
merged 38 commits into from
Apr 19, 2022
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
4d9b901
Fixes #5382
STRd6 Apr 1, 2022
0fb2951
build:browser
STRd6 Apr 1, 2022
bebcec0
Merge remote-tracking branch 'origin/main' into 5382
STRd6 Apr 3, 2022
9354f97
Basic tests and inline source maps when native source maps are enabled
STRd6 Apr 3, 2022
c942bd0
Added exemption for node v12, native source maps don't seem to be acc…
STRd6 Apr 3, 2022
264b009
Added guard for in browser
STRd6 Apr 3, 2022
9f65df3
Use --require rather than -r
STRd6 Apr 4, 2022
05a9502
PR Feedback
STRd6 Apr 4, 2022
6c1312b
Experimental big refactoring of source mappings
STRd6 Apr 4, 2022
3cbbf48
Better tracking anonymous files
STRd6 Apr 4, 2022
b71bad6
Comment cleanup
STRd6 Apr 4, 2022
dad126e
Restored NODE_OPTIONS environment variable check
STRd6 Apr 4, 2022
44234dd
Added test for NODE_OPTIONS
STRd6 Apr 4, 2022
946a82f
Node v12 ... my old nemesis
STRd6 Apr 4, 2022
fae524b
Simplified
STRd6 Apr 5, 2022
f971278
Added default options object
STRd6 Apr 5, 2022
46a3962
Ensuring relative path for `sourceRoot` ends with separator
STRd6 Apr 5, 2022
30489cf
Added test for source mapped stack traces when executing bin/coffee
STRd6 Apr 5, 2022
0410b11
Using static class methods for SourceMap cache
STRd6 Apr 5, 2022
af44a0b
Extend browser test timeout from 30 => 60 seconds
STRd6 Apr 5, 2022
f341739
More reliable stream capturing in tests
STRd6 Apr 5, 2022
b46da93
Report errors when running browser tests
STRd6 Apr 5, 2022
608f0d6
Merge branch 'main' into 5382
STRd6 Apr 5, 2022
40529cd
Removed test pattern grepping
STRd6 Apr 5, 2022
a29f6bf
Merge branch 'main' into 5382
STRd6 Apr 5, 2022
942ce2c
Object.create null instead of empty object for the map cache
STRd6 Apr 6, 2022
1049cc6
Single quote string style
STRd6 Apr 10, 2022
4015fc5
Fixed stack trace in browser docs
STRd6 Apr 11, 2022
8590d28
Removed new stacktrace.coffee file
STRd6 Apr 11, 2022
e6ab9f6
Don't display inline maps on doc examples
STRd6 Apr 11, 2022
58afee8
attachStackTrace -> patchStackTrace
STRd6 Apr 17, 2022
8e2f090
Apply suggestions from code review
STRd6 Apr 17, 2022
2467d7d
Coding style cleanup
STRd6 Apr 17, 2022
219f76a
Updated comment on registerCompiled export
STRd6 Apr 17, 2022
267d91c
doc:test
STRd6 Apr 17, 2022
d24c75b
Fixed test guard conditional
STRd6 Apr 17, 2022
0d64fcc
Slightly more robust version checking
STRd6 Apr 17, 2022
c56d9a2
Comment about spawn vs fork
STRd6 Apr 18, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion docs/v2/browser-compiler-legacy/coffeescript.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion docs/v2/browser-compiler-modern/coffeescript.js

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions docs/v2/index.html

Large diffs are not rendered by default.

99 changes: 48 additions & 51 deletions docs/v2/test.html
Original file line number Diff line number Diff line change
Expand Up @@ -32779,14 +32779,14 @@ <h2>Another heading</h2>

test "node --enable-source-map built in stack trace mapping", ->
new Promise (resolve, reject) ->
proc = fork "./test/importing/error.coffee", [
"--enable-source-maps"
], stdio: "pipe"

err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.stderr.on 'finish', ->
proc = fork './test/importing/error.coffee', [
'--enable-source-maps'
], stdio: 'pipe'

err = ''
proc.stderr.setEncoding 'utf8'
proc.stderr.on 'data', (str) -> err += str
proc.on 'close', ->
try
match = err.match /error\.coffee:(\d+):(\d+)/
throw new Error err unless match
Expand All @@ -32796,21 +32796,21 @@ <h2>Another heading</h2>
equal column, 9 # Mapped source column

resolve()
catch e
reject(e)
catch exception
reject exception

unless process.version.slice(1, 3) is "12"
if Number(process.version.slice(1, 3)) >= 14
test "NODE_OPTIONS=--enable-source-maps environment variable stack trace mapping", ->
new Promise (resolve, reject) ->
proc = fork "./test/importing/error.coffee", [],
proc = fork './test/importing/error.coffee', [],
env:
NODE_OPTIONS: "--enable-source-maps"
stdio: "pipe"
NODE_OPTIONS: '--enable-source-maps'
stdio: 'pipe'

err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.stderr.on 'finish', ->
err = ''
proc.stderr.setEncoding 'utf8'
proc.stderr.on 'data', (str) -> err += str
proc.on 'close', ->
try
match = err.match /error\.coffee:(\d+):(\d+)/
throw new Error err unless match
Expand All @@ -32820,22 +32820,19 @@ <h2>Another heading</h2>
equal column, 9 # Mapped source column

resolve()
catch e
reject(e)
catch exception
reject exception

test "generate correct stack traces with --enable-source-maps from bin/coffee", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"./bin/coffee"
"--nodejs"
"--enable-source-maps"
"test/importing/error.coffee"
]
proc = fork 'test/importing/error.coffee',
['--enable-source-maps'],
stdio: 'pipe'

err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.stderr.on 'finish', ->
proc.stderr.setEncoding 'utf8'
proc.stderr.on 'data', (str) -> err += str
proc.on 'close', ->
try
match = err.match /error\.coffee:(\d+):(\d+)/
throw new Error err unless match
Expand All @@ -32845,53 +32842,53 @@ <h2>Another heading</h2>
equal column, 9 # Mapped source column

resolve()
catch e
reject e
catch exception
reject exception

test "don't change stack traces if another library has patched `Error.prepareStackTrace`", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--eval", """
proc = spawn 'node', [
'--eval', """
const patchedPrepareStackTrace = Error.prepareStackTrace = function() {};
require('./register.js');
console.log(Error.prepareStackTrace === patchedPrepareStackTrace);
process.stdout.write(Error.prepareStackTrace === patchedPrepareStackTrace ? 'preserved' : 'overwritten');
"""
]

out = ""
proc.stdout.setEncoding('utf8')
proc.stdout.on 'data', (s) -> out += s
out = ''
proc.stdout.setEncoding 'utf8'
proc.stdout.on 'data', (str) -> out += str

proc.on 'exit', (status) ->
proc.on 'close', (status) ->
try
equal status, 0
equal out, "true\n"
equal out, 'preserved'

resolve()
catch e
reject e
catch exception
reject exception

test "requiring 'CoffeeScript' doesn't change `Error.prepareStackTrace`", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--eval", """
proc = spawn 'node', [
'--eval', """
require('./lib/coffeescript/coffeescript.js');
console.log(Error.prepareStackTrace);
process.stdout.write(Error.prepareStackTrace === undefined ? 'unused' : 'defined');
"""
]

out = ""
proc.stdout.setEncoding('utf8')
proc.stdout.on 'data', (s) -> out += s
out = ''
proc.stdout.setEncoding 'utf8'
proc.stdout.on 'data', (str) -> out += str

proc.on 'exit', (status) ->
proc.on 'close', (status) ->
try
equal status, 0
equal out, "undefined\n"
equal out, 'unused'

resolve()
catch e
reject e
catch exception
reject exception

</script>
<script type="text/x-coffeescript" class="test" id="strict">
Expand Down
2 changes: 1 addition & 1 deletion documentation/site/docs.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ window.gtag 'config', window.GA_TRACKING_ID

# Initialize the CoffeeScript docs interactions
$(document).ready ->
CoffeeScript.attachStackTrace()
CoffeeScript.patchStackTrace()

# Format dates for the user’s locale, e.g. 'December 24, 2009' or '24 décembre 2009'
$('time').each (index, el) ->
Expand Down
2 changes: 1 addition & 1 deletion lib/coffeescript-browser-compiler-legacy/coffeescript.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion lib/coffeescript-browser-compiler-modern/coffeescript.js

Large diffs are not rendered by default.

7 changes: 5 additions & 2 deletions lib/coffeescript/coffeescript.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 3 additions & 3 deletions lib/coffeescript/register.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 5 additions & 2 deletions src/coffeescript.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ exports.FILE_EXTENSIONS = FILE_EXTENSIONS = ['.coffee', '.litcoffee', '.coffee.m
exports.helpers = helpers

{getSourceMap, registerCompiled} = SourceMap
# This is exported to enable an external module to implement caching of
# sourcemaps. This is used only when `patchStackTrace` has been called to adjust
# stack traces for files with cached source maps.
exports.registerCompiled = registerCompiled

# Function that allows for btoa in both nodejs and the browser.
Expand Down Expand Up @@ -247,7 +250,7 @@ parser.yy.parseError = (message, {token}) ->
# from the lexer.
helpers.throwSyntaxError "unexpected #{errorText}", errorLoc

exports.attachStackTrace = ->
exports.patchStackTrace = ->
# Based on http://v8.googlecode.com/svn/branches/bleeding_edge/src/messages.js
# Modified to handle sourceMap
formatSourcePosition = (frame, getSourceMapping) ->
Expand Down Expand Up @@ -313,7 +316,7 @@ exports.attachStackTrace = ->
# positions.
Error.prepareStackTrace = (err, stack) ->
frames = for frame in stack
# Don't display stack frames deeper than `CoffeeScript.run`
# Dont display stack frames deeper than `CoffeeScript.run`.
break if frame.getFunction() is exports.run
" at #{formatSourcePosition frame, getSourceMapping}"

Expand Down
4 changes: 2 additions & 2 deletions src/register.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ child_process = require 'child_process'
helpers = require './helpers'
path = require 'path'

{attachStackTrace} = CoffeeScript
{patchStackTrace} = CoffeeScript

# Check if Node's built-in source map stack trace transformations are enabled.
nodeSourceMapsSupportEnabled = process? and (
Expand All @@ -13,7 +13,7 @@ nodeSourceMapsSupportEnabled = process? and (

unless Error.prepareStackTrace or nodeSourceMapsSupportEnabled
cacheSourceMaps = true
attachStackTrace()
patchStackTrace()

# Load and run a CoffeeScript file for Node, stripping any `BOM`s.
loadFile = (module, filename) ->
Expand Down
Loading