Skip to content

test_runner: scope file-level hooks per file in no-isolation mode #83219

test_runner: scope file-level hooks per file in no-isolation mode

test_runner: scope file-level hooks per file in no-isolation mode #83219

Triggered via pull request April 6, 2026 14:00
Status Failure
Total duration 45m 3s
Artifacts

test-linux.yml

on: pull_request
Matrix: test-linux
Fit to window
Zoom out
Zoom in

Annotations

12 errors, 2 warnings, and 2 notices
test-linux (ubuntu-24.04-arm)
Process completed with exit code 2.
test-linux (ubuntu-24.04-arm): test/parallel/test-runner-global-setup-teardown.mjs#L514
--- stdout --- Test failure: 'should execute globalSetup and globalTeardown correctly with imported module containing tests' Location: test/parallel/test-runner-global-setup-teardown.mjs:483:7 AssertionError [ERR_ASSERTION]: The input did not match the regular expression /suites 0/. Input: 'Global setup executed\n' + 'βœ” Imported module Ok (0.652284ms)\n' + 'βœ– Imported module Fail (0.20975ms)\n' + 'β–Ά /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js\n' + ' βœ” verify setup was executed (0.371499ms)\n' + ' βœ” another simple test (0.15074ms)\n' + 'βœ” /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js (0.79832ms)\n' + 'Global teardown executed\n' + 'β„Ή tests 4\n' + 'β„Ή suites 1\n' + 'β„Ή pass 3\n' + 'β„Ή fail 1\n' + 'β„Ή cancelled 0\n' + 'β„Ή skipped 0\n' + 'β„Ή todo 0\n' + 'β„Ή duration_ms 19.861986\n' + '\n' + 'βœ– failing tests:\n' + '\n' + 'test at test/fixtures/test-runner/global-setup-teardown/imported-module-with-test.mjs:4:1\n' + 'βœ– Imported module Fail (0.20975ms)\n' + ' Error: fail\n' + ' at TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/imported-module-with-test.mjs:4:44)\n' + ' at Test.runInAsyncScope (node:async_hooks:226:14)\n' + ' at Test.run (node:internal/test_runner/test:1272:25)\n' + ' at Test.processPendingSubtests (node:internal/test_runner/test:887:18)\n' + ' at Test.postRun (node:internal/test_runner/test:1401:19)\n' + ' at Test.run (node:internal/test_runner/test:1329:12)\n' + ' at async startSubtestAfterBootstrap (node:internal/test_runner/harness:385:3)\n' at TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/parallel/test-runner-global-setup-teardown.mjs:514:16) at process.processTicksAndRejections (node:internal/process/task_queues:104:5) at async Test.run (node:internal/test_runner/test:1279:7) at async Suite.processPendingSubtests (node:internal/test_runner/test:887:7) { generatedMessage: true, code: 'ERR_ASSERTION', actual: 'Global setup executed\n' + 'βœ” Imported module Ok (0.652284ms)\n' + 'βœ– Imported module Fail (0.20975ms)\n' + 'β–Ά /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js\n' + ' βœ” verify setup was executed (0.371499ms)\n' + ' βœ” another simple test (0.15074ms)\n' + 'βœ” /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js (0.79832ms)\n' + 'Global teardown executed\n' + 'β„Ή tests 4\n' + 'β„Ή suites 1\n' + '...', expected: /suites 0/, operator: 'match', diff: 'simple' } Command: out/Release/node --test-reporter=./test/common/test-error-reporter.js --test-reporter-destination=stdout /home/runner/work/node/node/node/test/parallel/test-runner-global-setup-teardown.mjs
test-linux (ubuntu-24.04-arm): test/parallel/test-runner-cli.js#L39
--- stderr --- node:internal/assert/utils:146 throw error; ^ AssertionError [ERR_ASSERTION]: The input did not match the regular expression /not ok 2 - this should fail/. Input: 'TAP version 13\n' + '# Subtest: index.test.js\n' + ' # Subtest: this should pass\n' + ' ok 1 - this should pass\n' + ' ---\n' + ' duration_ms: 0.499375\n' + " type: 'test'\n" + ' ...\n' + ' 1..1\n' + 'ok 1 - index.test.js\n' + ' ---\n' + ' duration_ms: 3.492446\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: random.test.mjs\n' + ' # Subtest: this should fail\n' + ' not ok 1 - this should fail\n' + ' ---\n' + ' duration_ms: 0.205038\n' + " type: 'test'\n" + " location: '/home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:3:1'\n" + " failureType: 'testCodeFailure'\n" + " error: 'this is a failing test'\n" + " code: 'ERR_TEST_FAILURE'\n" + ' stack: |-\n' + ' TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:4:9)\n' + ' Test.runInAsyncScope (node:async_hooks:226:14)\n' + ' Test.run (node:internal/test_runner/test:1272:25)\n' + ' Test.start (node:internal/test_runner/test:1167:17)\n' + ' node:internal/test_runner/test:1688:71\n' + ' node:internal/per_context/primordials:466:82\n' + ' new Promise (<anonymous>)\n' + ' new SafePromise (node:internal/per_context/primordials:435:3)\n' + ' node:internal/per_context/primordials:466:9\n' + ' Array.map (<anonymous>)\n' + ' ...\n' + ' 1..1\n' + 'not ok 2 - random.test.mjs\n' + ' ---\n' + ' duration_ms: 0.350994\n' + " type: 'suite'\n" + " location: '/home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:1:1'\n" + " failureType: 'subtestsFailed'\n" + " error: '1 subtest failed'\n" + " code: 'ERR_TEST_FAILURE'\n" + ' ...\n' + '# Subtest: subdir/subdir_test.js\n' + 'ok 3 - subdir/subdir_test.js\n' + ' ---\n' + ' duration_ms: 0.058546\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/random.cjs\n' + ' # Subtest: this should pass\n' + ' ok 1 - this should pass\n' + ' ---\n' + ' duration_ms: 1.00359\n' + " type: 'test'\n" + ' ...\n' + ' 1..1\n' + 'ok 4 - test/random.cjs\n' + ' ---\n' + ' duration_ms: 1.102729\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/skip_by_name.cjs\n' + ' # Subtest: this should be skipped\n' + ' ok 1 - this should be skipped\n' + ' ---\n' + ' duration_ms: 0.160669\n' + " type: 'test'\n" + ' ...\n' + ' # Subtest: this should be executed\n' + ' ok 2 - this should be executed\n' + ' ---\n' + ' duration_ms: 0.128268\n' + " type: 'test'\n" + ' ...\n' + ' 1..2\n' + 'ok 5 - test/skip_by_name.cjs\n' + ' ---\n' + ' duration_ms: 2.278043\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/suite_and_test.cjs\n' + ' # Subtest: this is a suite\n' + ' ok 1 - this is a suite\n' + ' ---\n' + ' duration_ms: 0.039193\n' + " type: 'suite'\n" + ' ...\n' + ' # Subtest: this is a test\n' + ' ok 2 - this is a test\n' + ' ---\n' + ' duration_ms: 0.060722\n' + " type: 'test'\n" + ' ...\n' + ' 1..2\n' + 'ok 6 - test/suite_and_test.cjs\n' + ' ---\n' + ' duration_ms: 0.238935\n' + " type: 'suite'\n" + ' ...\n' + '1..6\n' + '# tests 6\n' + '# suites 7\n' + '# pass 5\n' + '# fail 1\n' + '# cancelled 0\n' + '# skipped 0\n' + '# todo 0\n' + '# duration_ms 52.507912\n' at Object.<anonymous> (/home/runner/work/node/node/node/test/parallel/test-runner-cli.js:39:12) at Module._compile (node:internal/modules/cjs/loader:1829:14) at Object..js (node:internal/modules/cjs/loader:1969:10) at Module.load (node:internal
test-linux (ubuntu-24.04-arm): test/parallel/test-inspector-dom-storage.js#L75
--- stderr --- Debugger listening on ws://127.0.0.1:46853/e072c281-5db6-4926-9479-19be9377fe2c For help, see: https://nodejs.org/en/docs/inspector node:inspector:212 emitProtocolEvent(eventName, params); ^ TypeError: Missing newValue in event at broadcastToFrontend (node:inspector:212:3) at Object.domStorageItemAdded (node:inspector:233:36) at itemAdded (node:internal/inspector/webstorage:53:14) at InspectorLocalStorage.setItem (node:internal/inspector/webstorage:13:7) at test (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:75:16) at async testGetData (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:62:3) at async test (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:167:3) Node.js v26.0.0-pre Command: out/Release/node --inspect=0 --experimental-storage-inspection --localstorage-file=./localstorage.db /home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js
test-linux (ubuntu-24.04-arm): test/test-runner/test-output-randomize-output-cli-none.mjs#L0
--- stderr --- node:internal/modules/run_main:107 triggerUncaughtException( ^ AssertionError [ERR_ASSERTION]: Expected values to be strictly equal: + actual - expected + 'β–Ά <project-root>/test/fixtures/test-runner/shards/j.cjs\n' + + ' βœ” j.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/j.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/c.cjs\n' + + ' βœ” c.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/c.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/e.cjs\n' + + ' βœ” e.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/e.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/h.cjs\n' + + ' βœ” h.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/h.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/f.cjs\n' + + ' βœ” f.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/f.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/b.cjs\n' + + ' βœ” b.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/b.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/a.cjs\n' + + ' βœ” a.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/a.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/i.cjs\n' + + ' βœ” i.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/i.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/g.cjs\n' + + ' βœ” g.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/g.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/d.cjs\n' + + ' βœ” d.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/d.cjs (*ms)\n' + - 'βœ” j.cjs this should pass (*ms)\n' + - 'βœ” c.cjs this should pass (*ms)\n' + - 'βœ” e.cjs this should pass (*ms)\n' + - 'βœ” h.cjs this should pass (*ms)\n' + - 'βœ” f.cjs this should pass (*ms)\n' + - 'βœ” b.cjs this should pass (*ms)\n' + - 'βœ” a.cjs this should pass (*ms)\n' + - 'βœ” i.cjs this should pass (*ms)\n' + - 'βœ” g.cjs this should pass (*ms)\n' + - 'βœ” d.cjs this should pass (*ms)\n' + 'β„Ή Randomized test order seed: 12345\n' + 'β„Ή tests 10\n' + + 'β„Ή suites 10\n' + - 'β„Ή suites 0\n' + 'β„Ή pass 10\n' + 'β„Ή fail 0\n' + 'β„Ή cancelled 0\n' + 'β„Ή skipped 0\n' + 'β„Ή todo 0\n' + at assertSnapshot (/home/runner/work/node/node/node/test/common/assertSnapshot.js:173:12) at async spawnAndAssert (/home/runner/work/node/node/node/test/common/assertSnapshot.js:208:3) at async file:///home/runner/work/node/node/node/test/test-runner/test-output-randomize-output-cli-none.mjs:8:1 { generatedMessage: true, code: 'ERR_ASSERTION', actual: 'β–Ά <project-root>/test/fixtures/test-runner/shards/j.cjs\n' + ' βœ” j.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/j.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/c.cjs\n' + ' βœ” c.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/c.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/e.cjs\n' + ' βœ” e.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/e.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/h.cjs\n' + ' βœ” h.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/h.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/f.cjs\n' + ' βœ” f.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/f.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/b.cjs\n' + ' βœ” b.cjs t
test-linux (ubuntu-24.04-arm): test/test-runner/test-output-randomize-nested-scenarios-output-cli-none.mjs#L0
--- stderr --- node:internal/modules/run_main:107 triggerUncaughtException( ^ AssertionError [ERR_ASSERTION]: Expected values to be strictly equal: + actual - expected + 'β–Ά <project-root>/test/fixtures/test-runner/randomize/internal-order-nested-scenarios.cjs\n' + + ' β–Ά nested-scenarios\n' + + ' β–Ά scenario describe-it\n' + + ' β–Ά describe-it block\n' + + ' β–Ά describe-it 2\n' + + ' β–Ά describe-it 2-2\n' + + ' βœ” describe-it 2-2-2 (*ms)\n' + + ' βœ” describe-it 2-2-1 (*ms)\n' + + ' βœ” describe-it 2-2-3 (*ms)\n' + + ' βœ” describe-it 2-2 (*ms)\n' + + ' β–Ά describe-it 2-1\n' + + ' βœ” describe-it 2-1-2 (*ms)\n' + + ' βœ” describe-it 2-1-1 (*ms)\n' + + ' βœ” describe-it 2-1-3 (*ms)\n' + + ' βœ” describe-it 2-1 (*ms)\n' + + ' β–Ά describe-it 2-3\n' + + ' βœ” describe-it 2-3-2 (*ms)\n' + + ' βœ” describe-it 2-3-1 (*ms)\n' + + ' βœ” describe-it 2-3-3 (*ms)\n' + + ' βœ” describe-it 2-3 (*ms)\n' + + ' βœ” describe-it 2 (*ms)\n' + + ' β–Ά describe-it 1\n' + + ' β–Ά describe-it 1-2\n' + + ' βœ” describe-it 1-2-2 (*ms)\n' + + ' βœ” describe-it 1-2-1 (*ms)\n' + + ' βœ” describe-it 1-2-3 (*ms)\n' + + ' βœ” describe-it 1-2 (*ms)\n' + + ' β–Ά describe-it 1-1\n' + + ' βœ” describe-it 1-1-2 (*ms)\n' + + ' βœ” describe-it 1-1-1 (*ms)\n' + + ' βœ” describe-it 1-1-3 (*ms)\n' + + ' βœ” describe-it 1-1 (*ms)\n' + + ' β–Ά describe-it 1-3\n' + + ' βœ” describe-it 1-3-2 (*ms)\n' + + ' βœ” describe-it 1-3-1 (*ms)\n' + + ' βœ” describe-it 1-3-3 (*ms)\n' + + ' βœ” describe-it 1-3 (*ms)\n' + + ' βœ” describe-it 1 (*ms)\n' + + ' β–Ά describe-it 3\n' + + ' β–Ά describe-it 3-2\n' + + ' βœ” describe-it 3-2-2 (*ms)\n' + + ' βœ” describe-it 3-2-1 (*ms)\n' + + ' βœ” describe-it 3-2-3 (*ms)\n' + + ' βœ” describe-it 3-2 (*ms)\n' + + ' β–Ά describe-it 3-1\n' + + ' βœ” describe-it 3-1-2 (*ms)\n' + + ' βœ” describe-it 3-1-1 (*ms)\n' + + ' βœ” describe-it 3-1-3 (*ms)\n' + + ' βœ” describe-it 3-1 (*ms)\n' + + ' β–Ά describe-it 3-3\n' + + ' βœ” describe-it 3-3-2 (*ms)\n' + + ' βœ” describe-it 3-3-1 (*ms)\n' + + ' βœ” describe-it 3-3-3 (*ms)\n' + + ' βœ” describe-it 3-3 (*ms)\n' + + ' βœ” describe-it 3 (*ms)\n' + + ' βœ” describe-it block (*ms)\n' + + ' βœ” scenario describe-it (*ms)\n' + + ' β–Ά scenario static-no-await\n' + + ' β–Ά static-no-await block\n' + + ' β–Ά static-no-await 2\n' + + ' β–Ά static-no-await 2-2\n' + + ' βœ” static-no-await 2-2-2 (*ms)\n' + + ' βœ” static-no-await 2-2-1 (*ms)\n' + + ' βœ” static-no-await 2-2-3 (*ms)\n' + + ' βœ” static-no-await 2-2 (*ms)\n' + + ' β–Ά static-no-await 2-1\n' + + ' βœ” static-no-await 2-1-2 (*ms)\n' + + ' βœ” static-no-await 2-1-1 (*ms)\n' + + ' βœ” static-no-await 2-1-3 (*ms)\n' + + ' βœ” static-no-await 2-1 (*ms)\n' + + ' β–Ά static-no-await 2-3\n' + + ' βœ” static-no-await 2-3-2 (*ms)\n' + + ' βœ” static-no-await 2-3-1 (*ms)\n' + + ' βœ” static-no-await 2-3-3 (*ms)\n' + + ' βœ” static-no-await 2-3 (*ms)\n' + + ' βœ” static-no-await 2 (*ms)\n' + + ' β–Ά static-no-await 1\n' + + ' β–Ά static-no-await 1-2\n' + + ' βœ” static-no-await 1-2-2 (*ms)\n' + + ' βœ” static-no-await 1-2-1 (*ms)\n' + + ' βœ” static-no-await 1-2-3 (*ms)\n' + + ' βœ” static-no-await 1-2 (*ms)\n' + + ' β–Ά static-n
test-linux (ubuntu-24.04)
Process completed with exit code 2.
test-linux (ubuntu-24.04): test/parallel/test-runner-global-setup-teardown.mjs#L514
--- stdout --- Test failure: 'should execute globalSetup and globalTeardown correctly with imported module containing tests' Location: test/parallel/test-runner-global-setup-teardown.mjs:483:7 AssertionError [ERR_ASSERTION]: The input did not match the regular expression /suites 0/. Input: 'Global setup executed\n' + 'βœ” Imported module Ok (1.065701ms)\n' + 'βœ– Imported module Fail (0.199202ms)\n' + 'β–Ά /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js\n' + ' βœ” verify setup was executed (0.38374ms)\n' + ' βœ” another simple test (0.189272ms)\n' + 'βœ” /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js (0.889583ms)\n' + 'Global teardown executed\n' + 'β„Ή tests 4\n' + 'β„Ή suites 1\n' + 'β„Ή pass 3\n' + 'β„Ή fail 1\n' + 'β„Ή cancelled 0\n' + 'β„Ή skipped 0\n' + 'β„Ή todo 0\n' + 'β„Ή duration_ms 19.622468\n' + '\n' + 'βœ– failing tests:\n' + '\n' + 'test at test/fixtures/test-runner/global-setup-teardown/imported-module-with-test.mjs:4:1\n' + 'βœ– Imported module Fail (0.199202ms)\n' + ' Error: fail\n' + ' at TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/imported-module-with-test.mjs:4:44)\n' + ' at Test.runInAsyncScope (node:async_hooks:226:14)\n' + ' at Test.run (node:internal/test_runner/test:1272:25)\n' + ' at Test.processPendingSubtests (node:internal/test_runner/test:887:18)\n' + ' at Test.postRun (node:internal/test_runner/test:1401:19)\n' + ' at Test.run (node:internal/test_runner/test:1329:12)\n' + ' at async startSubtestAfterBootstrap (node:internal/test_runner/harness:385:3)\n' at TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/parallel/test-runner-global-setup-teardown.mjs:514:16) at process.processTicksAndRejections (node:internal/process/task_queues:104:5) at async Test.run (node:internal/test_runner/test:1279:7) at async Suite.processPendingSubtests (node:internal/test_runner/test:887:7) { generatedMessage: true, code: 'ERR_ASSERTION', actual: 'Global setup executed\n' + 'βœ” Imported module Ok (1.065701ms)\n' + 'βœ– Imported module Fail (0.199202ms)\n' + 'β–Ά /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js\n' + ' βœ” verify setup was executed (0.38374ms)\n' + ' βœ” another simple test (0.189272ms)\n' + 'βœ” /home/runner/work/node/node/node/test/fixtures/test-runner/global-setup-teardown/test-file.js (0.889583ms)\n' + 'Global teardown executed\n' + 'β„Ή tests 4\n' + 'β„Ή suites 1\n' + '...', expected: /suites 0/, operator: 'match', diff: 'simple' } Command: out/Release/node --test-reporter=./test/common/test-error-reporter.js --test-reporter-destination=stdout /home/runner/work/node/node/node/test/parallel/test-runner-global-setup-teardown.mjs
test-linux (ubuntu-24.04): test/parallel/test-runner-cli.js#L39
--- stderr --- node:internal/assert/utils:146 throw error; ^ AssertionError [ERR_ASSERTION]: The input did not match the regular expression /not ok 2 - this should fail/. Input: 'TAP version 13\n' + '# Subtest: index.test.js\n' + ' # Subtest: this should pass\n' + ' ok 1 - this should pass\n' + ' ---\n' + ' duration_ms: 0.740723\n' + " type: 'test'\n" + ' ...\n' + ' 1..1\n' + 'ok 1 - index.test.js\n' + ' ---\n' + ' duration_ms: 1.96643\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: random.test.mjs\n' + ' # Subtest: this should fail\n' + ' not ok 1 - this should fail\n' + ' ---\n' + ' duration_ms: 0.326672\n' + " type: 'test'\n" + " location: '/home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:3:1'\n" + " failureType: 'testCodeFailure'\n" + " error: 'this is a failing test'\n" + " code: 'ERR_TEST_FAILURE'\n" + ' stack: |-\n' + ' TestContext.<anonymous> (file:///home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:4:9)\n' + ' Test.runInAsyncScope (node:async_hooks:226:14)\n' + ' Test.run (node:internal/test_runner/test:1272:25)\n' + ' Test.start (node:internal/test_runner/test:1167:17)\n' + ' node:internal/test_runner/test:1688:71\n' + ' node:internal/per_context/primordials:466:82\n' + ' new Promise (<anonymous>)\n' + ' new SafePromise (node:internal/per_context/primordials:435:3)\n' + ' node:internal/per_context/primordials:466:9\n' + ' Array.map (<anonymous>)\n' + ' ...\n' + ' 1..1\n' + 'not ok 2 - random.test.mjs\n' + ' ---\n' + ' duration_ms: 0.526153\n' + " type: 'suite'\n" + " location: '/home/runner/work/node/node/node/test/fixtures/test-runner/default-behavior/random.test.mjs:1:1'\n" + " failureType: 'subtestsFailed'\n" + " error: '1 subtest failed'\n" + " code: 'ERR_TEST_FAILURE'\n" + ' ...\n' + '# Subtest: subdir/subdir_test.js\n' + 'ok 3 - subdir/subdir_test.js\n' + ' ---\n' + ' duration_ms: 0.100901\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/random.cjs\n' + ' # Subtest: this should pass\n' + ' ok 1 - this should pass\n' + ' ---\n' + ' duration_ms: 0.942291\n' + " type: 'test'\n" + ' ...\n' + ' 1..1\n' + 'ok 4 - test/random.cjs\n' + ' ---\n' + ' duration_ms: 1.112727\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/skip_by_name.cjs\n' + ' # Subtest: this should be skipped\n' + ' ok 1 - this should be skipped\n' + ' ---\n' + ' duration_ms: 0.200366\n' + " type: 'test'\n" + ' ...\n' + ' # Subtest: this should be executed\n' + ' ok 2 - this should be executed\n' + ' ---\n' + ' duration_ms: 2.341444\n' + " type: 'test'\n" + ' ...\n' + ' 1..2\n' + 'ok 5 - test/skip_by_name.cjs\n' + ' ---\n' + ' duration_ms: 2.826321\n' + " type: 'suite'\n" + ' ...\n' + '# Subtest: test/suite_and_test.cjs\n' + ' # Subtest: this is a suite\n' + ' ok 1 - this is a suite\n' + ' ---\n' + ' duration_ms: 0.063486\n' + " type: 'suite'\n" + ' ...\n' + ' # Subtest: this is a test\n' + ' ok 2 - this is a test\n' + ' ---\n' + ' duration_ms: 0.10038\n' + " type: 'test'\n" + ' ...\n' + ' 1..2\n' + 'ok 6 - test/suite_and_test.cjs\n' + ' ---\n' + ' duration_ms: 0.400415\n' + " type: 'suite'\n" + ' ...\n' + '1..6\n' + '# tests 6\n' + '# suites 7\n' + '# pass 5\n' + '# fail 1\n' + '# cancelled 0\n' + '# skipped 0\n' + '# todo 0\n' + '# duration_ms 55.404575\n' at Object.<anonymous> (/home/runner/work/node/node/node/test/parallel/test-runner-cli.js:39:12) at Module._compile (node:internal/modules/cjs/loader:1829:14) at Object..js (node:internal/modules/cjs/loader:1969:10) at Module.load (node:internal/
test-linux (ubuntu-24.04): test/parallel/test-inspector-dom-storage.js#L75
--- stderr --- Debugger listening on ws://127.0.0.1:44585/3121e9b9-d906-4d0a-b181-aed9578c8696 For help, see: https://nodejs.org/en/docs/inspector node:inspector:212 emitProtocolEvent(eventName, params); ^ TypeError: Missing newValue in event at broadcastToFrontend (node:inspector:212:3) at Object.domStorageItemAdded (node:inspector:233:36) at itemAdded (node:internal/inspector/webstorage:53:14) at InspectorLocalStorage.setItem (node:internal/inspector/webstorage:13:7) at test (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:75:16) at async testGetData (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:62:3) at async test (/home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js:167:3) Node.js v26.0.0-pre Command: out/Release/node --inspect=0 --experimental-storage-inspection --localstorage-file=./localstorage.db /home/runner/work/node/node/node/test/parallel/test-inspector-dom-storage.js
test-linux (ubuntu-24.04): test/test-runner/test-output-randomize-output-cli-none.mjs#L0
--- stderr --- node:internal/modules/run_main:107 triggerUncaughtException( ^ AssertionError [ERR_ASSERTION]: Expected values to be strictly equal: + actual - expected + 'β–Ά <project-root>/test/fixtures/test-runner/shards/j.cjs\n' + + ' βœ” j.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/j.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/c.cjs\n' + + ' βœ” c.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/c.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/e.cjs\n' + + ' βœ” e.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/e.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/h.cjs\n' + + ' βœ” h.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/h.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/f.cjs\n' + + ' βœ” f.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/f.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/b.cjs\n' + + ' βœ” b.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/b.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/a.cjs\n' + + ' βœ” a.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/a.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/i.cjs\n' + + ' βœ” i.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/i.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/g.cjs\n' + + ' βœ” g.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/g.cjs (*ms)\n' + + 'β–Ά <project-root>/test/fixtures/test-runner/shards/d.cjs\n' + + ' βœ” d.cjs this should pass (*ms)\n' + + 'βœ” <project-root>/test/fixtures/test-runner/shards/d.cjs (*ms)\n' + - 'βœ” j.cjs this should pass (*ms)\n' + - 'βœ” c.cjs this should pass (*ms)\n' + - 'βœ” e.cjs this should pass (*ms)\n' + - 'βœ” h.cjs this should pass (*ms)\n' + - 'βœ” f.cjs this should pass (*ms)\n' + - 'βœ” b.cjs this should pass (*ms)\n' + - 'βœ” a.cjs this should pass (*ms)\n' + - 'βœ” i.cjs this should pass (*ms)\n' + - 'βœ” g.cjs this should pass (*ms)\n' + - 'βœ” d.cjs this should pass (*ms)\n' + 'β„Ή Randomized test order seed: 12345\n' + 'β„Ή tests 10\n' + + 'β„Ή suites 10\n' + - 'β„Ή suites 0\n' + 'β„Ή pass 10\n' + 'β„Ή fail 0\n' + 'β„Ή cancelled 0\n' + 'β„Ή skipped 0\n' + 'β„Ή todo 0\n' + at assertSnapshot (/home/runner/work/node/node/node/test/common/assertSnapshot.js:173:12) at async spawnAndAssert (/home/runner/work/node/node/node/test/common/assertSnapshot.js:208:3) at async file:///home/runner/work/node/node/node/test/test-runner/test-output-randomize-output-cli-none.mjs:8:1 { generatedMessage: true, code: 'ERR_ASSERTION', actual: 'β–Ά <project-root>/test/fixtures/test-runner/shards/j.cjs\n' + ' βœ” j.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/j.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/c.cjs\n' + ' βœ” c.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/c.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/e.cjs\n' + ' βœ” e.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/e.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/h.cjs\n' + ' βœ” h.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/h.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/f.cjs\n' + ' βœ” f.cjs this should pass (*ms)\n' + 'βœ” <project-root>/test/fixtures/test-runner/shards/f.cjs (*ms)\n' + 'β–Ά <project-root>/test/fixtures/test-runner/shards/b.cjs\n' + ' βœ” b.cjs t
test-linux (ubuntu-24.04): test/test-runner/test-output-randomize-nested-scenarios-output-cli-none.mjs#L0
--- stderr --- node:internal/modules/run_main:107 triggerUncaughtException( ^ AssertionError [ERR_ASSERTION]: Expected values to be strictly equal: + actual - expected + 'β–Ά <project-root>/test/fixtures/test-runner/randomize/internal-order-nested-scenarios.cjs\n' + + ' β–Ά nested-scenarios\n' + + ' β–Ά scenario describe-it\n' + + ' β–Ά describe-it block\n' + + ' β–Ά describe-it 2\n' + + ' β–Ά describe-it 2-2\n' + + ' βœ” describe-it 2-2-2 (*ms)\n' + + ' βœ” describe-it 2-2-1 (*ms)\n' + + ' βœ” describe-it 2-2-3 (*ms)\n' + + ' βœ” describe-it 2-2 (*ms)\n' + + ' β–Ά describe-it 2-1\n' + + ' βœ” describe-it 2-1-2 (*ms)\n' + + ' βœ” describe-it 2-1-1 (*ms)\n' + + ' βœ” describe-it 2-1-3 (*ms)\n' + + ' βœ” describe-it 2-1 (*ms)\n' + + ' β–Ά describe-it 2-3\n' + + ' βœ” describe-it 2-3-2 (*ms)\n' + + ' βœ” describe-it 2-3-1 (*ms)\n' + + ' βœ” describe-it 2-3-3 (*ms)\n' + + ' βœ” describe-it 2-3 (*ms)\n' + + ' βœ” describe-it 2 (*ms)\n' + + ' β–Ά describe-it 1\n' + + ' β–Ά describe-it 1-2\n' + + ' βœ” describe-it 1-2-2 (*ms)\n' + + ' βœ” describe-it 1-2-1 (*ms)\n' + + ' βœ” describe-it 1-2-3 (*ms)\n' + + ' βœ” describe-it 1-2 (*ms)\n' + + ' β–Ά describe-it 1-1\n' + + ' βœ” describe-it 1-1-2 (*ms)\n' + + ' βœ” describe-it 1-1-1 (*ms)\n' + + ' βœ” describe-it 1-1-3 (*ms)\n' + + ' βœ” describe-it 1-1 (*ms)\n' + + ' β–Ά describe-it 1-3\n' + + ' βœ” describe-it 1-3-2 (*ms)\n' + + ' βœ” describe-it 1-3-1 (*ms)\n' + + ' βœ” describe-it 1-3-3 (*ms)\n' + + ' βœ” describe-it 1-3 (*ms)\n' + + ' βœ” describe-it 1 (*ms)\n' + + ' β–Ά describe-it 3\n' + + ' β–Ά describe-it 3-2\n' + + ' βœ” describe-it 3-2-2 (*ms)\n' + + ' βœ” describe-it 3-2-1 (*ms)\n' + + ' βœ” describe-it 3-2-3 (*ms)\n' + + ' βœ” describe-it 3-2 (*ms)\n' + + ' β–Ά describe-it 3-1\n' + + ' βœ” describe-it 3-1-2 (*ms)\n' + + ' βœ” describe-it 3-1-1 (*ms)\n' + + ' βœ” describe-it 3-1-3 (*ms)\n' + + ' βœ” describe-it 3-1 (*ms)\n' + + ' β–Ά describe-it 3-3\n' + + ' βœ” describe-it 3-3-2 (*ms)\n' + + ' βœ” describe-it 3-3-1 (*ms)\n' + + ' βœ” describe-it 3-3-3 (*ms)\n' + + ' βœ” describe-it 3-3 (*ms)\n' + + ' βœ” describe-it 3 (*ms)\n' + + ' βœ” describe-it block (*ms)\n' + + ' βœ” scenario describe-it (*ms)\n' + + ' β–Ά scenario static-no-await\n' + + ' β–Ά static-no-await block\n' + + ' β–Ά static-no-await 2\n' + + ' β–Ά static-no-await 2-2\n' + + ' βœ” static-no-await 2-2-2 (*ms)\n' + + ' βœ” static-no-await 2-2-1 (*ms)\n' + + ' βœ” static-no-await 2-2-3 (*ms)\n' + + ' βœ” static-no-await 2-2 (*ms)\n' + + ' β–Ά static-no-await 2-1\n' + + ' βœ” static-no-await 2-1-2 (*ms)\n' + + ' βœ” static-no-await 2-1-1 (*ms)\n' + + ' βœ” static-no-await 2-1-3 (*ms)\n' + + ' βœ” static-no-await 2-1 (*ms)\n' + + ' β–Ά static-no-await 2-3\n' + + ' βœ” static-no-await 2-3-2 (*ms)\n' + + ' βœ” static-no-await 2-3-1 (*ms)\n' + + ' βœ” static-no-await 2-3-3 (*ms)\n' + + ' βœ” static-no-await 2-3 (*ms)\n' + + ' βœ” static-no-await 2 (*ms)\n' + + ' β–Ά static-no-await 1\n' + + ' β–Ά static-no-await 1-2\n' + + ' βœ” static-no-await 1-2-2 (*ms)\n' + + ' βœ” static-no-await 1-2-1 (*ms)\n' + + ' βœ” static-no-await 1-2-3 (*ms)\n' + + ' βœ” static-no-await 1-2 (*ms)\n' + + ' β–Ά static-n
test-linux (ubuntu-24.04-arm)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: Mozilla-Actions/sccache-action@7d986dd989559c6ecdb630a3fd2557667be217ad. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026. Please check if updated versions of these actions are available that support Node.js 24. To opt into Node.js 24 now, set the FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true environment variable on the runner or in your workflow file. Once Node.js 24 becomes the default, you can temporarily opt out by setting ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true. For more information see: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/
test-linux (ubuntu-24.04)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: Mozilla-Actions/sccache-action@7d986dd989559c6ecdb630a3fd2557667be217ad. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026. Please check if updated versions of these actions are available that support Node.js 24. To opt into Node.js 24 now, set the FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true environment variable on the runner or in your workflow file. Once Node.js 24 becomes the default, you can temporarily opt out by setting ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true. For more information see: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/
sccache stats
64% - 3090 hits, 1774 misses, 0 errors
sccache stats
72% - 3484 hits, 1367 misses, 0 errors