From 1e97f0f1487d27b69d85ebe8e9d84c21af1d9dde Mon Sep 17 00:00:00 2001 From: Marvin Hagemeister Date: Mon, 8 Jul 2024 15:19:59 +0200 Subject: feat: add `__tests__` to test file detection defaults (#24443) The `jest` test runner popularized putting tests into a `__tests__` folder. Whilst many have switched to going with a `.test` suffix in the file name these days, there are still many jest projects that have `__tests__`. By adding this to the default test detection logic it makes `deno test` discover those out of the box. --- cli/tools/test/mod.rs | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'cli/tools/test') diff --git a/cli/tools/test/mod.rs b/cli/tools/test/mod.rs index e7273c069..81dc36a89 100644 --- a/cli/tools/test/mod.rs +++ b/cli/tools/test/mod.rs @@ -1611,9 +1611,16 @@ pub(crate) fn is_supported_test_path(path: &Path) -> bool { fn has_supported_test_path_name(path: &Path) -> bool { if let Some(name) = path.file_stem() { let basename = name.to_string_lossy(); - basename.ends_with("_test") + if basename.ends_with("_test") || basename.ends_with(".test") || basename == "test" + { + return true; + } + + path + .components() + .any(|seg| seg.as_os_str().to_str() == Some("__tests__")) } else { false } @@ -2077,6 +2084,18 @@ mod inner_test { assert!(is_supported_test_path(Path::new("foo/bar/test.jsx"))); assert!(is_supported_test_path(Path::new("foo/bar/test.ts"))); assert!(is_supported_test_path(Path::new("foo/bar/test.tsx"))); + assert!(is_supported_test_path(Path::new( + "foo/bar/__tests__/foo.js" + ))); + assert!(is_supported_test_path(Path::new( + "foo/bar/__tests__/foo.jsx" + ))); + assert!(is_supported_test_path(Path::new( + "foo/bar/__tests__/foo.ts" + ))); + assert!(is_supported_test_path(Path::new( + "foo/bar/__tests__/foo.tsx" + ))); assert!(!is_supported_test_path(Path::new("README.md"))); assert!(!is_supported_test_path(Path::new("lib/typescript.d.ts"))); assert!(!is_supported_test_path(Path::new("notatest.js"))); -- cgit v1.2.3