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