Skip to content

CI

CI #48

Triggered via schedule March 31, 2026 05:42
Status Failure
Total duration 1h 1m 23s
Artifacts 4

ci.yml

on: schedule
Workflow Security
9s
Workflow Security
Changelog Guard
0s
Changelog Guard
Code Coverage
15m 44s
Code Coverage
Matrix: local-validation
Fit to window
Zoom out
Zoom in

Annotations

11 errors, 10 warnings, and 1 notice
Code Coverage
Process completed with exit code 1.
[default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file: crates/web/ui/e2e/specs/chat-input.spec.js#L86
3) [default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Error: locator.click: Test timeout of 45000ms exceeded. Call log: - waiting for locator('#fullContextBtn') - locator resolved to <button id="fullContextBtn" title="Show full LLM context (system prompt + history)" class="text-xs border border-[var(--border)] px-2 py-1 rounded-md transition-colors cursor-pointer bg-transparent font-[var(--font-body)] inline-flex items-center gap-1 text-[var(--muted)]">…</button> - attempting click action 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 20ms 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 100ms 82 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 500ms 84 | } 85 | > 86 | await toggleBtn.click(); | ^ 87 | await expect(panel).toBeVisible(); 88 | 89 | const result = await expect at openFullContextWithRetry (/home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:86:19) at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:423:19
[default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file: crates/web/ui/e2e/specs/chat-input.spec.js#L0
3) [default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Test timeout of 45000ms exceeded.
[default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file: crates/web/ui/e2e/specs/chat-input.spec.js#L86
3) [default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file Error: locator.click: Test timeout of 45000ms exceeded. Call log: - waiting for locator('#fullContextBtn') - locator resolved to <button id="fullContextBtn" title="Show full LLM context (system prompt + history)" class="text-xs border border-[var(--border)] px-2 py-1 rounded-md transition-colors cursor-pointer bg-transparent font-[var(--font-body)] inline-flex items-center gap-1 text-[var(--muted)]">…</button> - attempting click action 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 20ms 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 100ms 82 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 500ms 84 | } 85 | > 86 | await toggleBtn.click(); | ^ 87 | await expect(panel).toBeVisible(); 88 | 89 | const result = await expect at openFullContextWithRetry (/home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:86:19) at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:423:19
[default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file: crates/web/ui/e2e/specs/chat-input.spec.js#L0
3) [default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file Test timeout of 45000ms exceeded.
[default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style: crates/web/ui/e2e/specs/chat-input.spec.js#L86
2) [default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Error: locator.click: Test timeout of 45000ms exceeded. Call log: - waiting for locator('#fullContextBtn') - locator resolved to <button id="fullContextBtn" title="Show full LLM context (system prompt + history)" class="text-xs border border-[var(--border)] px-2 py-1 rounded-md transition-colors cursor-pointer bg-transparent font-[var(--font-body)] inline-flex items-center gap-1 text-[var(--muted)]">…</button> - attempting click action 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 20ms 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 100ms 81 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 500ms 84 | } 85 | > 86 | await toggleBtn.click(); | ^ 87 | await expect(panel).toBeVisible(); 88 | 89 | const result = await expect at openFullContextWithRetry (/home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:86:19) at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:360:19
[default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style: crates/web/ui/e2e/specs/chat-input.spec.js#L0
2) [default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Test timeout of 45000ms exceeded.
[default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style: crates/web/ui/e2e/specs/chat-input.spec.js#L86
2) [default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style Error: locator.click: Test timeout of 45000ms exceeded. Call log: - waiting for locator('#fullContextBtn') - locator resolved to <button id="fullContextBtn" title="Show full LLM context (system prompt + history)" class="text-xs border border-[var(--border)] px-2 py-1 rounded-md transition-colors cursor-pointer bg-transparent font-[var(--font-body)] inline-flex items-center gap-1 text-[var(--muted)]">…</button> - attempting click action 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 20ms 2 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 100ms 81 × waiting for element to be visible, enabled and stable - element is not visible - retrying click action - waiting 500ms 84 | } 85 | > 86 | await toggleBtn.click(); | ^ 87 | await expect(panel).toBeVisible(); 88 | 89 | const result = await expect at openFullContextWithRetry (/home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:86:19) at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/chat-input.spec.js:360:19
[default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style: crates/web/ui/e2e/specs/chat-input.spec.js#L0
2) [default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style Test timeout of 45000ms exceeded.
[default] › e2e/specs/agents.spec.js:143:2 › Agents settings page › session header agent selector switches session agent and shows sidebar indicator: crates/web/ui/e2e/specs/agents.spec.js#L153
1) [default] › e2e/specs/agents.spec.js:143:2 › Agents settings page › session header agent selector switches session agent and shows sidebar indicator Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Error: expect(locator).toBeVisible() failed Locator: locator('.backend-card').filter({ hasText: 'Selector Test Agent' }) Expected: visible Timeout: 10000ms Error: element(s) not found Call log: - Expect "toBeVisible" with timeout 10000ms - waiting for locator('.backend-card').filter({ hasText: 'Selector Test Agent' }) 151 | await page.getByPlaceholder("Creative Writer").fill("Selector Test Agent"); 152 | await page.getByRole("button", { name: "Create", exact: true }).click(); > 153 | await expect(page.locator(".backend-card").filter({ hasText: "Selector Test Agent" })).toBeVisible({ | ^ 154 | timeout: 10_000, 155 | }); 156 | at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/agents.spec.js:153:90
[default] › e2e/specs/agents.spec.js:143:2 › Agents settings page › session header agent selector switches session agent and shows sidebar indicator: crates/web/ui/e2e/specs/agents.spec.js#L163
1) [default] › e2e/specs/agents.spec.js:143:2 › Agents settings page › session header agent selector switches session agent and shows sidebar indicator Error: expect(locator).toBeEnabled() failed Locator: locator('select[title="Session agent"]') Expected: enabled Timeout: 10000ms Error: element(s) not found Call log: - Expect "toBeEnabled" with timeout 10000ms - waiting for locator('select[title="Session agent"]') 161 | 162 | const agentSelect = page.locator('select[title="Session agent"]'); > 163 | await expect(agentSelect).toBeEnabled({ timeout: 10_000 }); | ^ 164 | await expect(agentSelect.locator('option[value="selector-test"]')).toBeAttached({ timeout: 10_000 }); 165 | await agentSelect.selectOption("selector-test"); 166 | // The controlled Preact select resets value on re-render; wait for at /home/runner/work/moltis/moltis/crates/web/ui/e2e/specs/agents.spec.js:163:29
Workflow Security
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5. 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/
Biome
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, biomejs/setup-biome@29711cbb52afee00eb13aeb30636592f9edc0088. 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/
Format
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5. 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/
iOS App
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5. 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/
Code Coverage
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea, Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5. 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/
macOS App
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5. 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/
E2E Tests
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020, actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02. 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/
E2E Tests
Unexpected input(s) 'package-manager-cache', valid inputs are ['always-auth', 'node-version', 'node-version-file', 'architecture', 'check-latest', 'registry-url', 'scope', 'token', 'cache', 'cache-dependency-path', 'mirror', 'mirror-token']
Rust CI (clippy + test)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02. 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/
Rust Full Targets (scheduled)
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5, actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02. 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/
🎭 Playwright Run Summary
12 failed [default] › e2e/specs/agents.spec.js:143:2 › Agents settings page › session header agent selector switches session agent and shows sidebar indicator [default] › e2e/specs/chat-input.spec.js:358:2 › Chat input and slash commands › full context copy button uses small button style [default] › e2e/specs/chat-input.spec.js:421:2 › Chat input and slash commands › full context download button produces .jsonl file [default] › e2e/specs/sandboxes.spec.js:112:2 › Sandboxes page – Running Containers › running containers section renders with heading and refresh button [default] › e2e/specs/sandboxes.spec.js:123:2 › Sandboxes page – Running Containers › refresh button triggers container list fetch [default] › e2e/specs/sandboxes.spec.js:193:2 › Sandboxes page – Running Containers › refresh button also fetches disk usage [default] › e2e/specs/sessions.spec.js:236:2 › Session management › main session shows clear action while non-main sessions show delete [default] › e2e/specs/sessions.spec.js:253:2 › Session management › stop action appears for active run and clears after abort [default] › e2e/specs/sessions.spec.js:284:2 › Session management › share button creates cutoff notice and copyable link [default] › e2e/specs/sessions.spec.js:333:2 › Session management › share copy fallback uses styled modal instead of browser prompt [default] › e2e/specs/sessions.spec.js:506:2 › Session management › deleting unmodified fork skips confirmation dialog [default] › e2e/specs/sessions.spec.js:548:2 › Session management › deleting modified fork still shows confirmation dialog 1 flaky [default] › e2e/specs/sandboxes.spec.js:218:2 › Sandboxes page – Running Containers › clean all endpoint responds correctly 6 skipped 22 did not run 180 passed (18.4m)

Artifacts

Produced during runtime
Name Size Digest
cargo-timings-rust-ci-23782406503-1
287 KB
sha256:83c857dc6768fb7116d9edfa3a5ce77724730ab8fd4af25537d280720f1d6f17
cargo-timings-rust-full-targets-23782406503-1
296 KB
sha256:af5da46930b1503cf9b861cd6f757f78f8c6db497d946afaca5720e660e3384e
e2e-test-results-23782406503-1 Expired
215 MB
sha256:c6b41099e1951d542a2be816db0dd0cf2eaa3e0a481835d65a32151a136cda6b
test-results-23782406503-1
66 KB
sha256:9dd7a6e1b3c24bfe2808e0e238eea3dfb5cef6bf08c09ae28f3b70c9c1b06458