diff --git a/src/node_contextify.cc b/src/node_contextify.cc index ed552ddd559f51..fdab91714d7da0 100644 --- a/src/node_contextify.cc +++ b/src/node_contextify.cc @@ -530,7 +530,9 @@ void ContextifyContext::PropertySetterCallback( return; USE(ctx->sandbox()->Set(context, property, value)); - args.GetReturnValue().Set(value); + if (is_function) { + args.GetReturnValue().Set(value); + } } // static diff --git a/test/parallel/test-vm-global-symbol.js b/test/parallel/test-vm-global-symbol.js new file mode 100644 index 00000000000000..7c9fa0be24e19d --- /dev/null +++ b/test/parallel/test-vm-global-symbol.js @@ -0,0 +1,14 @@ +'use strict'; +const assert = require('assert'); +const vm = require('vm'); + +const global = vm.runInContext('this', vm.createContext()); +const totoSymbol = Symbol.for('toto'); +Object.defineProperty(global, totoSymbol, { + enumerable: true, + writable: true, + value: 4, + configurable: true, +}); +assert(global[totoSymbol] === 4); +assert(Object.getOwnPropertySymbols(global).includes(totoSymbol));