Skip to content

Commit

Permalink
test: eval a strict function
Browse files Browse the repository at this point in the history
PR-URL: #5250
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
  • Loading branch information
kthelgason authored and Myles Borins committed Mar 21, 2016
1 parent f9c32e2 commit 8c682a3
Showing 1 changed file with 28 additions and 0 deletions.
28 changes: 28 additions & 0 deletions test/parallel/test-regress-GH-2245.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
/* eslint-disable strict */
require('../common');
var assert = require('assert');

/*
in node 0.10 a bug existed that caused strict functions to not capture
their environment when evaluated. When run in 0.10 `test()` fails with a
`ReferenceError`. See https://github.com/nodejs/node/issues/2245 for details.
*/

function test() {

var code = [
'var foo = {m: 1};',
'',
'function bar() {',
'\'use strict\';',
'return foo; // foo isn\'t captured in 0.10',
'};'
].join('\n');

eval(code);

return bar();

}

assert.deepEqual(test(), {m: 1});

0 comments on commit 8c682a3

Please sign in to comment.