From 1b27b5839624ebf9fef65cea28a17281f3b79a74 Mon Sep 17 00:00:00 2001 From: Leo Kettmeir Date: Thu, 2 May 2024 11:13:51 -0700 Subject: [PATCH] fix(test): proper type checking for files with doc tests (#23654) Closes https://github.com/denoland/deno/issues/23430 --------- Co-authored-by: Yoshiya Hinosawa --- cli/tools/test/mod.rs | 33 +++++++------------ .../test/type_check_with_doc/__test__.jsonc | 5 +++ tests/specs/test/type_check_with_doc/main.out | 13 ++++++++ tests/specs/test/type_check_with_doc/main.ts | 8 +++++ 4 files changed, 37 insertions(+), 22 deletions(-) create mode 100644 tests/specs/test/type_check_with_doc/__test__.jsonc create mode 100644 tests/specs/test/type_check_with_doc/main.out create mode 100644 tests/specs/test/type_check_with_doc/main.ts diff --git a/cli/tools/test/mod.rs b/cli/tools/test/mod.rs index ffa0fef9ee..d63176d392 100644 --- a/cli/tools/test/mod.rs +++ b/cli/tools/test/mod.rs @@ -1326,27 +1326,7 @@ pub async fn check_specifiers( ) .await?; - if !inline_files.is_empty() { - let specifiers = inline_files - .iter() - .map(|file| file.specifier.clone()) - .collect(); - - for file in inline_files { - file_fetcher.insert_memory_files(file); - } - - module_load_preparer - .prepare_module_load( - specifiers, - false, - lib, - PermissionsContainer::new(Permissions::allow_all()), - ) - .await?; - } - - let module_specifiers = specifiers + let mut module_specifiers = specifiers .into_iter() .filter_map(|(specifier, mode)| { if mode != TestMode::Documentation { @@ -1355,7 +1335,16 @@ pub async fn check_specifiers( None } }) - .collect(); + .collect::>(); + + if !inline_files.is_empty() { + module_specifiers + .extend(inline_files.iter().map(|file| file.specifier.clone())); + + for file in inline_files { + file_fetcher.insert_memory_files(file); + } + } module_load_preparer .prepare_module_load( diff --git a/tests/specs/test/type_check_with_doc/__test__.jsonc b/tests/specs/test/type_check_with_doc/__test__.jsonc new file mode 100644 index 0000000000..c4a26529ac --- /dev/null +++ b/tests/specs/test/type_check_with_doc/__test__.jsonc @@ -0,0 +1,5 @@ +{ + "args": "test --doc main.ts", + "output": "main.out", + "exitCode": 1 +} diff --git a/tests/specs/test/type_check_with_doc/main.out b/tests/specs/test/type_check_with_doc/main.out new file mode 100644 index 0000000000..931a6a5f3e --- /dev/null +++ b/tests/specs/test/type_check_with_doc/main.out @@ -0,0 +1,13 @@ +Check [WILDCARD]/main.ts +Check [WILDCARD]/main.ts$2-5.ts +error: TS2322 [ERROR]: Type 'number' is not assignable to type 'string'. +const a: string = 1; + ^ + at file://[WILDCARD]/main.ts:8:7 + +TS2322 [ERROR]: Type 'string' is not assignable to type 'number'. +const b: number = "1"; + ^ + at file://[WILDCARD]/main.ts$2-5.ts:1:7 + +Found 2 errors. diff --git a/tests/specs/test/type_check_with_doc/main.ts b/tests/specs/test/type_check_with_doc/main.ts new file mode 100644 index 0000000000..04ccd00bf3 --- /dev/null +++ b/tests/specs/test/type_check_with_doc/main.ts @@ -0,0 +1,8 @@ +/** + * ```ts + * const b: number = "1"; + * ``` + */ +function foo() {} + +const a: string = 1;