mirror of https://github.com/lukechilds/node.git
Browse Source
Fix the regexp used to detect 'Unexpected token' errors so that they can be considered as recoverable. This fixes the following use case: > var foo = 'bar \ ... baz'; undefined > foo 'bar baz' > Fixes: https://github.com/joyent/node/issues/8874 PR-URL: https://github.com/joyent/node/pull/8875 PR-URL: https://github.com/nodejs/io.js/pull/2052 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>v4.0.0-rc
committed by
cjihrig
2 changed files with 34 additions and 1 deletions
@ -0,0 +1,33 @@ |
|||
'use strict'; |
|||
/* |
|||
* This is a regression test for https://github.com/joyent/node/issues/8874.
|
|||
*/ |
|||
var common = require('../common'); |
|||
var assert = require('assert'); |
|||
|
|||
var spawn = require('child_process').spawn; |
|||
// use -i to force node into interactive mode, despite stdout not being a TTY
|
|||
var args = [ '-i' ]; |
|||
var child = spawn(process.execPath, args); |
|||
|
|||
var input = 'var foo = "bar\\\nbaz"'; |
|||
// Match '...' as well since it marks a multi-line statement
|
|||
var expectOut = /^> ... undefined\n/; |
|||
|
|||
child.stderr.setEncoding('utf8'); |
|||
child.stderr.on('data', function(c) { |
|||
throw new Error('child.stderr be silent'); |
|||
}); |
|||
|
|||
child.stdout.setEncoding('utf8'); |
|||
var out = ''; |
|||
child.stdout.on('data', function(c) { |
|||
out += c; |
|||
}); |
|||
|
|||
child.stdout.on('end', function() { |
|||
assert(expectOut.test(out)); |
|||
console.log('ok'); |
|||
}); |
|||
|
|||
child.stdin.end(input); |
Loading…
Reference in new issue