From 6141d5e7c6003bf58d485c4c562d27ae3dd0e2a4 Mon Sep 17 00:00:00 2001 From: cjihrig Date: Sat, 16 Mar 2024 12:12:44 -0400 Subject: [PATCH 1/3] test_runner: skip each hooks for skipped tests When a test is skipped, the corresponding beforeEach and afterEach hooks should also be skipped. Fixes: https://github.com/nodejs/node/issues/52112 --- lib/internal/test_runner/test.js | 4 ++-- .../test-runner/output/skip-each-hooks.js | 21 +++++++++++++++++++ .../output/skip-each-hooks.snapshot | 11 ++++++++++ test/parallel/test-runner-output.mjs | 1 + 4 files changed, 35 insertions(+), 2 deletions(-) create mode 100644 test/fixtures/test-runner/output/skip-each-hooks.js create mode 100644 test/fixtures/test-runner/output/skip-each-hooks.snapshot diff --git a/lib/internal/test_runner/test.js b/lib/internal/test_runner/test.js index d57c1d6d12610e..e5877a1d5ec9e4 100644 --- a/lib/internal/test_runner/test.js +++ b/lib/internal/test_runner/test.js @@ -666,7 +666,7 @@ class Test extends AsyncResource { } }; const afterEach = runOnce(async () => { - if (this.parent?.hooks.afterEach.length > 0) { + if (this.parent?.hooks.afterEach.length > 0 && !this.skipped) { await this.parent.runHook('afterEach', hookArgs); } }); @@ -678,7 +678,7 @@ class Test extends AsyncResource { // This hook usually runs immediately, we need to wait for it to finish await this.parent.runHook('before', this.parent.getRunArgs()); } - if (this.parent?.hooks.beforeEach.length > 0) { + if (this.parent?.hooks.beforeEach.length > 0 && !this.skipped) { await this.parent.runHook('beforeEach', hookArgs); } stopPromise = stopTest(this.timeout, this.signal); diff --git a/test/fixtures/test-runner/output/skip-each-hooks.js b/test/fixtures/test-runner/output/skip-each-hooks.js new file mode 100644 index 00000000000000..f4fbb2d23fffa3 --- /dev/null +++ b/test/fixtures/test-runner/output/skip-each-hooks.js @@ -0,0 +1,21 @@ +// Flags: --test-reporter=spec +'use strict'; +const { after, afterEach, before, beforeEach, test } = require('node:test'); + +before(() => { + console.log('BEFORE'); +}); + +beforeEach(() => { + console.log('BEFORE EACH'); +}); + +after(() => { + console.log('AFTER'); +}); + +afterEach(() => { + console.log('AFTER EACH'); +}); + +test('skipped test', { skip: true }); diff --git a/test/fixtures/test-runner/output/skip-each-hooks.snapshot b/test/fixtures/test-runner/output/skip-each-hooks.snapshot new file mode 100644 index 00000000000000..e92376101dac1d --- /dev/null +++ b/test/fixtures/test-runner/output/skip-each-hooks.snapshot @@ -0,0 +1,11 @@ +BEFORE +AFTER +﹣ skipped test (*ms) # SKIP +ℹ tests 1 +ℹ suites 0 +ℹ pass 0 +ℹ fail 0 +ℹ cancelled 0 +ℹ skipped 1 +ℹ todo 0 +ℹ duration_ms * diff --git a/test/parallel/test-runner-output.mjs b/test/parallel/test-runner-output.mjs index 77a3f4e2a0263b..159f66751ae2b7 100644 --- a/test/parallel/test-runner-output.mjs +++ b/test/parallel/test-runner-output.mjs @@ -96,6 +96,7 @@ const tests = [ { name: 'test-runner/output/eval_tap.js' }, { name: 'test-runner/output/hooks.js' }, { name: 'test-runner/output/hooks_spec_reporter.js', transform: specTransform }, + { name: 'test-runner/output/skip-each-hooks.js', transform: specTransform }, { name: 'test-runner/output/timeout_in_before_each_should_not_affect_further_tests.js' }, { name: 'test-runner/output/hooks-with-no-global-test.js' }, { name: 'test-runner/output/global-hooks-with-no-tests.js' }, From 14e3f9f5637d3f9444bd5eaad1abb127043b0094 Mon Sep 17 00:00:00 2001 From: cjihrig Date: Sat, 16 Mar 2024 13:32:22 -0400 Subject: [PATCH 2/3] additional tests --- .../test-runner/output/suite-skip-hooks.js | 76 +++++++++++++++++++ .../output/suite-skip-hooks.snapshot | 24 ++++++ test/parallel/test-runner-output.mjs | 1 + 3 files changed, 101 insertions(+) create mode 100644 test/fixtures/test-runner/output/suite-skip-hooks.js create mode 100644 test/fixtures/test-runner/output/suite-skip-hooks.snapshot diff --git a/test/fixtures/test-runner/output/suite-skip-hooks.js b/test/fixtures/test-runner/output/suite-skip-hooks.js new file mode 100644 index 00000000000000..4c1de8b757a06d --- /dev/null +++ b/test/fixtures/test-runner/output/suite-skip-hooks.js @@ -0,0 +1,76 @@ +// Flags: --test-reporter=spec +'use strict'; +const { + after, + afterEach, + before, + beforeEach, + describe, + it, +} = require('node:test'); + +// before(() => { +// console.log('BEFORE'); +// }); + +// beforeEach(() => { +// console.log('BEFORE EACH'); +// }); + +// after(() => { +// console.log('AFTER'); +// }); + +// afterEach(() => { +// console.log('AFTER EACH'); +// }); + +describe('skip all hooks in this suite', { skip: true }, () => { + before(() => { + console.log('BEFORE 1'); + }); + + beforeEach(() => { + console.log('BEFORE EACH 1'); + }); + + after(() => { + console.log('AFTER 1'); + }); + + afterEach(() => { + console.log('AFTER EACH 1'); + }); + + it('should not run'); +}); + +describe('suite runs with mixture of skipped tests', () => { + before(() => { + console.log('BEFORE 2'); + }); + + beforeEach(() => { + console.log('BEFORE EACH 2'); + }); + + after(() => { + console.log('AFTER 2'); + }); + + afterEach(() => { + console.log('AFTER EACH 2'); + }); + + it('should not run', { skip: true }); + + it('should run 1', () => { + console.log('should run 1'); + }); + + it('should not run', { skip: true }); + + it('should run 2', () => { + console.log('should run 2'); + }); +}); diff --git a/test/fixtures/test-runner/output/suite-skip-hooks.snapshot b/test/fixtures/test-runner/output/suite-skip-hooks.snapshot new file mode 100644 index 00000000000000..610b1d984530d9 --- /dev/null +++ b/test/fixtures/test-runner/output/suite-skip-hooks.snapshot @@ -0,0 +1,24 @@ +BEFORE 2 +BEFORE EACH 2 +should run 1 +AFTER EACH 2 +BEFORE EACH 2 +should run 2 +AFTER EACH 2 +AFTER 2 +﹣ skip all hooks in this suite (*ms) # SKIP +▶ suite runs with mixture of skipped tests + ﹣ should not run (*ms) # SKIP + ✔ should run 1 (*ms) + ﹣ should not run (*ms) # SKIP + ✔ should run 2 (*ms) +▶ suite runs with mixture of skipped tests (*ms) + +ℹ tests 4 +ℹ suites 2 +ℹ pass 2 +ℹ fail 0 +ℹ cancelled 0 +ℹ skipped 2 +ℹ todo 0 +ℹ duration_ms * diff --git a/test/parallel/test-runner-output.mjs b/test/parallel/test-runner-output.mjs index 159f66751ae2b7..abc3d7c97b4879 100644 --- a/test/parallel/test-runner-output.mjs +++ b/test/parallel/test-runner-output.mjs @@ -97,6 +97,7 @@ const tests = [ { name: 'test-runner/output/hooks.js' }, { name: 'test-runner/output/hooks_spec_reporter.js', transform: specTransform }, { name: 'test-runner/output/skip-each-hooks.js', transform: specTransform }, + { name: 'test-runner/output/suite-skip-hooks.js', transform: specTransform }, { name: 'test-runner/output/timeout_in_before_each_should_not_affect_further_tests.js' }, { name: 'test-runner/output/hooks-with-no-global-test.js' }, { name: 'test-runner/output/global-hooks-with-no-tests.js' }, From 3d5934220ed76e480814ce68ae3a54ef206e419a Mon Sep 17 00:00:00 2001 From: Colin Ihrig Date: Sat, 16 Mar 2024 19:13:57 -0400 Subject: [PATCH 3/3] Update test/fixtures/test-runner/output/suite-skip-hooks.js Co-authored-by: Chemi Atlow --- .../test-runner/output/suite-skip-hooks.js | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/test/fixtures/test-runner/output/suite-skip-hooks.js b/test/fixtures/test-runner/output/suite-skip-hooks.js index 4c1de8b757a06d..2d8396597146f1 100644 --- a/test/fixtures/test-runner/output/suite-skip-hooks.js +++ b/test/fixtures/test-runner/output/suite-skip-hooks.js @@ -9,22 +9,6 @@ const { it, } = require('node:test'); -// before(() => { -// console.log('BEFORE'); -// }); - -// beforeEach(() => { -// console.log('BEFORE EACH'); -// }); - -// after(() => { -// console.log('AFTER'); -// }); - -// afterEach(() => { -// console.log('AFTER EACH'); -// }); - describe('skip all hooks in this suite', { skip: true }, () => { before(() => { console.log('BEFORE 1');