Skip to content

Commit

Permalink
Added exemption for node v12, native source maps don't seem to be acc…
Browse files Browse the repository at this point in the history
…urate...
  • Loading branch information
STRd6 committed Apr 3, 2022
1 parent 9354f97 commit c942bd0
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 48 deletions.
52 changes: 29 additions & 23 deletions docs/v2/test.html
Original file line number Diff line number Diff line change
Expand Up @@ -32777,28 +32777,30 @@ <h2>Another heading</h2>
arrayEq v3SourceMap.sources, ['tempus_fugit.coffee']
eq v3SourceMap.sourceRoot, './www_root/coffee/'

test "native source maps", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--enable-source-maps"
"-r", "./register.js"
"-r", "./test/integration/error.coffee"
]
# Source maps aren't accurate on Node v12 ??
if process.version.split(".")[0] != "v12"
test "native source maps", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--enable-source-maps"
"-r", "./register.js"
"-r", "./test/integration/error.coffee"
]

# proc.stdout.setEncoding('utf8')
# proc.stdout.on 'data', (s) -> console.log(s)
err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.on 'exit', (status) ->
try
equal status, 1
# proc.stdout.setEncoding('utf8')
# proc.stdout.on 'data', (s) -> console.log(s)
err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.on 'exit', (status) ->
try
equal status, 1

[_, line] = err.match /error\.coffee:(\d+)/
equal line, 3 # Mapped source line
resolve()
catch e
reject(e)
[_, line] = err.match /error\.coffee:(\d+)/
equal line, 3 # Mapped source line
resolve()
catch e
reject(e)

test "don't change stack traces if another library has patched `Error.prepareStackTrace`", ->
new Promise (resolve, reject) ->
Expand All @@ -32817,9 +32819,13 @@ <h2>Another heading</h2>
try
equal status, 1

[_, line] = err.match /error\.coffee:(\d+)/
equal line, 4 # Unmapped source line
resolve()
match = err.match /error\.coffee:(\d+)/
if match
[_, line] = match
equal line, 4 # Unmapped source line
resolve()
else
reject new Error err
catch e
reject(e)

Expand Down
56 changes: 31 additions & 25 deletions test/sourcemap.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -65,28 +65,30 @@ test "#3075: v3 source map fields", ->
arrayEq v3SourceMap.sources, ['tempus_fugit.coffee']
eq v3SourceMap.sourceRoot, './www_root/coffee/'

test "native source maps", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--enable-source-maps"
"-r", "./register.js"
"-r", "./test/integration/error.coffee"
]

# proc.stdout.setEncoding('utf8')
# proc.stdout.on 'data', (s) -> console.log(s)
err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.on 'exit', (status) ->
try
equal status, 1

[_, line] = err.match /error\.coffee:(\d+)/
equal line, 3 # Mapped source line
resolve()
catch e
reject(e)
# Source maps aren't accurate on Node v12 ??
if process.version.split(".")[0] != "v12"
test "native source maps", ->
new Promise (resolve, reject) ->
proc = spawn "node", [
"--enable-source-maps"
"-r", "./register.js"
"-r", "./test/integration/error.coffee"
]

# proc.stdout.setEncoding('utf8')
# proc.stdout.on 'data', (s) -> console.log(s)
err = ""
proc.stderr.setEncoding('utf8')
proc.stderr.on 'data', (s) -> err += s
proc.on 'exit', (status) ->
try
equal status, 1

[_, line] = err.match /error\.coffee:(\d+)/
equal line, 3 # Mapped source line
resolve()
catch e
reject(e)

test "don't change stack traces if another library has patched `Error.prepareStackTrace`", ->
new Promise (resolve, reject) ->
Expand All @@ -105,8 +107,12 @@ test "don't change stack traces if another library has patched `Error.prepareSta
try
equal status, 1

[_, line] = err.match /error\.coffee:(\d+)/
equal line, 4 # Unmapped source line
resolve()
match = err.match /error\.coffee:(\d+)/
if match
[_, line] = match
equal line, 4 # Unmapped source line
resolve()
else
reject new Error err
catch e
reject(e)

0 comments on commit c942bd0

Please sign in to comment.