Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Full Release Validation è il contenitore di rilascio. È l’unico punto di
ingresso manuale per la prova pre-rilascio, ma la maggior parte del lavoro
avviene nei flussi di lavoro figlio, così un ambiente non riuscito può essere
rieseguito senza riavviare l’intero rilascio.
Eseguilo da un riferimento di workflow attendibile, normalmente main, e passa
il branch di rilascio, il tag o lo SHA completo del commit come ref:
ref per il candidato in test. Questo mantiene disponibile
la nuova logica di validazione quando si valida un branch o tag di rilascio meno
recente.
Per impostazione predefinita, release_profile=stable esegue le corsie
bloccanti per il rilascio e salta il soak live/Docker esaustivo. Passa
run_release_soak=true per includere le corsie di soak in un’esecuzione stable.
release_profile=full abilita sempre le corsie di soak, così il profilo
consultivo ampio non perde copertura in modo silenzioso.
Package Acceptance normalmente crea il tarball candidato dal ref risolto,
incluse le esecuzioni con SHA completo avviate con pnpm ci:full-release. Dopo
la pubblicazione, passa package_acceptance_package_spec=openclaw@YYYY.M.D
(oppure openclaw@beta/openclaw@latest) per eseguire invece la stessa matrice
di package/aggiornamento contro il package npm rilasciato.
Fasi di primo livello
| Fase | Dettagli |
|---|---|
| Risoluzione target | Job: Resolve target refFlusso di lavoro figlio: nessuno Prova: risolve il branch di rilascio, il tag o lo SHA completo del commit e registra gli input selezionati. Riesecuzione: riesegui il contenitore se questa fase non riesce. |
| Vitest e CI normale | Job: Run normal full CIFlusso di lavoro figlio: CIProva: grafo CI completo manuale contro il ref target, incluse le corsie Linux Node, gli shard dei Plugin in bundle, i contratti dei canali, la compatibilità Node 22, check, check-additional, smoke build, controlli docs, Skills Python, Windows, macOS, i18n della Control UI e Android tramite il contenitore.Riesecuzione: rerun_group=ci. |
| Prerelease Plugin | Job: Run plugin prerelease validationFlusso di lavoro figlio: Plugin PrereleaseProva: controlli statici solo di rilascio per Plugin, copertura agentica dei Plugin, shard batch completi delle estensioni e corsie Docker di prerelease dei Plugin. Riesecuzione: rerun_group=plugin-prerelease. |
| Controlli rilascio | Job: Run release/live/Docker/QA validationFlusso di lavoro figlio: OpenClaw Release ChecksProva: smoke install, controlli package cross-OS, Package Acceptance, parità QA Lab, Matrix live e Telegram live. Con run_release_soak=true o release_profile=full, esegue anche suite live/E2E esaustive e blocchi del percorso di rilascio Docker.Riesecuzione: rerun_group=release-checks o un handle release-checks più ristretto. |
| Artefatto package | Job: Prepare release package artifactFlusso di lavoro figlio: nessuno Prova: crea il tarball padre release-package-under-test abbastanza presto per i controlli rivolti ai package che non devono attendere OpenClaw Release Checks.Riesecuzione: riesegui il contenitore o fornisci npm_telegram_package_spec per rerun_group=npm-telegram. |
| Package Telegram | Job: Run package Telegram E2EFlusso di lavoro figlio: NPM Telegram Beta E2EProva: prova del package Telegram basata sull’artefatto padre per rerun_group=all con release_profile=full, oppure prova Telegram del package pubblicato quando npm_telegram_package_spec è impostato.Riesecuzione: rerun_group=npm-telegram con npm_telegram_package_spec. |
| Verificatore ombrello | Job: Verify full validationFlusso di lavoro figlio: nessuno Prova: ricontrolla le conclusioni registrate delle esecuzioni figlio e aggiunge tabelle dei job più lenti dai flussi di lavoro figlio. Riesecuzione: riesegui solo questo job dopo aver rieseguito un figlio non riuscito fino a renderlo verde. |
ref=main e rerun_group=all, un contenitore più recente sostituisce uno
meno recente. Quando il padre viene annullato, il suo monitor annulla qualsiasi
flusso di lavoro figlio che ha già avviato. Le esecuzioni di validazione di
branch e tag di rilascio non si annullano tra loro per impostazione predefinita.
Fasi dei controlli di rilascio
OpenClaw Release Checks è il flusso di lavoro figlio più grande. Risolve il
target una sola volta e prepara un artefatto condiviso release-package-under-test
quando le fasi rivolte a package o Docker ne hanno bisogno.
| Fase | Dettagli |
|---|---|
| Target di rilascio | Job: Resolve target refWorkflow di supporto: nessuno Test: ref selezionato, SHA previsto opzionale, profilo, gruppo di riesecuzione e filtro focalizzato della suite live. Riesecuzione: rerun_group=release-checks. |
| Artefatto pacchetto | Job: Prepare release package artifactWorkflow di supporto: nessuno Test: crea pacchetti o risolve un tarball candidato e carica release-package-under-test per i controlli downstream rivolti al pacchetto.Riesecuzione: il gruppo pacchetto, cross-OS o live/E2E interessato. |
| Smoke di installazione | Job: Run install smokeWorkflow di supporto: Install SmokeTest: percorso di installazione completo con riuso dell’immagine smoke Dockerfile root, installazione del pacchetto QR, smoke Docker root e Gateway, test Docker dell’installer, smoke del provider di immagini con installazione globale Bun, ed E2E rapido di installazione/disinstallazione dei Plugin inclusi. Riesecuzione: rerun_group=install-smoke. |
| Cross-OS | Job: cross_os_release_checksWorkflow di supporto: OpenClaw Cross-OS Release Checks (Reusable)Test: corsie fresh e upgrade su Linux, Windows e macOS per il provider e la modalità selezionati, usando il tarball candidato più un pacchetto baseline. Riesecuzione: rerun_group=cross-os. |
| Repo ed E2E live | Job: Run repo/live E2E validationWorkflow di supporto: OpenClaw Live And E2E Checks (Reusable)Test: E2E del repository, cache live, streaming websocket OpenAI, shard del provider live nativo e dei Plugin, e harness di modello/backend/Gateway live basati su Docker selezionati da release_profile.Esecuzioni: run_release_soak=true, release_profile=full o rerun_group=live-e2e focalizzato.Riesecuzione: rerun_group=live-e2e, facoltativamente con live_suite_filter. |
| Percorso di rilascio Docker | Job: Run Docker release-path validationWorkflow di supporto: OpenClaw Live And E2E Checks (Reusable)Test: blocchi Docker del percorso di rilascio contro l’artefatto pacchetto condiviso. Esecuzioni: run_release_soak=true, release_profile=full o rerun_group=live-e2e focalizzato.Riesecuzione: rerun_group=live-e2e. |
| Accettazione pacchetto | Job: Run package acceptanceWorkflow di supporto: Package AcceptanceTest: fixture offline dei pacchetti Plugin, aggiornamento Plugin, accettazione pacchetto Telegram con mock OpenAI, e controlli di sopravvivenza all’upgrade pubblicato contro lo stesso tarball. I controlli di rilascio bloccanti usano la baseline pubblicata più recente predefinita; i controlli soak si espandono a ogni rilascio npm stabile a partire da 2026.4.23 più le fixture dei problemi segnalati.Riesecuzione: rerun_group=package. |
| Parità QA | Job: Run QA Lab parity lane e Run QA Lab parity reportWorkflow di supporto: job diretti Test: pacchetti di parità agentica candidato e baseline, poi il report di parità. Riesecuzione: rerun_group=qa-parity o rerun_group=qa. |
| Matrix QA live | Job: Run QA Lab live Matrix laneWorkflow di supporto: job diretto Test: profilo QA Matrix live rapido nell’ambiente qa-live-shared.Riesecuzione: rerun_group=qa-live o rerun_group=qa. |
| Telegram QA live | Job: Run QA Lab live Telegram laneWorkflow di supporto: job diretto Test: QA Telegram live con lease delle credenziali Convex CI. Riesecuzione: rerun_group=qa-live o rerun_group=qa. |
| Verificatore rilascio | Job: Verify release checksWorkflow di supporto: nessuno Test: job di controllo del rilascio richiesti per il gruppo di riesecuzione selezionato. Riesecuzione: riesegui dopo che i job figli focalizzati sono passati. |
Blocchi del percorso di rilascio Docker
La fase del percorso di rilascio Docker esegue questi blocchi quandolive_suite_filter è
vuoto:
| Blocco | Copertura |
|---|---|
core | Corsie smoke del percorso di rilascio Docker core. |
package-update-openai | Comportamento di installazione/aggiornamento del pacchetto OpenAI, inclusa l’installazione on-demand di Codex. |
package-update-anthropic | Comportamento di installazione e aggiornamento del pacchetto Anthropic. |
package-update-core | Comportamento di pacchetto e aggiornamento neutrale rispetto al provider. |
plugins-runtime-plugins | Corsie runtime dei Plugin che esercitano il comportamento dei Plugin. |
plugins-runtime-services | Corsie runtime dei Plugin live e supportate da servizi; include OpenWebUI quando richiesto. |
plugins-runtime-install-a through plugins-runtime-install-h | Batch di installazione/runtime dei Plugin suddivisi per la convalida parallela del rilascio. |
docker_lanes=<lane[,lane]> mirato nel workflow live/E2E riutilizzabile quando
è fallita una sola corsia Docker. Gli artefatti di rilascio includono comandi di riesecuzione
per corsia con artefatto pacchetto e input di riuso immagine quando disponibili.
Profili di rilascio
release_profile controlla principalmente l’ampiezza live/provider all’interno dei controlli di rilascio.
Non rimuove la normale CI completa, Plugin Prerelease, smoke di installazione, accettazione
pacchetto o QA Lab. Per stable, E2E repo/live esaustivo e blocchi del
percorso di rilascio Docker sono copertura soak e vengono eseguiti quando run_release_soak=true.
full forza l’attivazione della copertura soak e fa anche sì che l’esecuzione ombrello esegua l’E2E Telegram del pacchetto
contro l’artefatto pacchetto di rilascio padre quando rerun_group=all, così un candidato
pre-pubblicazione completo non salta silenziosamente quella corsia pacchetto Telegram.
| Profilo | Uso previsto | Copertura live/provider inclusa |
|---|---|---|
minimum | Smoke più rapido critico per il rilascio. | Percorso live OpenAI/core, modelli live Docker per OpenAI, core Gateway nativo, profilo Gateway OpenAI nativo, Plugin OpenAI nativo e Gateway OpenAI live Docker. |
stable | Profilo predefinito di approvazione del rilascio. | minimum più smoke Anthropic, Google, MiniMax, backend, harness di test live nativo, backend CLI live Docker, bind ACP Docker, harness Codex Docker e uno shard smoke OpenCode Go. |
full | Ampia scansione consultiva. | stable più provider consultivi, shard live dei Plugin e shard live media. |
Aggiunte solo full
Queste suite vengono saltate dastable e incluse da full:
| Area | Copertura solo full |
|---|---|
| Modelli live Docker | OpenCode Go, OpenRouter, xAI, Z.ai e Fireworks. |
| Gateway live Docker | Provider consultivi suddivisi in shard DeepSeek/Fireworks, OpenCode Go/OpenRouter e xAI/Z.ai. |
| Profili provider Gateway nativo | Shard Anthropic Opus e Sonnet/Haiku completi, Fireworks, DeepSeek, shard completi dei modelli OpenCode Go, OpenRouter, xAI e Z.ai. |
| Shard live dei Plugin nativi | Plugin A-K, L-N, O-Z altri, Moonshot e xAI. |
| Shard live media nativi | Gruppi audio, musica Google, musica MiniMax e video A-D. |
stable include native-live-src-gateway-profiles-anthropic-smoke e
native-live-src-gateway-profiles-opencode-go-smoke; full usa invece gli shard di modelli
Anthropic e OpenCode Go più ampi. Le riesecuzioni focalizzate possono comunque usare gli handle
aggregati native-live-src-gateway-profiles-anthropic o
native-live-src-gateway-profiles-opencode-go.
Riesecuzioni focalizzate
Usarerun_group per evitare di ripetere box di rilascio non correlati:
| Handle | Ambito |
|---|---|
all | Tutte le fasi di convalida completa della release. |
ci | Solo figlio CI completo manuale. |
plugin-prerelease | Solo figlio pre-release Plugin. |
release-checks | Tutte le fasi dei controlli di release OpenClaw. |
install-smoke | Smoke di installazione tramite i controlli di release. |
cross-os | Controlli di release cross-OS. |
live-e2e | Convalida E2E repo/live e del percorso di release Docker. |
package | Accettazione del pacchetto. |
qa | Parità QA più corsie QA live. |
qa-parity | Solo corsie e report di parità QA. |
qa-live | Solo QA live Matrix e Telegram. |
npm-telegram | E2E Telegram del pacchetto pubblicato; richiede npm_telegram_package_spec. |
live_suite_filter con rerun_group=live-e2e quando una suite live non è riuscita.
Gli ID filtro validi sono definiti nel workflow live/E2E riutilizzabile, inclusi
docker-live-models, live-gateway-docker,
live-gateway-anthropic-docker, live-gateway-google-docker,
live-gateway-minimax-docker, live-gateway-advisory-docker,
live-cli-backend-docker, live-acp-bind-docker e
live-codex-harness-docker.
L’handle live-gateway-advisory-docker è un handle di riesecuzione aggregato per i suoi
tre shard di provider, quindi si espande comunque a tutti i job Gateway Docker consultivi.
Usa cross_os_suite_filter con rerun_group=cross-os quando una corsia cross-OS
non è riuscita. Il filtro accetta un ID OS, un ID suite o una coppia OS/suite, per
esempio windows/packaged-upgrade, windows o packaged-fresh. I riepiloghi cross-OS
includono i tempi per fase per le corsie di upgrade pacchettizzato, e i comandi a lunga
esecuzione stampano righe di Heartbeat così un aggiornamento Windows bloccato è visibile prima del
timeout del job.
Le corsie QA dei controlli di release sono consultive. Un errore solo QA viene segnalato come avviso
e non blocca il verificatore dei controlli di release; riesegui rerun_group=qa,
qa-parity o qa-live quando ti servono prove QA aggiornate.
Prove da conservare
Conserva il riepilogoFull Release Validation come indice a livello di release. Collega
gli ID delle esecuzioni figlie e include tabelle dei job più lenti. Per gli errori, ispeziona prima il
workflow figlio, poi riesegui l’handle corrispondente più piccolo tra quelli sopra.
Artefatti utili:
release-package-under-testdal padre Full Release Validation eOpenClaw Release Checks- Artefatti del percorso di release Docker in
.artifacts/docker-tests/ package-under-testdi Accettazione del pacchetto e artefatti di accettazione Docker- Artefatti dei controlli di release cross-OS per ciascun OS e suite
- Artefatti di parità QA, Matrix e Telegram
File di workflow
.github/workflows/full-release-validation.yml.github/workflows/openclaw-release-checks.yml.github/workflows/openclaw-live-and-e2e-checks-reusable.yml.github/workflows/plugin-prerelease.yml.github/workflows/install-smoke.yml.github/workflows/openclaw-cross-os-release-checks-reusable.yml.github/workflows/package-acceptance.yml