mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
4c37df779c
PR-URL: https://github.com/nodejs/node/pull/22381 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Guy Bedford <guybedford@gmail.com> Reviewed-By: Tiancheng "Timothy" Gu <timothygu99@gmail.com>
78 lines
2.5 KiB
JavaScript
78 lines
2.5 KiB
JavaScript
// Flags: --experimental-modules
|
|
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const { URL } = require('url');
|
|
const vm = require('vm');
|
|
|
|
const relativePath = '../fixtures/es-modules/test-esm-ok.mjs';
|
|
const absolutePath = require.resolve('../fixtures/es-modules/test-esm-ok.mjs');
|
|
const targetURL = new URL('file:///');
|
|
targetURL.pathname = absolutePath;
|
|
|
|
function expectErrorProperty(result, propertyKey, value) {
|
|
Promise.resolve(result)
|
|
.catch(common.mustCall(error => {
|
|
assert.strictEqual(error[propertyKey], value);
|
|
}));
|
|
}
|
|
|
|
function expectMissingModuleError(result) {
|
|
expectErrorProperty(result, 'code', 'MODULE_NOT_FOUND');
|
|
}
|
|
|
|
function expectInvalidUrlError(result) {
|
|
expectErrorProperty(result, 'code', 'ERR_INVALID_URL');
|
|
}
|
|
|
|
function expectInvalidReferrerError(result) {
|
|
expectErrorProperty(result, 'code', 'ERR_INVALID_URL');
|
|
}
|
|
|
|
function expectInvalidProtocolError(result) {
|
|
expectErrorProperty(result, 'code', 'ERR_INVALID_PROTOCOL');
|
|
}
|
|
|
|
function expectInvalidContextError(result) {
|
|
expectErrorProperty(result,
|
|
'message', 'import() called outside of main context');
|
|
}
|
|
|
|
function expectOkNamespace(result) {
|
|
Promise.resolve(result)
|
|
.then(common.mustCall(ns => {
|
|
// Can't deepStrictEqual because ns isn't a normal object
|
|
assert.deepEqual(ns, { default: true });
|
|
}));
|
|
}
|
|
|
|
function expectFsNamespace(result) {
|
|
Promise.resolve(result)
|
|
.then(common.mustCall(ns => {
|
|
assert.strictEqual(typeof ns.default.writeFile, 'function');
|
|
assert.strictEqual(typeof ns.writeFile, 'function');
|
|
}));
|
|
}
|
|
|
|
// For direct use of import expressions inside of CJS or ES modules, including
|
|
// via eval, all kinds of specifiers should work without issue.
|
|
(function testScriptOrModuleImport() {
|
|
// Importing another file, both direct & via eval
|
|
// expectOkNamespace(import(relativePath));
|
|
expectOkNamespace(eval.call(null, `import("${relativePath}")`));
|
|
expectOkNamespace(eval(`import("${relativePath}")`));
|
|
expectOkNamespace(eval.call(null, `import("${targetURL}")`));
|
|
|
|
// Importing a built-in, both direct & via eval
|
|
expectFsNamespace(import("fs"));
|
|
expectFsNamespace(eval('import("fs")'));
|
|
expectFsNamespace(eval.call(null, 'import("fs")'));
|
|
|
|
expectMissingModuleError(import("./not-an-existing-module.mjs"));
|
|
// TODO(jkrems): Right now this doesn't hit a protocol error because the
|
|
// module resolution step already rejects it. These arguably should be
|
|
// protocol errors.
|
|
expectMissingModuleError(import("node:fs"));
|
|
expectMissingModuleError(import('http://example.com/foo.js'));
|
|
})();
|