Description
Version
Test on v23.6.0 and v22.10.0
Platform
All
Subsystem
test_runner
What steps will reproduce the bug?
Consider this folder structure:
└── test
├── fixtures
│ ├── boom.js
│ └── boom.ts
└── index.test.js
When running node --test
the test runner will execute ./test/fixtures/boom.js
.
In v23 it will also execute ./test/fixtures/boom.ts
, since --experimental-strip-types
has been unflagged.
Error: boom
at Object. (/Users/marcoippolito/Documents/projects/test/test/fixtures/boom.js:1:7)
at Module._compile (node:internal/modules/cjs/loader:1739:14)
at Object..js (node:internal/modules/cjs/loader:1904:10)
at Module.load (node:internal/modules/cjs/loader:1473:32)
at Function._load (node:internal/modules/cjs/loader:1285:12)
at TracingChannel.traceSync (node:diagnostics_channel:322:14)
at wrapModuleLoad (node:internal/modules/cjs/loader:234:24)
at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:151:5)
at node:internal/main/run_main_module:33:47
Node.js v23.6.0
✖ test/fixtures/boom.js (36.07275ms)
'test failed'
/Users/marcoippolito/Documents/projects/test/test/fixtures/boom.ts:1
throw new Error('boom TS');
^
Error: boom TS
at Object. (/Users/marcoippolito/Documents/projects/test/test/fixtures/boom.ts:1:7)
at Module._compile (node:internal/modules/cjs/loader:1739:14)
at Object.loadTS [as .ts] (node:internal/modules/cjs/loader:1831:10)
at Module.load (node:internal/modules/cjs/loader:1473:32)
at Function._load (node:internal/modules/cjs/loader:1285:12)
at TracingChannel.traceSync (node:diagnostics_channel:322:14)
at wrapModuleLoad (node:internal/modules/cjs/loader:234:24)
at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:151:5)
at node:internal/main/run_main_module:33:47
Node.js v23.6.0
✖ test/fixtures/boom.ts (62.136209ms)
'test failed'
✔ should return true (0.3725ms)
ℹ tests 3
ℹ suites 0
ℹ pass 1
ℹ fail 2
ℹ cancelled 0
ℹ skipped 0
ℹ todo 0
ℹ duration_ms 72.075583
✖ failing tests:
test at test/fixtures/boom.js:1:1
✖ test/fixtures/boom.js (36.07275ms)
'test failed'
test at test/fixtures/boom.ts:1:1
✖ test/fixtures/boom.ts (62.136209ms)
'test failed'
How often does it reproduce? Is there a required condition?
Always
What is the expected behavior? Why is that the expected behavior?
Maybe this is intended behavior but I'd would expect matching .test.js
.
I think it's an undesired side effect to execute everything.
I immagine breakages due to a lot of .ts
fixtures being executed.
What do you see instead?
Everything is executed.
Additional information
I know changing this would be a breaking change, but I dont think it's sane as it is.
Activity