1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-05 05:49:20 -05:00

fix(node): package path not exported error - add if types resolution was occurring (#19963)

This commit is contained in:
David Sherret 2023-07-27 12:27:01 -04:00 committed by GitHub
parent 02d6bbff2c
commit cfc0c80642
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 3 deletions

View file

@ -7,6 +7,8 @@ use deno_core::error::type_error;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::url::Url; use deno_core::url::Url;
use crate::NodeResolutionMode;
pub fn err_invalid_module_specifier( pub fn err_invalid_module_specifier(
request: &str, request: &str,
reason: &str, reason: &str,
@ -95,6 +97,7 @@ pub fn err_package_path_not_exported(
mut pkg_path: String, mut pkg_path: String,
subpath: String, subpath: String,
maybe_referrer: Option<String>, maybe_referrer: Option<String>,
mode: NodeResolutionMode,
) -> AnyError { ) -> AnyError {
let mut msg = "[ERR_PACKAGE_PATH_NOT_EXPORTED]".to_string(); let mut msg = "[ERR_PACKAGE_PATH_NOT_EXPORTED]".to_string();
@ -111,11 +114,15 @@ pub fn err_package_path_not_exported(
} }
} }
let types_msg = match mode {
NodeResolutionMode::Execution => String::new(),
NodeResolutionMode::Types => " for types".to_string(),
};
if subpath == "." { if subpath == "." {
msg = msg =
format!("{msg} No \"exports\" main defined in '{pkg_path}package.json'"); format!("{msg} No \"exports\" main defined{types_msg} in '{pkg_path}package.json'");
} else { } else {
msg = format!("{msg} Package subpath '{subpath}' is not defined by \"exports\" in '{pkg_path}package.json'"); msg = format!("{msg} Package subpath '{subpath}' is not defined{types_msg} by \"exports\" in '{pkg_path}package.json'");
}; };
if let Some(referrer) = maybe_referrer { if let Some(referrer) = maybe_referrer {
@ -160,3 +167,33 @@ pub fn err_unsupported_esm_url_scheme(url: &Url) -> AnyError {
msg = format!("{}. Received protocol '{}'", msg, url.scheme()); msg = format!("{}. Received protocol '{}'", msg, url.scheme());
generic_error(msg) generic_error(msg)
} }
#[cfg(test)]
mod test {
use super::*;
#[test]
fn types_resolution_package_path_not_exported() {
let separator_char = if cfg!(windows) { '\\' } else { '/' };
assert_eq!(
err_package_path_not_exported(
"test_path".to_string(),
"./jsx-runtime".to_string(),
None,
NodeResolutionMode::Types,
)
.to_string(),
format!("[ERR_PACKAGE_PATH_NOT_EXPORTED] Package subpath './jsx-runtime' is not defined for types by \"exports\" in 'test_path{separator_char}package.json'")
);
assert_eq!(
err_package_path_not_exported(
"test_path".to_string(),
".".to_string(),
None,
NodeResolutionMode::Types,
)
.to_string(),
format!("[ERR_PACKAGE_PATH_NOT_EXPORTED] No \"exports\" main defined for types in 'test_path{separator_char}package.json'")
);
}
}

View file

@ -367,7 +367,7 @@ impl NodeResolver {
permissions, permissions,
) )
.with_context(|| { .with_context(|| {
format!("Error resolving package config for '{reference}'") format!("Failed resolving package config for '{reference}'")
})?; })?;
let resolved_path = match maybe_resolved_path { let resolved_path = match maybe_resolved_path {
Some(resolved_path) => resolved_path, Some(resolved_path) => resolved_path,
@ -933,6 +933,7 @@ impl NodeResolver {
package_subpath, package_subpath,
package_json_path, package_json_path,
referrer, referrer,
mode,
)); ));
} }
return Ok(resolved.unwrap()); return Ok(resolved.unwrap());
@ -994,6 +995,7 @@ impl NodeResolver {
package_subpath, package_subpath,
package_json_path, package_json_path,
referrer, referrer,
mode,
)); ));
} }
} }
@ -1002,6 +1004,7 @@ impl NodeResolver {
package_subpath, package_subpath,
package_json_path, package_json_path,
referrer, referrer,
mode,
)) ))
} }
@ -1447,11 +1450,13 @@ fn throw_exports_not_found(
subpath: String, subpath: String,
package_json_path: &Path, package_json_path: &Path,
referrer: &ModuleSpecifier, referrer: &ModuleSpecifier,
mode: NodeResolutionMode,
) -> AnyError { ) -> AnyError {
errors::err_package_path_not_exported( errors::err_package_path_not_exported(
package_json_path.parent().unwrap().display().to_string(), package_json_path.parent().unwrap().display().to_string(),
subpath, subpath,
Some(to_specifier_display_string(referrer)), Some(to_specifier_display_string(referrer)),
mode,
) )
} }