vm: increase code coverage of source_text_module.js
PR-URL: https://github.com/nodejs/node/pull/28350 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
This commit is contained in:
parent
8007134189
commit
99879cac86
35
test/parallel/test-vm-module-dynamic-namespace.js
Normal file
35
test/parallel/test-vm-module-dynamic-namespace.js
Normal file
@ -0,0 +1,35 @@
|
||||
'use strict';
|
||||
|
||||
// Flags: --experimental-vm-modules --expose-internals
|
||||
//
|
||||
const common = require('../common');
|
||||
|
||||
const assert = require('assert');
|
||||
|
||||
const { types } = require('util');
|
||||
const { SourceTextModule, wrapMap } = require('internal/vm/source_text_module');
|
||||
|
||||
const { importModuleDynamicallyCallback } =
|
||||
require('internal/process/esm_loader');
|
||||
|
||||
async function getNamespace() {
|
||||
const m = new SourceTextModule('');
|
||||
await m.link(() => 0);
|
||||
m.instantiate();
|
||||
await m.evaluate();
|
||||
return m.namespace;
|
||||
}
|
||||
|
||||
(async () => {
|
||||
const namespace = await getNamespace();
|
||||
const m = new SourceTextModule('export const A = "A";', {
|
||||
importModuleDynamically: common.mustCall((specifier, wrap) => {
|
||||
return namespace;
|
||||
})
|
||||
});
|
||||
await m.link(() => 0);
|
||||
m.instantiate();
|
||||
await m.evaluate();
|
||||
const ns = await importModuleDynamicallyCallback(wrapMap.get(m));
|
||||
assert.ok(types.isModuleNamespaceObject(ns));
|
||||
})().then(common.mustCall());
|
Loading…
x
Reference in New Issue
Block a user