test: refactor test-vm-new-script-new-context

* block scope test cases
* clean up global leaks in individual test cases
* enable global variable leak checking
* remove console.error() statements

PR-URL: https://github.com/nodejs/node/pull/14536
Reviewed-By: Refael Ackermann <refack@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
This commit is contained in:
Rich Trott 2017-07-29 09:04:00 -07:00
parent 8c2cac650a
commit ff1a51920e

View File

@ -20,71 +20,88 @@
// USE OR OTHER DEALINGS IN THE SOFTWARE. // USE OR OTHER DEALINGS IN THE SOFTWARE.
'use strict'; 'use strict';
const common = require('../common'); require('../common');
const assert = require('assert'); const assert = require('assert');
const Script = require('vm').Script; const Script = require('vm').Script;
common.globalCheck = false; {
const script = new Script('\'passed\';');
const result1 = script.runInNewContext();
const result2 = script.runInNewContext();
assert.strictEqual('passed', result1);
assert.strictEqual('passed', result2);
}
console.error('run a string'); {
let script = new Script('\'passed\';'); const script = new Script('throw new Error(\'test\');');
console.error('script created'); assert.throws(function() {
const result1 = script.runInNewContext(); script.runInNewContext();
const result2 = script.runInNewContext(); }, /^Error: test$/);
assert.strictEqual('passed', result1); }
assert.strictEqual('passed', result2);
console.error('thrown error'); {
script = new Script('throw new Error(\'test\');'); const script = new Script('foo.bar = 5;');
assert.throws(function() { assert.throws(function() {
script.runInNewContext();
}, /^ReferenceError: foo is not defined$/);
}
{
global.hello = 5;
const script = new Script('hello = 2');
script.runInNewContext(); script.runInNewContext();
}, /^Error: test$/); assert.strictEqual(5, global.hello);
// cleanup
delete global.hello;
}
console.error('undefined reference'); {
script = new Script('foo.bar = 5;'); global.code = 'foo = 1;' +
assert.throws(function() { 'bar = 2;' +
script.runInNewContext(); 'if (baz !== 3) throw new Error(\'test fail\');';
}, /^ReferenceError: foo is not defined$/); global.foo = 2;
global.obj = { foo: 0, baz: 3 };
const script = new Script(global.code);
/* eslint-disable no-unused-vars */
const baz = script.runInNewContext(global.obj);
/* eslint-enable no-unused-vars */
assert.strictEqual(1, global.obj.foo);
assert.strictEqual(2, global.obj.bar);
assert.strictEqual(2, global.foo);
//cleanup
delete global.code;
delete global.foo;
delete global.obj;
}
global.hello = 5; {
script = new Script('hello = 2'); const script = new Script('f()');
script.runInNewContext(); function changeFoo() { global.foo = 100; }
assert.strictEqual(5, global.hello); script.runInNewContext({ f: changeFoo });
assert.strictEqual(global.foo, 100);
// cleanup
delete global.foo;
}
console.error('pass values in and out'); {
global.code = 'foo = 1;' + const script = new Script('f.a = 2');
'bar = 2;' + const f = { a: 1 };
'if (baz !== 3) throw new Error(\'test fail\');'; script.runInNewContext({ f: f });
global.foo = 2; assert.strictEqual(f.a, 2);
global.obj = { foo: 0, baz: 3 };
script = new Script(global.code);
/* eslint-disable no-unused-vars */
const baz = script.runInNewContext(global.obj);
/* eslint-enable no-unused-vars */
assert.strictEqual(1, global.obj.foo);
assert.strictEqual(2, global.obj.bar);
assert.strictEqual(2, global.foo);
console.error('call a function by reference'); assert.throws(function() {
script = new Script('f()'); script.runInNewContext();
function changeFoo() { global.foo = 100; } }, /^ReferenceError: f is not defined$/);
script.runInNewContext({ f: changeFoo }); }
assert.strictEqual(global.foo, 100);
console.error('modify an object by reference'); {
script = new Script('f.a = 2'); const script = new Script('');
const f = { a: 1 }; assert.throws(function() {
script.runInNewContext({ f: f }); script.runInNewContext.call('\'hello\';');
assert.strictEqual(f.a, 2); }, /^TypeError: this\.runInContext is not a function$/);
}
assert.throws(function() {
script.runInNewContext();
}, /^ReferenceError: f is not defined$/);
console.error('invalid this');
assert.throws(function() {
script.runInNewContext.call('\'hello\';');
}, /^TypeError: this\.runInContext is not a function$/);