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

fix(npm/check): prioritize exports over types entry (#16788)

This commit is contained in:
David Sherret 2022-11-24 12:07:36 -05:00 committed by Bartek Iwańczuk
parent 40198a1504
commit 72c8c16a85
No known key found for this signature in database
GPG key ID: 0C6BCDDC3B3AD750
11 changed files with 51 additions and 17 deletions

View file

@ -665,6 +665,18 @@ fn package_config_resolve(
let package_config =
PackageJson::load(npm_resolver, package_json_path.clone())?;
if let Some(exports) = &package_config.exports {
let result = package_exports_resolve(
&package_json_path,
package_subpath.to_string(),
exports,
&referrer,
referrer_kind,
conditions,
npm_resolver,
);
match result {
Ok(found) => return Ok(Some(found)),
Err(exports_err) => {
let is_types = conditions == TYPES_CONDITIONS;
if is_types && package_subpath == "." {
if let Ok(Some(path)) =
@ -675,16 +687,9 @@ fn package_config_resolve(
return Ok(None);
}
}
return package_exports_resolve(
&package_json_path,
package_subpath.to_string(),
exports,
&referrer,
referrer_kind,
conditions,
npm_resolver,
)
.map(Some);
return Err(exports_err);
}
}
}
if package_subpath == "." {
return legacy_main_resolve(&package_config, referrer_kind, conditions);

View file

@ -424,7 +424,8 @@ impl ProcState {
drop(_pb_clear_guard);
// type check if necessary
if self.options.type_check_mode() != TypeCheckMode::None {
let is_std_node = roots.len() == 1 && roots[0].0 == *node::MODULE_ALL_URL;
if self.options.type_check_mode() != TypeCheckMode::None && !is_std_node {
log::debug!("Type checking.");
let maybe_config_specifier = self.options.maybe_config_file_specifier();
let roots = roots.clone();

View file

@ -298,6 +298,14 @@ itest!(no_types_in_conditional_exports {
http_server: true,
});
itest!(types_entry_value_not_exists {
args: "run --check=all npm/types_entry_value_not_exists/main.ts",
output: "npm/types_entry_value_not_exists/main.out",
envs: env_vars(),
http_server: true,
exit_code: 0,
});
#[test]
fn parallel_downloading() {
let (out, _err) = util::run_and_collect_output_with_args(

View file

@ -3,6 +3,5 @@ Download http://localhost:4545/npm/registry/@types/node
Download http://localhost:4545/npm/registry/@denotest/globals/1.0.0.tgz
Download http://localhost:4545/npm/registry/@types/node/node-18.8.2.tgz
Check file:///[WILDCARD]/npm/compare_globals/main.ts
Check file:///[WILDCARD]/std/node/module_all.ts
true
[]

View file

@ -1,6 +1,5 @@
Download http://localhost:4545/npm/registry/chalk
Download http://localhost:4545/npm/registry/chalk/chalk-5.0.1.tgz
Check [WILDCARD]/std/node/module_all.ts
running 1 test from ./npm/esm/test.js
test ...
------- output -------

View file

@ -1,5 +1,4 @@
Download http://localhost:4545/npm/registry/@denotest/no-types-in-conditional-exports
Download http://localhost:4545/npm/registry/@denotest/no-types-in-conditional-exports/1.0.0.tgz
Check [WILDCARD]npm/no_types_in_conditional_exports/main.ts
[WILDCARD]
{ foo: "bar" }

View file

@ -0,0 +1 @@
export function getValue(): 5;

View file

@ -0,0 +1 @@
module.exports.getValue = () => 5;

View file

@ -0,0 +1,13 @@
{
"name": "@denotest/types-entry-value-not-exists",
"version": "1.0.0",
"main": "./dist/main.js",
"types": "./index.d.ts",
"exports": {
".": {
"types": "./dist/main.d.ts",
"node": "./dist/main.js",
"require": "./dist/main.js"
}
}
}

View file

@ -0,0 +1,4 @@
Download http://localhost:4545/npm/registry/@denotest/types-entry-value-not-exists
Download http://localhost:4545/npm/registry/@denotest/types-entry-value-not-exists/1.0.0.tgz
Check file://[WILDCARD]/types_entry_value_not_exists/main.ts
5

View file

@ -0,0 +1,4 @@
import { getValue } from "npm:@denotest/types-entry-value-not-exists";
const result: 5 = getValue();
console.log(result);