From d411031b1a3b0b22362a489e2c887fd55f7f160c Mon Sep 17 00:00:00 2001 From: cjihrig Date: Fri, 6 Sep 2024 20:29:08 -0400 Subject: [PATCH] test_runner: detect only tests when --test is not used This commit updates the way the test runner processes 'only' tests when node:test files are run without the --test CLI. This is a breaking change. --- lib/internal/test_runner/harness.js | 4 ++-- .../test-runner/output/dot_reporter.snapshot | 2 +- .../output/junit_reporter.snapshot | 10 +++------ test/fixtures/test-runner/output/output.js | 2 +- .../test-runner/output/output.snapshot | 22 ++++++------------- .../test-runner/output/output_cli.snapshot | 5 ++--- .../test-runner/output/spec_reporter.snapshot | 12 ++++------ .../output/spec_reporter_cli.snapshot | 5 ++--- test/parallel/test-runner-no-isolation.mjs | 8 +------ test/parallel/test-runner-output.mjs | 2 +- 10 files changed, 24 insertions(+), 48 deletions(-) diff --git a/lib/internal/test_runner/harness.js b/lib/internal/test_runner/harness.js index 69669687b2e0f8..e63d19cb518ab3 100644 --- a/lib/internal/test_runner/harness.js +++ b/lib/internal/test_runner/harness.js @@ -38,8 +38,8 @@ function createTestTree(rootTestOptions, globalOptions) { const buildPhaseDeferred = createDeferredPromise(); const isFilteringByName = globalOptions.testNamePatterns || globalOptions.testSkipPatterns; - const isFilteringByOnly = globalOptions.only || (globalOptions.isTestRunner && - globalOptions.isolation === 'none'); + const isFilteringByOnly = (globalOptions.isolation === 'process' || process.env.NODE_TEST_CONTEXT) ? + globalOptions.only : true; const harness = { __proto__: null, buildPromise: buildPhaseDeferred.promise, diff --git a/test/fixtures/test-runner/output/dot_reporter.snapshot b/test/fixtures/test-runner/output/dot_reporter.snapshot index 5f2bf18e1d0137..6e6383e4a4d509 100644 --- a/test/fixtures/test-runner/output/dot_reporter.snapshot +++ b/test/fixtures/test-runner/output/dot_reporter.snapshot @@ -1,7 +1,7 @@ ..XX...X..XXX.X..... XXX.....X..X...X.... .....X...XXX.XX..... -.XXXXXXX...XXXXX +XXXXXXX...XXXXX Failed tests: diff --git a/test/fixtures/test-runner/output/junit_reporter.snapshot b/test/fixtures/test-runner/output/junit_reporter.snapshot index d244e7dd594bb3..3b477520f58186 100644 --- a/test/fixtures/test-runner/output/junit_reporter.snapshot +++ b/test/fixtures/test-runner/output/junit_reporter.snapshot @@ -309,15 +309,11 @@ Error [ERR_TEST_FAILURE]: thrown from callback async throw - + - - - - [Error [ERR_TEST_FAILURE]: customized] { code: 'ERR_TEST_FAILURE', failureType: 'testCodeFailure', cause: customized } @@ -521,9 +517,9 @@ Error [ERR_TEST_FAILURE]: test could not be started because its parent finished - + - + diff --git a/test/fixtures/test-runner/output/output.js b/test/fixtures/test-runner/output/output.js index ff1b2958774052..c920347ea30644 100644 --- a/test/fixtures/test-runner/output/output.js +++ b/test/fixtures/test-runner/output/output.js @@ -274,7 +274,7 @@ test('callback async throw after done', (t, done) => { done(); }); -test('only is set but not in only mode', { only: true }, async (t) => { +test('only is set on subtests but not in only mode', async (t) => { // All of these subtests should run. await t.test('running subtest 1'); t.runOnly(true); diff --git a/test/fixtures/test-runner/output/output.snapshot b/test/fixtures/test-runner/output/output.snapshot index 0acb6573bc6710..f288832c42fb64 100644 --- a/test/fixtures/test-runner/output/output.snapshot +++ b/test/fixtures/test-runner/output/output.snapshot @@ -463,35 +463,27 @@ ok 48 - callback async throw after done --- duration_ms: * ... -# Subtest: only is set but not in only mode +# Subtest: only is set on subtests but not in only mode # Subtest: running subtest 1 ok 1 - running subtest 1 --- duration_ms: * ... - # Subtest: running subtest 2 - ok 2 - running subtest 2 - --- - duration_ms: * - ... - # 'only' and 'runOnly' require the --test-only command-line option. # Subtest: running subtest 3 - ok 3 - running subtest 3 + ok 2 - running subtest 3 --- duration_ms: * ... - # 'only' and 'runOnly' require the --test-only command-line option. # Subtest: running subtest 4 - ok 4 - running subtest 4 + ok 3 - running subtest 4 --- duration_ms: * ... - 1..4 -ok 49 - only is set but not in only mode + 1..3 +ok 49 - only is set on subtests but not in only mode --- duration_ms: * ... -# 'only' and 'runOnly' require the --test-only command-line option. # Subtest: custom inspect symbol fail not ok 50 - custom inspect symbol fail --- @@ -718,9 +710,9 @@ not ok 62 - invalid subtest fail # Error: Test "immediate reject - passes but warns" at test/fixtures/test-runner/output/output.js:(LINE):1 generated asynchronous activity after the test ended. This activity created the error "Error: rejected from immediate reject fail" and would have caused the test to fail, but instead triggered an unhandledRejection event. # Error: Test "callback called twice in different ticks" at test/fixtures/test-runner/output/output.js:(LINE):1 generated asynchronous activity after the test ended. This activity created the error "Error [ERR_TEST_FAILURE]: callback invoked multiple times" and would have caused the test to fail, but instead triggered an uncaughtException event. # Error: Test "callback async throw after done" at test/fixtures/test-runner/output/output.js:(LINE):1 generated asynchronous activity after the test ended. This activity created the error "Error: thrown from callback async throw after done" and would have caused the test to fail, but instead triggered an uncaughtException event. -# tests 76 +# tests 75 # suites 0 -# pass 35 +# pass 34 # fail 25 # cancelled 3 # skipped 9 diff --git a/test/fixtures/test-runner/output/output_cli.snapshot b/test/fixtures/test-runner/output/output_cli.snapshot index d04dc0a0a905ad..430ef1966670b5 100644 --- a/test/fixtures/test-runner/output/output_cli.snapshot +++ b/test/fixtures/test-runner/output/output_cli.snapshot @@ -463,7 +463,7 @@ ok 48 - callback async throw after done --- duration_ms: * ... -# Subtest: only is set but not in only mode +# Subtest: only is set on subtests but not in only mode # Subtest: running subtest 1 ok 1 - running subtest 1 --- @@ -487,11 +487,10 @@ ok 48 - callback async throw after done duration_ms: * ... 1..4 -ok 49 - only is set but not in only mode +ok 49 - only is set on subtests but not in only mode --- duration_ms: * ... -# 'only' and 'runOnly' require the --test-only command-line option. # Subtest: custom inspect symbol fail not ok 50 - custom inspect symbol fail --- diff --git a/test/fixtures/test-runner/output/spec_reporter.snapshot b/test/fixtures/test-runner/output/spec_reporter.snapshot index f37d7f35b8a7d6..de9a38e780959c 100644 --- a/test/fixtures/test-runner/output/spec_reporter.snapshot +++ b/test/fixtures/test-runner/output/spec_reporter.snapshot @@ -185,15 +185,11 @@ * callback async throw after done (*ms) - only is set but not in only mode + only is set on subtests but not in only mode running subtest 1 (*ms) - running subtest 2 (*ms) - 'only' and 'runOnly' require the --test-only command-line option. running subtest 3 (*ms) - 'only' and 'runOnly' require the --test-only command-line option. running subtest 4 (*ms) - only is set but not in only mode (*ms) - 'only' and 'runOnly' require the --test-only command-line option. + only is set on subtests but not in only mode (*ms) custom inspect symbol fail (*ms) customized @@ -304,9 +300,9 @@ Error: Test "immediate reject - passes but warns" at test/fixtures/test-runner/output/output.js:86:1 generated asynchronous activity after the test ended. This activity created the error "Error: rejected from immediate reject fail" and would have caused the test to fail, but instead triggered an unhandledRejection event. Error: Test "callback called twice in different ticks" at test/fixtures/test-runner/output/output.js:251:1 generated asynchronous activity after the test ended. This activity created the error "Error [ERR_TEST_FAILURE]: callback invoked multiple times" and would have caused the test to fail, but instead triggered an uncaughtException event. Error: Test "callback async throw after done" at test/fixtures/test-runner/output/output.js:269:1 generated asynchronous activity after the test ended. This activity created the error "Error: thrown from callback async throw after done" and would have caused the test to fail, but instead triggered an uncaughtException event. - tests 76 + tests 75 suites 0 - pass 35 + pass 34 fail 25 cancelled 3 skipped 9 diff --git a/test/fixtures/test-runner/output/spec_reporter_cli.snapshot b/test/fixtures/test-runner/output/spec_reporter_cli.snapshot index d8648bfe03a8be..2e5f263e1a5e3a 100644 --- a/test/fixtures/test-runner/output/spec_reporter_cli.snapshot +++ b/test/fixtures/test-runner/output/spec_reporter_cli.snapshot @@ -185,15 +185,14 @@ * callback async throw after done (*ms) - only is set but not in only mode + only is set on subtests but not in only mode running subtest 1 (*ms) running subtest 2 (*ms) 'only' and 'runOnly' require the --test-only command-line option. running subtest 3 (*ms) 'only' and 'runOnly' require the --test-only command-line option. running subtest 4 (*ms) - only is set but not in only mode (*ms) - 'only' and 'runOnly' require the --test-only command-line option. + only is set on subtests but not in only mode (*ms) custom inspect symbol fail (*ms) customized diff --git a/test/parallel/test-runner-no-isolation.mjs b/test/parallel/test-runner-no-isolation.mjs index 60b0c962e6779b..ef280f726e5cdc 100644 --- a/test/parallel/test-runner-no-isolation.mjs +++ b/test/parallel/test-runner-no-isolation.mjs @@ -12,7 +12,7 @@ const stream = run({ }); stream.on('test:fail', mustNotCall()); -stream.on('test:pass', mustCall(5)); +stream.on('test:pass', mustCall(4)); // eslint-disable-next-line no-unused-vars for await (const _ of stream); allowGlobals(globalThis.GLOBAL_ORDER); @@ -28,12 +28,6 @@ deepStrictEqual(globalThis.GLOBAL_ORDER, [ 'afterEach one: suite one - test', 'afterEach two: suite one - test', - 'beforeEach one: test one', - 'beforeEach two: test one', - 'test one', - 'afterEach one: test one', - 'afterEach two: test one', - 'before suite two: suite two', 'beforeEach one: suite two - test', diff --git a/test/parallel/test-runner-output.mjs b/test/parallel/test-runner-output.mjs index 6de1c2eeafce98..9000c7fcf27253 100644 --- a/test/parallel/test-runner-output.mjs +++ b/test/parallel/test-runner-output.mjs @@ -225,7 +225,7 @@ const tests = [ } : false, { name: 'test-runner/output/test-diagnostic-warning-without-test-only-flag.js', - flags: ['--test-reporter=tap'], + flags: ['--test', '--test-reporter=tap'], }, process.features.inspector ? { name: 'test-runner/output/coverage-width-80.mjs',