WI: Build QA runner CLI for CI integration #182
Closed
opened 2026-05-24 05:11:17 +00:00 by toasterson
·
0 comments
No Branch/Tag specified
main
claude/wi-019dd344-push-diff-re-dispatch-d1-019db1b9-c06f-a
claude/wi-019dda52-pre-dispatch-decision-completeness-check
claude/wi-019ddfe9-audit-cleanup-orphaned-wis-without-plans
claude/wi-019ded3d-backend-extend-listprojectsresponse-with
claude/wi-019dff17-anima-agent-invalidate-stale-wip-snapsho
claude/wi-019dff20-promote-loop-push-diff-race-gate-promote
claude/wi-019e93df-mcp-ambient-get-work-item-detail-full-wi
claude/wi-019e0d32-replace-dockerfile-cargo-build-with-sols
claude/wi-019dd4db-mcp-expose-teamservice-issuepat-as-an-ad
claude/wi-019dd4db-mcp-add-ambient-post-message-variant-wor
claude/wi-019ddfd9-mcp-tool-time-bounded-out-of-hours-sessi
claude/wi-019ddfed-bug-ai-sessions-accumulate-as-pending-in
claude/wi-019de021-bug-team-view-has-no-ui-to-promote-demot
claude/wi-019de052-bug-open-prs-placeholder-pr-s-change-row
claude/wi-019dff16-anima-agent-raise-agent-max-concurrent-t
claude/wi-019dff20-wi-lifecycle-validate-phase-strings-serv
claude/wi-019e0d25-dockerfile-add-cache-mounts-for-cargo-re
claude/wi-019e0d25-dockerfile-add-apt-cache-mount-to-builde
claude/wi-019e57a6-p0-5-render-diff-harness-extend-snapshot
claude/wi-019e8873-native-solstice-ci-dispatch-send-explici
claude/wi-019e8f7d-merge-engine-commits-unresolved-conflict
claude/wi-019e8f7e-needs-rebase-re-dispatch-is-dead-on-arri
claude/wi-019e8f7e-post-merge-gap-analysis-runs-with-empty
claude/wi-019e8f7e-anima-agent-restore-daily-spawn-cap-on-c
claude/wi-019e505a-akh-medu-assert-batch-is-non-functional
claude/wi-019e533a-research-deployments-system-architecture
claude/wi-019e57a6-p2-screen-inference-all-5-pages-shared-c
claude/wi-019e57a6-p1-hybrid-refinement-loop-converge-to-2
claude/wi-019e590b-build-qa-runner-cli-for-ci-integration
claude/wi-019e796e-detect-anthropic-max-tokens-truncation-m
claude/wi-019e89ec-solstice-git-fetch-auth-parked-only-need
claude/wi-019e533b-phase-2-helm-provider-for-k8s-self-deplo
claude/wi-019e533b-phase-3-docker-compose-macos-native-prov
claude/wi-019e533b-phase-4-deployment-history-audit-trail-c
claude/wi-019e534c-add-create-project-mcp-tool-to-anima
claude/wi-019e57a6-p4-production-hardening-regression-safet
claude/wi-019e590b-create-anima-qa-crate-in-anima-workspace
claude/wi-019e590b-build-wayland-dev-vm-base-image-debian-b
claude/wi-019e590b-implement-yaml-test-spec-parser-and-exec
claude/wi-019e590b-integrate-qa-system-with-solstice-ci-and
claude/wi-019e590b-neocde-shell-startup-smoke-test-suite
claude/wi-019e796e-spawn-companion-startrun-dispatch-as-det
claude/wi-019e6070-add-mcp-tool-for-createproject-enable-gr
claude/wi-019e590b-wayray-compositor-smoke-test-suite
claude/wi-019e796e-make-review-wi-creation-failure-fatal-to
claude/wi-019e79d9-auto-run-gap-analysis-as-a-post-merge-pi
claude/wi-019e590b-anima-desktop-ui-smoke-test-suite
claude/wi-019e846d-catch-unwired-dead-code-pub-in-pub-mod-h
claude/wi-019e846d-in-server-merge-engine-hardening-anima-g
claude/wi-019e89ec-native-solstice-dispatch-inject-git-cred
claude/wi-019e57a6-p0-3-build-deterministic-css-to-slint-te
claude/wi-019e796d-implement-schedule-gate-working-hours-ev
claude/wi-019e590b-implement-visual-testing-primitives-scre
claude/wi-019db1bb-doc-system-a1-workspace-provisioner-proj
claude/wi-019db1bb-doc-system-a4-to-graph-queue-api-rest-mc
claude/wi-019dc9e9-anima-agent-re-adopt-orphan-orch-contain
claude/wi-019d9caa-dashboard-add-progress-indicators-to-act
claude/wi-019d9cab-work-item-add-sender-avatar-uniform-time
claude/wi-019db1bc-doc-system-a7-kg-explorer-sessions-tab-i
claude/wi-019db1bc-doc-system-i3-admin-ui-model-registry-ro
claude/wi-019dc57c-p1-5-seshat-ingest-hook-transcripts-libr
claude/wi-019d9caa-dashboard-add-recent-activity-right-side
claude/wi-019d9caa-projects-switch-from-vertical-list-to-3
claude/wi-019d9caa-projects-show-last-updated-x-ago-per-car
claude/wi-019d9cab-project-detail-add-right-sidebar-decisio
claude/wi-019d9cab-project-detail-extend-breadcrumb-to-incl
claude/wi-019d9cab-work-item-add-meta-row-assigned-to-risk
claude/wi-019d9cab-work-item-replace-send-with-split-button
claude/wi-019d9cab-cross-cutting-align-sidebar-brand-label
claude/wi-019d9cab-design-gap-5-slint-scenarios-have-no-pen
claude/wi-019dabaa-sign-agent-authored-commits-with-a-gpg-k
claude/wi-019db1bb-doc-system-a6-retrieval-scope-cross-work
claude/wi-019dc0e8-companionrow-scope-deserialize-surface-e
claude/wi-019dc0e8-companionrepo-set-next-fire-document-or
claude/wi-019dc57c-p2-host-diagnostics-heartbeat-ps-snapsho
claude/wi-019dcaad-list-work-items-returns-inconsistent-cou
claude/wi-019db055-binary-non-markdown-asset-support-in-doc
claude/wi-019dc0e8-remove-or-fix-stale-projectrepo-set-git
claude/wi-019dc0e8-backfill-unit-tests-for-projectremoterep
claude/wi-019dc0e8-git-remote-url-normalization-ssh-vs-git
claude/wi-019dc0e8-companionrepo-validate-cron-expr-on-crea
claude/wi-019e57a6-p3-ci-integration-design-to-slint-pipeli
research/deployments-system
hotfix/migration-version-bump
claude/wi-019dff17-merge-loop-investigate-outcome-error-on
claude/wi-019ddfac-emit-otlp-traces-from-seshat-seshd-to-te
claude/wi-019dc57a-plan-container-diagnostics-sessions-feat
claude/wi-019dca69-gemini-2-5-pro-code-review-via-openroute
claude/wi-019dd0b7-wipsnapshot-retention-per-wi-cap-age-pru
claude/wi-019dbb8e-auth-for-akh-medu-seshat-envoy-gateway-s
claude/wi-019dbb9c-agent-annotation-pathway-broken-pat-lack
claude/wi-019db055-document-ingest-api-seshat-backed
claude/wi-019db1bb-doc-system-a2-anima-branded-knowledge-mc
claude/wi-019db1bb-doc-system-a3-session-transcript-write-p
claude/wi-019d9caa-project-detail-add-phased-structure-insi
claude/wi-019db20e-anima-agent-listener-add-auth-tls-before
claude/wi-019db01f-desktop-ui-companions-settings-page-dash
claude/wi-019dac79-drop-agent-diff-column-setagentdiff-rpc
claude/wi-019db01f-mcp-tools-list-create-update-toggle-comp
claude/wi-019db1ba-doc-system-d5-anima-import-cli-bulk-mark
claude/wi-019db1ba-doc-system-d4-cross-project-dependencies
claude/wi-019db1ba-doc-system-d6-slint-library-viewer-basic
claude/wi-0-merge-commit-sha-null-fix
claude/wi-019dff17-merge-loop-error-taxonomy
claude/wi-019d9cab-project-detail-fix-empty-vertical-space
claude/wi-019db1bc-doc-system-i0-anima-inference-crate-open
claude/wi-019db1bc-doc-system-i2-tool-plumbing-across-provi
claude/wi-019db1bc-doc-system-i1-anthropic-direct-ollama-ad
claude/wi-019db030-plan-management-mcp-tools-list-get-creat
claude/wi-019db031-project-management-mcp-tools-create-upda
claude/wi-019dfe46-pipeline-stall-agent-dispatcher-offline
integration/wi-019df3aa-df3ab
claude/wi-019df3ab-anima-triage-wip-prefix
claude/wi-019df3aa-ai-module-diff-ready-gate
claude/wi-019dedb2-open-prs-marker-idempotency
claude/wi-019dedd5-triage-plan-idempotency
claude/wi-019daba7-cluster-deploy-anima-agent-retire-archib
claude/wi-019ded22-anima-native-dispatch-bundle
claude/wi-019de043-amqp-result-binding
claude/wi-019dc402-hide-wip-snapshot-changes
claude/wi-019ded24-ui-filter-empty-projects
claude/wi-019ded23-snapshot-loop-rate-limit
claude/wi-019ded23-akh-medu-ssh-push-remote
claude/wi-019ded24-restore-ci-docker-job
claude/wi-019ddaa2-ci-workflow-s-docker-job-omits-anima-tri
claude/wi-019de043-disable-forgejo-actions-ci
claude/wi-019ddfe2-open-prs-idempotent-marker-commit
claude/wi-019db1b9-c06f-d1-seshat-mcp-client-v2
claude/wi-019dda29-add-pr-ready-phase
claude/wi-019db1b9-doc-system-d2-createdocument-updatedocum
claude/wi-019db1b9-doc-system-d1-seshat-mcp-client-in-anima
claude/wi-019db054-phase-24-sensory-grounding
claude/wi-019db054-phase-23-affective-system
claude/wi-019db054-phase-22-akhipedia
claude/wi-019db054-phase-35-t5-training-infrastructure
claude/wi-019db054-phase-34-communicative-intelligence
claude/wi-019db054-phase-33-grounded-verbalization
claude/wi-019db054-phase-29-capability-exposure
claude/wi-019db054-phase-27-live-kg-llm-training
claude/wi-019db054-phase-26-llm-vsa-deep-integration
claude/wi-019db054-phase-21-game-theoretic-social-reasoning
claude/wi-019db054-phase-20-active-inference
claude/wi-019db054-phase-19-epistemic-logic-theory-of-mind
claude/wi-019db01d-companion-schema-domain-repos-companions
claude/wi-019daf97-projects-support-multiple-remotes-per-pr
claude/priceless-turing-45892e
No results found.
Labels
Clear labels
Compat/Breaking
Breaking change that won't be backward compatible
Kind/Bug
Something is not working
Kind/Documentation
Documentation changes
Kind/Enhancement
Improve existing functionality
Kind/Feature
New functionality
Kind/Security
This is security issue
Kind/Testing
Issue or pull request related to testing
Priority
Critical
The priority is critical
Priority
High
The priority is high
Priority
Low
The priority is low
Priority
Medium
The priority is medium
Reviewed
Confirmed
Issue has been confirmed
Reviewed
Duplicate
This issue or pull request already exists
Reviewed
Invalid
Invalid issue
Reviewed
Won't Fix
This issue won't be fixed
Status
Abandoned
Somebody has started to work on this but abandoned work
Status
Blocked
Something is blocking this issue or pull request
Status
Need More Info
Feedback is required to reproduce issue or to continue work
No labels
Compat/Breaking
Kind/Bug
Kind/Documentation
Kind/Enhancement
Kind/Feature
Kind/Security
Kind/Testing
Priority
Critical
Priority
High
Priority
Low
Priority
Medium
Reviewed
Confirmed
Reviewed
Duplicate
Reviewed
Invalid
Reviewed
Won't Fix
Status
Abandoned
Status
Blocked
Status
Need More Info
Milestone
Clear milestone
No items
No milestone
Projects
Clear projects
No items
No project
Assignees
Clear assignees
No assignees
1 participant
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".
No due date set.
Dependencies
No dependencies set.
Reference
toasterson/Anima#182
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Goal
Create a
cargo run -p anima-qa -- runnersubcommand that reads YAML test specs and drives the QA MCP server programmatically.Background
The MCP server handles VM lifecycle and individual actions. The runner CLI wraps this for CI: parse a test spec file, call the MCP sequentially, collect results, emit pass/fail. This is the CI-facing interface.
🔗 Remote Sources (all on code.aopc.cloud)
Anima workspace:
QA test specs: Ask Tecton for
memory/projects/anima-qa.md— full YAML schema definition🏗️ Implementation Guide
Step 1: Add subcommand structure
Extend main.rs with a
runnersubcommand using clap:--mcp-url(default: http://localhost:8090)--test(path to .qa.yaml file)--vm-image(default: debian-bookworm-wayland-dev:latest)--output(default: qa-results/)Step 2: Test spec parser
Parse
.qa.yamlfiles into typed structs: TestSuite with name, wi_ref, project, image, timeout_seconds, setup[], steps[], assertions[]. Use serde_yaml (add to Cargo.toml if not in workspace).Step 3: MCP client
HTTP client that POSTs JSON-RPC 2.0 requests to the MCP server. Map test step types to MCP tool calls:
Decode base64 screenshots → save to output directory.
Step 4: Execution flow
Parse → qa_start → setup commands → test steps → assertions → qa_stop (always) → write results.json
✅ Acceptance Criteria
Related WIs