From 452b393c1fc993c50acd447eb84eeea529b89111 Mon Sep 17 00:00:00 2001 From: Guy Bedford Date: Tue, 30 Jul 2019 21:41:58 -0400 Subject: [PATCH] module: exports error as MODULE_NOT_FOUND PR-URL: https://github.com/nodejs/node/pull/28905 Reviewed-By: Rich Trott Reviewed-By: Colin Ihrig Reviewed-By: Jan Krems Reviewed-By: Luigi Pinca Reviewed-By: Trivikram Kamat --- doc/api/errors.md | 7 ------- doc/api/modules.md | 4 ++-- lib/internal/errors.js | 2 -- lib/internal/modules/cjs/loader.js | 7 +++++-- src/module_wrap.cc | 2 +- src/node_errors.h | 1 - test/es-module/test-esm-exports.mjs | 6 +++--- 7 files changed, 11 insertions(+), 18 deletions(-) diff --git a/doc/api/errors.md b/doc/api/errors.md index e166638cbf3d94..e809b26f6d0d9c 100644 --- a/doc/api/errors.md +++ b/doc/api/errors.md @@ -1599,13 +1599,6 @@ compiled with ICU support. A given value is out of the accepted range. - -### ERR_PATH_NOT_EXPORTED - -> Stability: 1 - Experimental - -An attempt was made to load a protected path from a package using `exports`. - ### ERR_REQUIRE_ESM diff --git a/doc/api/modules.md b/doc/api/modules.md index abac7eaf91d854..bf8209965e9122 100644 --- a/doc/api/modules.md +++ b/doc/api/modules.md @@ -223,10 +223,10 @@ RESOLVE_BARE_SPECIFIER(DIR, X) a. Parse DIR/name/package.json, and look for "exports" field. b. If "exports" is null or undefined, GOTO 3. c. Find the longest key in "exports" that the subpath starts with. - d. If no such key can be found, throw "not exported". + d. If no such key can be found, throw "not found". e. If the key matches the subpath entirely, return DIR/name/${exports[key]}. f. If either the key or exports[key] do not end with a slash (`/`), - throw "not exported". + throw "not found". g. Return DIR/name/${exports[key]}${subpath.slice(key.length)}. 3. return DIR/X ``` diff --git a/lib/internal/errors.js b/lib/internal/errors.js index cc60bf5ab8fd17..6e3bfb29c03f27 100644 --- a/lib/internal/errors.js +++ b/lib/internal/errors.js @@ -1104,8 +1104,6 @@ E('ERR_OUT_OF_RANGE', msg += ` It must be ${range}. Received ${received}`; return msg; }, RangeError); -E('ERR_PATH_NOT_EXPORTED', - 'Package exports for \'%s\' do not define a \'%s\' subpath', Error); E('ERR_REQUIRE_ESM', 'Must use import to load ES Module: %s', Error); E('ERR_SCRIPT_EXECUTION_INTERRUPTED', 'Script execution was interrupted by `SIGINT`', Error); diff --git a/lib/internal/modules/cjs/loader.js b/lib/internal/modules/cjs/loader.js index bdc012259068d6..95b56e08520a52 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -60,7 +60,6 @@ const { compileFunction } = internalBinding('contextify'); const { ERR_INVALID_ARG_VALUE, ERR_INVALID_OPT_VALUE, - ERR_PATH_NOT_EXPORTED, ERR_REQUIRE_ESM } = require('internal/errors').codes; const { validateString } = require('internal/validators'); @@ -377,7 +376,11 @@ function resolveExports(nmPath, request, absoluteRequest) { return fileURLToPath(resolved); } } - throw new ERR_PATH_NOT_EXPORTED(basePath, mappingKey); + // eslint-disable-next-line no-restricted-syntax + const e = new Error(`Package exports for '${basePath}' do not define ` + + `a '${mappingKey}' subpath`); + e.code = 'MODULE_NOT_FOUND'; + throw e; } } diff --git a/src/module_wrap.cc b/src/module_wrap.cc index 522e7c2a4587f1..5b33ef261cf69c 100644 --- a/src/module_wrap.cc +++ b/src/module_wrap.cc @@ -859,7 +859,7 @@ Maybe PackageExportsResolve(Environment* env, std::string msg = "Package exports for '" + URL(".", pjson_url).ToFilePath() + "' do not define a '" + pkg_subpath + "' subpath, imported from " + base.ToFilePath(); - node::THROW_ERR_PATH_NOT_EXPORTED(env, msg.c_str()); + node::THROW_ERR_MODULE_NOT_FOUND(env, msg.c_str()); return Nothing(); } diff --git a/src/node_errors.h b/src/node_errors.h index c2587d73e67df4..939f93a4899f59 100644 --- a/src/node_errors.h +++ b/src/node_errors.h @@ -53,7 +53,6 @@ void PrintErrorString(const char* format, ...); V(ERR_MISSING_PLATFORM_FOR_WORKER, Error) \ V(ERR_MODULE_NOT_FOUND, Error) \ V(ERR_OUT_OF_RANGE, RangeError) \ - V(ERR_PATH_NOT_EXPORTED, Error) \ V(ERR_SCRIPT_EXECUTION_INTERRUPTED, Error) \ V(ERR_SCRIPT_EXECUTION_TIMEOUT, Error) \ V(ERR_STRING_TOO_LONG, Error) \ diff --git a/test/es-module/test-esm-exports.mjs b/test/es-module/test-esm-exports.mjs index ca10097aa9ba27..6c42d3b64ead40 100644 --- a/test/es-module/test-esm-exports.mjs +++ b/test/es-module/test-esm-exports.mjs @@ -29,7 +29,7 @@ import { requireFixture, importFixture } from '../fixtures/pkgexports.mjs'; // There's no such export - so there's nothing to do. loadFixture('pkgexports/missing').catch(mustCall((err) => { - strictEqual(err.code, 'ERR_PATH_NOT_EXPORTED'); + strictEqual(err.code, (isRequire ? '' : 'ERR_') + 'MODULE_NOT_FOUND'); assertStartsWith(err.message, 'Package exports'); assertIncludes(err.message, 'do not define a \'./missing\' subpath'); })); @@ -37,7 +37,7 @@ import { requireFixture, importFixture } from '../fixtures/pkgexports.mjs'; // The file exists but isn't exported. The exports is a number which counts // as a non-null value without any properties, just like `{}`. loadFixture('pkgexports-number/hidden.js').catch(mustCall((err) => { - strictEqual(err.code, 'ERR_PATH_NOT_EXPORTED'); + strictEqual(err.code, (isRequire ? '' : 'ERR_') + 'MODULE_NOT_FOUND'); assertStartsWith(err.message, 'Package exports'); assertIncludes(err.message, 'do not define a \'./hidden.js\' subpath'); })); @@ -57,7 +57,7 @@ import { requireFixture, importFixture } from '../fixtures/pkgexports.mjs'; // Even though 'pkgexports/sub/asdf.js' works, alternate "path-like" variants // do not to prevent confusion and accidental loopholes. loadFixture('pkgexports/sub/./../asdf.js').catch(mustCall((err) => { - strictEqual(err.code, 'ERR_PATH_NOT_EXPORTED'); + strictEqual(err.code, (isRequire ? '' : 'ERR_') + 'MODULE_NOT_FOUND'); assertStartsWith(err.message, 'Package exports'); assertIncludes(err.message, 'do not define a \'./sub/./../asdf.js\' subpath');