Back to branch review

sledtools/pika branch #146

pika-cloud-substrate-polish

Polish pika-cloud Incus substrate

branch: merged target: master
Updated 2026-03-27 14:44:59
Head 91deb743484ee8be833da2c5756dbc1eb5839127
Merge Base 1de303dcc9590022db0aa074bb3dcd74e47063f0

Continuous Integration

CI: success

branch merged · tutorial ready

Use recovery controls only for wedged queues, stale leases, or broken runners.

Run History

Full lane, log, rerun, and recovery detail lives here.

Run #184 success

head 91deb743484ee8be833da2c5756dbc1eb5839127 · queued 2026-03-27 14:38:51 · 5 lane(s)

queued 3m 12s · ran 3m 16s

started 2026-03-27 14:42:03

finished 2026-03-27 14:45:19

Lane #1004 · check-notifications success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-notifications · lane id notifications · retries 0 · queued 2026-03-27 14:38:51

queued 3m 12s · ran 28s

target pre-merge-notifications

last heartbeat 2026-03-27 14:42:31

CI run 20260327T144230Z-fdae9052 · target pre-merge-notifications

started 2026-03-27 14:42:03

finished 2026-03-27 14:42:31

[pikaci] run started: 20260327T144230Z-fdae9052 · pre-merge-notifications · Run the VM-backed Rust tests from the notifications lane
[pikaci] run finished: 20260327T144230Z-fdae9052 · status=skipped · skipped; no changed files matched 27 filter(s)
this derivation will be built:
  /nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1005 · check-agent-contracts success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-agent-contracts · lane id agent_contracts · retries 0 · queued 2026-03-27 14:38:51

queued 3m 12s · ran 28s

target pre-merge-agent-contracts

last heartbeat 2026-03-27 14:42:31

CI run 20260327T144230Z-6b62c600 · target pre-merge-agent-contracts

started 2026-03-27 14:42:03

finished 2026-03-27 14:42:31

[pikaci] run started: 20260327T144230Z-6b62c600 · pre-merge-agent-contracts · Run the Incus-backed pre-merge agent contracts lane
[pikaci] run finished: 20260327T144230Z-6b62c600 · status=skipped · skipped; no changed files matched 32 filter(s)
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/49456a70e3ec0b0f6545157e6144b9b7f4ccee90f65a2001d5df981d55280c0e.sqlite' is busy
this derivation will be built:
  /nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1006 · check-pikachat success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-pikachat-rust · lane id pikachat · retries 0 · queued 2026-03-27 14:38:51

queued 3m 12s · ran 28s

target pre-merge-pikachat-rust

last heartbeat 2026-03-27 14:42:31

CI run 20260327T144230Z-203dabaf · target pre-merge-pikachat-rust

started 2026-03-27 14:42:03

finished 2026-03-27 14:42:31

[pikaci] run started: 20260327T144230Z-203dabaf · pre-merge-pikachat-rust · Run the VM-backed Rust tests from the pikachat lane
[pikaci] run finished: 20260327T144230Z-203dabaf · status=skipped · skipped; no changed files matched 33 filter(s)
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/49456a70e3ec0b0f6545157e6144b9b7f4ccee90f65a2001d5df981d55280c0e.sqlite' is busy
this derivation will be built:
  /nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1007 · check-apple-host-sanity success

nix run .#pikaci -- run apple_host_sanity · lane id apple_host_sanity · retries 0 · queued 2026-03-27 14:38:51

queued 3m 12s · ran 3m 16s

target apple-host

last heartbeat 2026-03-27 14:45:19

started 2026-03-27 14:42:03

finished 2026-03-27 14:45:19

20260327T144228Z-90e3411d apple_host_sanity passed
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/49456a70e3ec0b0f6545157e6144b9b7f4ccee90f65a2001d5df981d55280c0e.sqlite' is busy
this derivation will be built:
  /nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv
building '/nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv'...
host-local command passed
Lane #1008 · check-fixture success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-fixture-rust · lane id fixture · retries 0 · queued 2026-03-27 14:38:51

queued 3m 12s · ran 28s

target pre-merge-fixture-rust

last heartbeat 2026-03-27 14:42:31

CI run 20260327T144230Z-6def0b7a · target pre-merge-fixture-rust

started 2026-03-27 14:42:03

finished 2026-03-27 14:42:31

[pikaci] run started: 20260327T144230Z-6def0b7a · pre-merge-fixture-rust · Run the VM-backed Rust tests from the fixture lane
[pikaci] run finished: 20260327T144230Z-6def0b7a · status=skipped · skipped; no changed files matched 44 filter(s)
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/49456a70e3ec0b0f6545157e6144b9b7f4ccee90f65a2001d5df981d55280c0e.sqlite' is busy
this derivation will be built:
  /nix/store/av5msgrdm1cib3imrqjwn3vsb5qdyd9f-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/q0dfxdz555438srp0f9nqc7qsq74wx2d-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output

Run #182 success

head 6d5f18f6e5856c957e68201004a4bf86a5de9ae4 · queued 2026-03-27 14:19:36 · 5 lane(s)

queued 13s · ran 3m 31s

started 2026-03-27 14:19:49

finished 2026-03-27 14:23:20

Lane #999 · check-notifications success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-notifications · lane id notifications · retries 0 · queued 2026-03-27 14:19:36

queued 13s · ran 30s

target pre-merge-notifications

last heartbeat 2026-03-27 14:20:19

CI run 20260327T142019Z-22b0059c · target pre-merge-notifications

started 2026-03-27 14:19:49

finished 2026-03-27 14:20:19

[pikaci] run started: 20260327T142019Z-22b0059c · pre-merge-notifications · Run the VM-backed Rust tests from the notifications lane
[pikaci] run finished: 20260327T142019Z-22b0059c · status=skipped · skipped; no changed files matched 27 filter(s)
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1000 · check-agent-contracts success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-agent-contracts · lane id agent_contracts · retries 0 · queued 2026-03-27 14:19:36

queued 13s · ran 28s

target pre-merge-agent-contracts

last heartbeat 2026-03-27 14:20:17

CI run 20260327T142017Z-88aea46e · target pre-merge-agent-contracts

started 2026-03-27 14:19:49

finished 2026-03-27 14:20:17

[pikaci] run started: 20260327T142017Z-88aea46e · pre-merge-agent-contracts · Run the Incus-backed pre-merge agent contracts lane
[pikaci] run finished: 20260327T142017Z-88aea46e · status=skipped · skipped; no changed files matched 32 filter(s)
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/8a37549cf4d1f0f77dc933ef603541f7aca2e71210c737efd178aa67d4cb4fbf.sqlite' is busy
this derivation will be built:
  /nix/store/w43dgzxqhqmybs3fj4nl91sslmixa3bl-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1001 · check-pikachat success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-pikachat-rust · lane id pikachat · retries 0 · queued 2026-03-27 14:19:36

queued 13s · ran 25s

target pre-merge-pikachat-rust

last heartbeat 2026-03-27 14:20:14

CI run 20260327T142014Z-ee59ecb5 · target pre-merge-pikachat-rust

started 2026-03-27 14:19:49

finished 2026-03-27 14:20:14

[pikaci] run started: 20260327T142014Z-ee59ecb5 · pre-merge-pikachat-rust · Run the VM-backed Rust tests from the pikachat lane
[pikaci] run finished: 20260327T142014Z-ee59ecb5 · status=skipped · skipped; no changed files matched 33 filter(s)
error (ignored): SQLite database '/var/lib/pika-git/.cache/nix/eval-cache-v6/8a37549cf4d1f0f77dc933ef603541f7aca2e71210c737efd178aa67d4cb4fbf.sqlite' is busy
this derivation will be built:
  /nix/store/w43dgzxqhqmybs3fj4nl91sslmixa3bl-pikaci-0.1.0.drv
building '/nix/store/w43dgzxqhqmybs3fj4nl91sslmixa3bl-pikaci-0.1.0.drv'...
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output
Lane #1002 · check-apple-host-sanity success

./scripts/pikaci-apple-remote.sh run --just-recipe apple-host-sanity · lane id apple_host_sanity · retries 0 · queued 2026-03-27 14:19:36

queued 13s · ran 3m 31s

target apple-host

last heartbeat 2026-03-27 14:23:20

started 2026-03-27 14:19:49

finished 2026-03-27 14:23:20

From /Volumes/pikaci-data/pikaci-apple/runs/apple-run-20260327T141949Z-6d5f18f6e585/source.bundle
 * [new ref]             refs/pikaci-apple/run/apple-run-20260327T141949Z-6d5f18f6e585 -> refs/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4
Preparing worktree (detached HEAD 6d5f18f6e)
building '/nix/store/ksa70zk1frwmd0lgkxswzny9qxi9gs8q-ph-0.1.0.drv'...
building '/nix/store/wy6jij3g3l96ppqxwm1i48gg6ivk4cvm-nix-shell-env.drv'...

Pika dev environment ready
  Rust:         rustc 1.93.0 (254b59607 2026-01-19)
  DATABASE_URL: postgresql:///pika_server?host=/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-server/.pgdata
  Postgres:     run 'cargo run -p pikahut -- up --profile postgres' when needed
  Xcode:        /Applications/Xcode-26.2.0.app/Contents/Developer

   Compiling pika-tls v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-tls)
   Compiling hypernote-protocol v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/hypernote-protocol)
   Compiling pika_core v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/rust)
   Compiling pika-managed-agent-contract v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-managed-agent-contract)
   Compiling pika-relay-profiles v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-relay-profiles)
   Compiling pika-media v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-media)
   Compiling pika-marmot-runtime v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-marmot-runtime)
   Compiling pika-desktop v0.1.0 (/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-desktop)
    Finished `test` profile [unoptimized + debuginfo] target(s) in 2m 09s

Pika dev environment ready
  Rust:         rustc 1.93.0 (254b59607 2026-01-19)
  DATABASE_URL: postgresql:///pika_server?host=/Volumes/pikaci-data/pikaci-apple/prepared/6d5f18f6e5856c957e68201004a4bf86a5de9ae4/worktree/crates/pika-server/.pgdata
  Postgres:     run 'cargo run -p pikahut -- up --profile postgres' when needed
  Xcode:        /Applications/Xcode-26.2.0.app/Contents/Developer


running 8 tests
test app_manager::tests::restoring_session_clears_after_non_login_state ... ok
test app_manager::tests::pending_login_nsec_clears_after_login_error_toast ... ok
test app_manager::tests::stale_full_state_is_dropped ... ok
2026-03-27T14:22:36.121164Z  INFO pika_core: FfiApp::new() starting data_dir=/tmp/nix-shell.MGiyXT/.tmpRF2o7k/desktop-recovery-config keychain_group= app_version=1.1.1
2026-03-27T14:22:36.124149Z  INFO pika_core: FfiApp::new() starting data_dir=/tmp/nix-shell.MGiyXT/.tmpNfoNdc/desktop-recovery-clear keychain_group= app_version=1.1.1
test app_manager::tests::account_created_side_effect_runs_when_stale ... ok
test app_manager::tests::nsec_store_uses_owner_only_permissions ... ok
test app_manager::tests::pending_login_nsec_persists_after_successful_login ... ok
test app_manager::tests::reset_relay_config_to_defaults_writes_default_relays ... ok
test app_manager::tests::clear_local_session_for_recovery_clears_persistence ... ok

test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s


running 12 tests
test screen::home::tests::effective_selected_chat_prefers_optimistic_selection ... ok
test screen::home::tests::effective_selected_chat_falls_back_to_projected_selection ... ok
test utils::tests::truncate_short_unchanged ... ok
test utils::tests::relative_time_recent ... ok
test utils::tests::truncate_long_adds_ellipsis ... ok
test utils::tests::truncated_npub_long_is_compact ... ok
test utils::tests::truncated_npub_long_variant_is_compact ... ok
test utils::tests::truncated_npub_short_unchanged ... ok
test views::conversation::tests::clean_reply_target_clears_submissions_when_chat_disappears ... ok
test views::conversation::tests::hypernote_action_bubbles_up_as_event ... ok
test views::conversation::tests::clean_reply_target_removes_missing_message_submissions ... ok
test views::conversation::tests::clean_reply_target_drops_optimistic_entry_after_authoritative_response ... ok

test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.30s

apple-host-sanity complete
Lane #1003 · check-fixture success

./scripts/pikaci-staged-linux-remote.sh run pre-merge-fixture-rust · lane id fixture · retries 0 · queued 2026-03-27 14:19:36

queued 13s · ran 28s

target pre-merge-fixture-rust

last heartbeat 2026-03-27 14:20:17

CI run 20260327T142017Z-24057281 · target pre-merge-fixture-rust

started 2026-03-27 14:19:49

finished 2026-03-27 14:20:17

[pikaci] run started: 20260327T142017Z-24057281 · pre-merge-fixture-rust · Run the VM-backed Rust tests from the fixture lane
[pikaci] run finished: 20260327T142017Z-24057281 · status=skipped · skipped; no changed files matched 44 filter(s)
this derivation will be built:
  /nix/store/w43dgzxqhqmybs3fj4nl91sslmixa3bl-pikaci-0.1.0.drv
[pikaci-tools] staged-linux-remote: resolution=nix-build package_root=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0
[pikaci-tools] staged-linux-remote: pikaci=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci
[pikaci-tools] staged-linux-remote: helper=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-fulfill-prepared-output
[pikaci-tools] staged-linux-remote: launcher=/nix/store/jz2d4iz2kp03ff7pfx08z0q0s4ab41i6-pikaci-0.1.0/bin/pikaci-launch-fulfill-prepared-output