CI #47
ci.yml
on: schedule
Workflow Security
11s
Changelog Guard
0s
Code Coverage
16m 20s
Matrix: local-validation
Rust CI (clippy + test)
36m 57s
E2E Tests
26m 58s
macOS App
14m 24s
iOS App
1m 56s
Rust Full Targets (scheduled)
23m 33s
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
80 × 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
83 × 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
80 × 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/
|
|
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/
|
|
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/
|
|
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
9 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/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
6 skipped
22 did not run
184 passed (15.3m)
|
Artifacts
Produced during runtime
| Name | Size | Digest | |
|---|---|---|---|
|
cargo-timings-rust-ci-23730180352-1
|
280 KB |
sha256:b8a95ac3fe5fc0ce58a5021c5c0e5fe935813df2c31b2d3522bfdaafaa7cfa54
|
|
|
cargo-timings-rust-full-targets-23730180352-1
|
309 KB |
sha256:e0818a9c94df58714716e85ba1fa18ec5024a34f276f37e7c0c31079bb80f4ae
|
|
|
e2e-test-results-23730180352-1
Expired
|
137 MB |
sha256:7cf43adab256df6dfb3a7e1134861731f79c44579de5e60567c91074a4843ead
|
|
|
test-results-23730180352-1
|
65.9 KB |
sha256:a4adfb758d27223e8d4e19c932e277edb67b4d998ec66c2789cf4d3241c2d74f
|
|