Skip to content

Count final chat messages for scroll badge #2296

Count final chat messages for scroll badge

Count final chat messages for scroll badge #2296

Triggered via push May 24, 2026 04:36
Status Failure
Total duration 3m 14s
Artifacts 1

ci.yml

on: push
Matrix: unit-tests
Web Tests (Unit)
55s
Web Tests (Unit)
Web Tests (Components)
1m 5s
Web Tests (Components)
Lint
33s
Lint
Typecheck
57s
Typecheck
Secret Scan (gitleaks)
11s
Secret Scan (gitleaks)
Server Unit Tests
1m 8s
Server Unit Tests
Unit Tests (macOS)
3m 11s
Unit Tests (macOS)
Unit Tests (Windows)
1m 43s
Unit Tests (Windows)
Unit Tests (Windows ConPTY)
1m 23s
Unit Tests (Windows ConPTY)
Server DB Integration Tests
1m 5s
Server DB Integration Tests
Preview Dist Smoke
41s
Preview Dist Smoke
Embedding Integration Tests
32s
Embedding Integration Tests
E2E Tests
E2E Tests
Repo Provider Integration Tests
Repo Provider Integration Tests
Coverage Report
Coverage Report
Docker Build & Push
0s
Docker Build & Push
Android Release Build
0s
Android Release Build
Publish to npm
0s
Publish to npm
Fit to window
Zoom out
Zoom in

Annotations

16 errors, 24 warnings, and 2 notices
Web Tests (Components)
Process completed with exit code 1.
test/components/SessionSettingsDialog.test.tsx > SessionSettingsDialog supervision > renders persisted supervision snapshot in the summary: web/test/components/SessionSettingsDialog.test.tsx#L235
TestingLibraryElementError: Unable to find an element with the text: summaryMode:supervised_audit. This could be because the text is broken up by multiple elements. In this case, you can provide a function for your text matcher to make your matcher more flexible. Ignored nodes: comments, script, style <body> <div> <div class="dialog-overlay" > <div class="dialog" style="width: 440px;" > <div class="dialog-header" > <span> settings </span> <button class="dialog-close" > close </button> </div> <div class="dialog-body" style="display: flex; flex-direction: column; gap: 14px;" > <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > type </div> <select class="input" style="width: 100%;" > <option value="claude-code-sdk" > claude_code_sdk </option> <option value="claude-code" > claude_code_cli </option> <option value="codex-sdk" > codex_sdk </option> <option value="codex" > codex_cli </option> <option value="copilot-sdk" > copilot_sdk </option> <option value="cursor-headless" > cursor_headless </option> <option value="opencode" > opencode </option> <option value="gemini-sdk" > gemini-sdk </option> <option value="gemini" > gemini </option> <option value="qwen" > qwen </option> <option value="openclaw" > openclaw </option> <option value="kimi-sdk" > kimi_sdk </option> <option value="shell" > shell </option> <option value="script" > script </option> </select> </div> <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > label </div> <input class="input" style="width: 100%;" /> </div> <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > description </div> <textarea class="input" placeholder="descriptionPlaceholder" rows="3" style="width: 100%; resize: vertical;" /> </div> <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > workingDir </div> <input class="input" placeholder="workingDirPlaceholder" style="width: 100%;" /> </div> <div style="display: flex; flex-direction: column; gap: 10px; padding-top: 4px; border-top: 1px solid rgba(148, 163, 184, 0.18);" > <div style="font-size: 12px; color: rgb(148, 163, 184); font-weight: 600;" >
test/components/SessionSettingsDialog.test.tsx > SessionSettingsDialog supervision > shows audit mode selection and persists the audit config: web/test/components/SessionSettingsDialog.test.tsx#L146
AssertionError: expected "spy" to be called with arguments: [ 'srv-1', 'deck_proj_brain', …(1) ] Received: 1st spy call: Array [ "srv-1", "deck_proj_brain", - ObjectContaining { - "transportConfig": ObjectContaining { - "supervision": ObjectContaining { - "auditMode": "audit>plan", + Object { + "transportConfig": Object { + "supervision": Object { + "auditMode": "audit", + "backend": "claude-code-sdk", + "maxAuditLoops": 2, + "maxAutoContinueStreak": 2, + "maxAutoContinueTotal": 0, + "maxParseRetries": 1, "mode": "supervised_audit", + "model": "opus[1M]", + "promptVersion": "supervision_decision_v1", + "taskRunPromptVersion": "task_run_status_v1", + "timeoutMs": 12000, }, }, }, ] Number of calls: 1 Ignored nodes: comments, script, style <html> <head /> <body> <div> <div class="dialog-overlay" > <div class="dialog" style="width: 440px;" > <div class="dialog-header" > <span> settings </span> <button class="dialog-close" > close </button> </div> <div class="dialog-body" style="display: flex; flex-direction: column; gap: 14px;" > <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > type </div> <select class="input" style="width: 100%;" > <option value="claude-code-sdk" > claude_code_sdk </option> <option value="claude-code" > claude_code_cli </option> <option value="codex-sdk" > codex_sdk </option> <option value="codex" > codex_cli </option> <option value="copilot-sdk" > copilot_sdk </option> <option value="cursor-headless" > cursor_headless </option> <option value="opencode" > opencode </option> <option value="gemini-sdk" > gemini-sdk </option> <option value="gemini" > gemini </option> <option value="qwen" > qwen </option> <option value="openclaw" > openclaw </option> <option value="kimi-sdk" > kimi_sdk </option> <option value="shell" > shell </option> <option value="script" > script </option> </select> </div> <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" > label </div> <input class="input" style="width: 100%;" /> </div> <div> <div style="font-size: 12px; color: rgb(148, 163, 184); margin-bottom: 4px;" >
Unit Tests (Node 24)
Process completed with exit code 1.
test/daemon/supervision-automation.test.ts > SupervisionAutomation > updates an in-flight run to the latest supervision snapshot when Auto settings change live: test/daemon/supervision-automation.test.ts#L436
AssertionError: expected "spy" to be called with arguments: [ ObjectContaining{…} ] Received: 1st spy call: Array [ - ObjectContaining { - "advanced": ObjectContaining { + Object { + "advanced": Object { "advancedRounds": Array [ - ObjectContaining { + Object { + "executionMode": "single_main", + "id": "automation_audit_1", + "permissionScope": "analysis_only", "preset": "implementation_audit", + "promptAppend": "[Contract: contextual_audit_v1] + Selected automation audit mode: audit + Task request: implement the feature + Task terminal state: complete + Audit the implementation result against the original request and recent execution summary. + Return exactly one verdict marker: <!-- P2P_VERDICT: PASS --> or <!-- P2P_VERDICT: REWORK -->.", + "timeoutMinutes": 6, + "title": "Implementation Audit 1", "verdictPolicy": "smart_gate", - }, - ObjectContaining { - "preset": "custom", - "verdictPolicy": "none", }, ], "kind": "supervision_internal", + }, + "fileContents": Array [ + Object { + "content": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", + "path": "contextual-audit-summary.md", }, + ], + "initiatorSession": "deck_supervision_brain", + "rounds": 1, + "serverLink": null, + "targets": Array [], + "userText": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", }, ] Number of calls: 1 ❯ test/daemon/supervision-automation.test.ts:436:29
test/supervision-config.test.ts > supervision config helpers > exposes the audit-mode allowlist from built-in combos: test/supervision-config.test.ts#L161
AssertionError: expected false to be true // Object.is equality - Expected + Received - true + false ❯ test/supervision-config.test.ts:161:59
test/supervision-config.test.ts > supervision config helpers > normalizes a heavy-mode session snapshot with audit defaults: test/supervision-config.test.ts#L88
AssertionError: expected 'audit' to be 'audit>plan' // Object.is equality Expected: "audit>plan" Received: "audit" ❯ test/supervision-config.test.ts:88:32
Unit Tests (Node 22)
The strategy configuration was canceled because "unit-tests._24" failed
Unit Tests (Node 22)
The operation was canceled.
test/daemon/supervision-automation.test.ts > SupervisionAutomation > updates an in-flight run to the latest supervision snapshot when Auto settings change live: test/daemon/supervision-automation.test.ts#L436
AssertionError: expected "spy" to be called with arguments: [ ObjectContaining{…} ] Received: 1st spy call: Array [ - ObjectContaining { - "advanced": ObjectContaining { + Object { + "advanced": Object { "advancedRounds": Array [ - ObjectContaining { + Object { + "executionMode": "single_main", + "id": "automation_audit_1", + "permissionScope": "analysis_only", "preset": "implementation_audit", + "promptAppend": "[Contract: contextual_audit_v1] + Selected automation audit mode: audit + Task request: implement the feature + Task terminal state: complete + Audit the implementation result against the original request and recent execution summary. + Return exactly one verdict marker: <!-- P2P_VERDICT: PASS --> or <!-- P2P_VERDICT: REWORK -->.", + "timeoutMinutes": 6, + "title": "Implementation Audit 1", "verdictPolicy": "smart_gate", - }, - ObjectContaining { - "preset": "custom", - "verdictPolicy": "none", }, ], "kind": "supervision_internal", + }, + "fileContents": Array [ + Object { + "content": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", + "path": "contextual-audit-summary.md", }, + ], + "initiatorSession": "deck_supervision_brain", + "rounds": 1, + "serverLink": null, + "targets": Array [], + "userText": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", }, ] Number of calls: 1 ❯ test/daemon/supervision-automation.test.ts:436:29
test/supervision-config.test.ts > supervision config helpers > exposes the audit-mode allowlist from built-in combos: test/supervision-config.test.ts#L161
AssertionError: expected false to be true // Object.is equality - Expected + Received - true + false ❯ test/supervision-config.test.ts:161:59
test/supervision-config.test.ts > supervision config helpers > normalizes a heavy-mode session snapshot with audit defaults: test/supervision-config.test.ts#L88
AssertionError: expected 'audit' to be 'audit>plan' // Object.is equality Expected: "audit>plan" Received: "audit" ❯ test/supervision-config.test.ts:88:32
Unit Tests (macOS)
Process completed with exit code 1.
test/daemon/supervision-automation.test.ts > SupervisionAutomation > updates an in-flight run to the latest supervision snapshot when Auto settings change live: test/daemon/supervision-automation.test.ts#L436
AssertionError: expected "spy" to be called with arguments: [ ObjectContaining{…} ] Received: 1st spy call: Array [ - ObjectContaining { - "advanced": ObjectContaining { + Object { + "advanced": Object { "advancedRounds": Array [ - ObjectContaining { + Object { + "executionMode": "single_main", + "id": "automation_audit_1", + "permissionScope": "analysis_only", "preset": "implementation_audit", + "promptAppend": "[Contract: contextual_audit_v1] + Selected automation audit mode: audit + Task request: implement the feature + Task terminal state: complete + Audit the implementation result against the original request and recent execution summary. + Return exactly one verdict marker: <!-- P2P_VERDICT: PASS --> or <!-- P2P_VERDICT: REWORK -->.", + "timeoutMinutes": 6, + "title": "Implementation Audit 1", "verdictPolicy": "smart_gate", - }, - ObjectContaining { - "preset": "custom", - "verdictPolicy": "none", }, ], "kind": "supervision_internal", + }, + "fileContents": Array [ + Object { + "content": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", + "path": "contextual-audit-summary.md", }, + ], + "initiatorSession": "deck_supervision_brain", + "rounds": 1, + "serverLink": null, + "targets": Array [], + "userText": "Contextual implementation audit for session deck_supervision_brain. + Audit verdict contract: contextual_audit_v1 + Selected automation audit mode: audit + Task request: implement the feature + Last assistant output: implemented the feature + Task terminal state: complete", }, ] Number of calls: 1 ❯ test/daemon/supervision-automation.test.ts:436:29
test/supervision-config.test.ts > supervision config helpers > exposes the audit-mode allowlist from built-in combos: test/supervision-config.test.ts#L161
AssertionError: expected false to be true // Object.is equality - Expected + Received - true + false ❯ test/supervision-config.test.ts:161:59
test/supervision-config.test.ts > supervision config helpers > normalizes a heavy-mode session snapshot with audit defaults: test/supervision-config.test.ts#L88
AssertionError: expected 'audit' to be 'audit>plan' // Object.is equality Expected: "audit>plan" Received: "audit" ❯ test/supervision-config.test.ts:88:32
Secret Scan (gitleaks)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, gitleaks/gitleaks-action@v2. 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/
Embedding Integration Tests
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/cache@v4, actions/checkout@v4, actions/setup-node@v4. 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/
Lint
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Lint: src/context/summary-compressor.ts#L240
'isRetryableError' is defined but never used
Lint: src/context/skill-registry.ts#L24
'EMPTY_SNAPSHOT' is assigned a value but never used
Lint: src/agent/runtime-context-bootstrap.ts#L24
'STARTUP_PROJECT_MEMORY_HEADER' is defined but never used
Lint: src/agent/providers/qwen.ts#L102
'_contextMessagePreamble' is assigned a value but never used
Lint: src/agent/providers/qwen.ts#L102
'_contextSystemText' is assigned a value but never used
Lint: src/agent/providers/qwen.ts#L101
'_memoryRecall' is assigned a value but never used
Lint: src/agent/providers/qwen.ts#L101
'_startupMemory' is assigned a value but never used
Lint: src/agent/providers/qwen.ts#L101
'_messagePreamble' is assigned a value but never used
Lint: src/agent/providers/qwen.ts#L101
'_systemText' is assigned a value but never used
Lint: src/agent/gemini-runtime-config.ts#L16
'err' is defined but never used
Preview Dist Smoke
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Web Tests (Unit)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Typecheck
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Web Tests (Components)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Server DB Integration Tests
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Server Unit Tests
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (Windows ConPTY)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (Windows)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (Node 24)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (Node 22)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (macOS)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@v4, actions/setup-node@v4. 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/
Unit Tests (Windows ConPTY)
NOTICE: windows-latest requests are being redirected to windows-2025-vs2026 by June 15, 2026
Unit Tests (Windows)
NOTICE: windows-latest requests are being redirected to windows-2025-vs2026 by June 15, 2026

Artifacts

Produced during runtime
Name Size Digest
gitleaks-results.sarif
367 Bytes
sha256:0def83ccba641919be5a4b7276f42dc01683861f42dec6926351bf00bd00010e