OpenClaw tem três faixas de lançamento públicas: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.
- stable: lançamentos marcados com tag que publicam no npm
betapor padrão, ou no npmlatestquando solicitado explicitamente - beta: tags de pré-lançamento que publicam no npm
beta - dev: a ponta móvel de
main
Nomenclatura de versões
- Versão de lançamento estável:
YYYY.M.D- Tag Git:
vYYYY.M.D
- Tag Git:
- Versão de lançamento de correção estável:
YYYY.M.D-N- Tag Git:
vYYYY.M.D-N
- Tag Git:
- Versão de pré-lançamento beta:
YYYY.M.D-beta.N- Tag Git:
vYYYY.M.D-beta.N
- Tag Git:
- Não preencha mês ou dia com zero à esquerda
latestsignifica o lançamento npm estável promovido atualbetasignifica o alvo atual de instalação beta- Lançamentos estáveis e de correção estável publicam no npm
betapor padrão; operadores de lançamento podem direcionar explicitamente paralatestou promover uma build beta validada posteriormente - Todo lançamento estável do OpenClaw entrega o pacote npm e o app macOS juntos; lançamentos beta normalmente validam e publicam primeiro o caminho npm/pacote, com build/assinatura/notarização do app Mac reservados para stable, salvo solicitação explícita
Cadência de lançamentos
- Os lançamentos seguem beta primeiro
- Stable vem somente depois que o beta mais recente é validado
- Mantenedores normalmente cortam lançamentos a partir de uma branch
release/YYYY.M.Dcriada a partir domainatual, para que a validação e as correções do lançamento não bloqueiem novo desenvolvimento emmain - Se uma tag beta foi enviada ou publicada e precisa de uma correção, mantenedores cortam
a próxima tag
-beta.Nem vez de excluir ou recriar a tag beta antiga - Procedimento detalhado de lançamento, aprovações, credenciais e notas de recuperação são restritos a mantenedores
Checklist do operador de lançamento
Este checklist é o formato público do fluxo de lançamento. Credenciais privadas, assinatura, notarização, recuperação de dist-tag e detalhes de rollback emergencial ficam no runbook de lançamento restrito a mantenedores.- Comece do
mainatual: puxe a versão mais recente, confirme que o commit-alvo foi enviado e confirme que a CI atual demainestá verde o suficiente para criar uma branch a partir dele. - Reescreva a seção superior de
CHANGELOG.mda partir do histórico real de commits com/changelog, mantenha as entradas voltadas ao usuário, faça commit, envie e faça rebase/pull mais uma vez antes de criar a branch. - Revise os registros de compatibilidade de lançamento em
src/plugins/compat/registry.tsesrc/commands/doctor/shared/deprecation-compat.ts. Remova compatibilidade expirada somente quando o caminho de upgrade continuar coberto, ou registre por que ela está sendo mantida intencionalmente. - Crie
release/YYYY.M.Da partir domainatual; não faça trabalho normal de lançamento diretamente emmain. - Atualize todas as localizações de versão exigidas para a tag pretendida e então execute
pnpm release:prep. Ele atualiza versões de plugins, inventário de plugins, esquema de configuração, metadados de configuração de canais empacotados, baseline de docs de configuração, exports do SDK de Plugin e baseline de API do SDK de Plugin na ordem correta. Faça commit de qualquer divergência gerada antes de criar a tag. Em seguida, execute o preflight determinístico local:pnpm check:test-types,pnpm check:architecture,pnpm build && pnpm ui:buildepnpm release:check. - Execute
OpenClaw NPM Releasecompreflight_only=true. Antes de existir uma tag, um SHA completo de 40 caracteres da branch de lançamento é permitido para preflight apenas de validação. Salve opreflight_run_idbem-sucedido. - Inicie todos os testes de pré-lançamento com
Full Release Validationpara a branch de lançamento, tag ou SHA completo do commit. Este é o único ponto de entrada manual para as quatro grandes caixas de teste de lançamento: Vitest, Docker, QA Lab e Package. - Se a validação falhar, corrija na branch de lançamento e reexecute o menor arquivo, faixa, job de workflow, perfil de pacote, provedor ou allowlist de modelo com falha que comprove a correção. Reexecute o guarda-chuva completo somente quando a superfície alterada tornar evidências anteriores obsoletas.
- Para beta, marque
vYYYY.M.D-beta.Ne então executeOpenClaw Release Publisha partir da branchrelease/YYYY.M.Dcorrespondente. Ele verificapnpm plugins:sync:check, despacha todos os pacotes de plugins publicáveis para o npm e o mesmo conjunto para o ClawHub em paralelo, e então promove o artefato de preflight npm do OpenClaw preparado com a dist-tag correspondente assim que a publicação npm dos plugins for bem-sucedida. Depois que o processo filho de publicação npm do OpenClaw for bem-sucedido, ele cria ou atualiza a página de lançamento/pré-lançamento correspondente do GitHub a partir da seção completa correspondente deCHANGELOG.md. Lançamentos estáveis publicados no npmlatestse tornam o lançamento mais recente do GitHub; lançamentos estáveis de manutenção mantidos no npmbetasão criados com GitHublatest=false. A publicação no ClawHub ainda pode estar em execução enquanto o OpenClaw publica no npm, mas o workflow de publicação de lançamento imprime os IDs de execução filhos imediatamente. Por padrão, ele não espera pelo ClawHub após despachá-lo, então a disponibilidade do OpenClaw no npm não é bloqueada por aprovações ou trabalho de registro mais lentos do ClawHub; definawait_for_clawhub=truequando o ClawHub precisar bloquear a conclusão do workflow. O caminho do ClawHub tenta novamente falhas transitórias de instalação de dependências da CLI, publica plugins aprovados no preview mesmo quando uma célula de preview falha de forma intermitente, e termina com verificação de registro para cada versão de plugin esperada, para que publicações parciais permaneçam visíveis e possam ser tentadas novamente. Após publicar, executepnpm release:verify-beta -- YYYY.M.D-beta.N --openclaw-npm-run <run-id> --plugin-npm-run <run-id> --plugin-clawhub-run <run-id>para verificar, com um único comando, o pré-lançamento do GitHub, as dist-tags npmbeta, a integridade npm, o caminho de instalação publicado, versões exatas no ClawHub, artefatos do ClawHub e conclusões de workflows filhos. Adicione--rerun-failed-clawhubquando o sidecar do ClawHub tiver falhado somente em jobs repetíveis e deva ser reexecutado no lugar. Em seguida, execute a aceitação de pacote pós-publicação contra o pacote publicadoopenclaw@YYYY.M.D-beta.Nouopenclaw@beta. Se um pré-lançamento enviado ou publicado precisar de correção, corte o próximo número de pré-lançamento correspondente; não exclua nem reescreva o pré-lançamento antigo. - Para stable, continue somente depois que o beta validado ou candidato a lançamento tiver a
evidência de validação exigida. A publicação npm estável também passa por
OpenClaw Release Publish, reutilizando o artefato de preflight bem-sucedido viapreflight_run_id; a prontidão do lançamento macOS estável também exige os arquivos.zip,.dmg,.dSYM.zipempacotados e oappcast.xmlatualizado emmain. O workflow privado de publicação macOS publica o appcast assinado nomainpúblico automaticamente depois que os ativos de lançamento são verificados; se a proteção de branch bloquear o push direto, ele abre ou atualiza um PR de appcast. - Após publicar, execute o verificador npm pós-publicação, o E2E Telegram standalone opcional do npm publicado quando precisar de prova de canal pós-publicação, promoção de dist-tag quando necessário, verifique a página de lançamento gerada no GitHub e execute as etapas de anúncio do lançamento.
Preflight de lançamento
- Execute
pnpm check:test-typesantes do preflight de lançamento para que o TypeScript dos testes permaneça coberto fora da gate local mais rápidapnpm check - Execute
pnpm check:architectureantes do preflight de lançamento para que as verificações mais amplas de ciclos de importação e limites de arquitetura estejam verdes fora da gate local mais rápida - Execute
pnpm build && pnpm ui:buildantes depnpm release:checkpara que os artefatos de lançamento esperados emdist/*e o pacote da UI de Controle existam para a etapa de validação de empacotamento - Execute
pnpm release:prepapós o incremento da versão raiz e antes de criar a tag. Ele executa todos os geradores determinísticos de lançamento que costumam divergir após uma alteração de versão/configuração/API: versões de plugin, inventário de plugins, esquema de configuração base, metadados de configuração de canais empacotados, baseline da documentação de configuração, exportações do SDK de plugin e baseline da API do SDK de plugin.pnpm release:checkreexecuta essas proteções em modo de verificação e relata, em uma única passagem, todas as falhas de divergência gerada que encontra antes de executar as verificações de lançamento de pacote. - Execute o workflow manual
Full Release Validationantes da aprovação de lançamento para iniciar todas as caixas de teste de pré-lançamento a partir de um único ponto de entrada. Ele aceita uma branch, tag ou SHA completo de commit, dispara manualmenteCIe disparaOpenClaw Release Checkspara smoke de instalação, aceitação de pacote, verificações de pacote entre SOs, paridade do QA Lab, Matrix e lanes do Telegram. Execuções estáveis/padrão mantêm o soak exaustivo live/E2E e de caminho de lançamento Docker atrás derun_release_soak=true;release_profile=fullforça o soak. Comrelease_profile=fullererun_group=all, ele também executa E2E de Telegram de pacote contra o artefatorelease-package-under-testdas verificações de lançamento. Forneçarelease_package_specapós publicar um beta para reutilizar o pacote npm lançado nas verificações de lançamento, na Aceitação de Pacote e no E2E de Telegram de pacote sem reconstruir o tarball de lançamento. Forneçanpm_telegram_package_specsomente quando o Telegram deve usar um pacote publicado diferente do restante da validação de lançamento. Forneçapackage_acceptance_package_specquando a Aceitação de Pacote deve usar um pacote publicado diferente da especificação do pacote de lançamento. Forneçaevidence_package_specquando o relatório privado de evidência deve provar que a validação corresponde a um pacote npm publicado sem forçar o E2E de Telegram. Exemplo:gh workflow run full-release-validation.yml --ref main -f ref=release/YYYY.M.D - Execute o workflow manual
Package Acceptancequando quiser uma prova de canal lateral para um candidato de pacote enquanto o trabalho de lançamento continua. Usesource=npmparaopenclaw@beta,openclaw@latestou uma versão exata de lançamento;source=refpara empacotar uma branch/tag/SHA confiável depackage_refcom o harnessworkflow_refatual;source=urlpara um tarball HTTPS com SHA-256 obrigatório; ousource=artifactpara um tarball enviado por outra execução do GitHub Actions. O workflow resolve o candidato parapackage-under-test, reutiliza o agendador de lançamento Docker E2E contra esse tarball e pode executar QA do Telegram contra o mesmo tarball comtelegram_mode=mock-openaioutelegram_mode=live-frontier. Quando as lanes Docker selecionadas incluempublished-upgrade-survivor, o artefato de pacote é o candidato epublished_upgrade_survivor_baselineseleciona a baseline publicada.update-restart-authusa o pacote candidato tanto como a CLI instalada quanto como o package-under-test, para exercitar o caminho de reinicialização gerenciada do comando de atualização candidato. Exemplo:gh workflow run package-acceptance.yml --ref main -f workflow_ref=main -f source=npm -f package_spec=openclaw@beta -f suite_profile=product -f published_upgrade_survivor_baseline=openclaw@2026.4.26 -f telegram_mode=mock-openaiPerfis comuns:smoke: lanes de instalação/canal/agente, rede do Gateway e recarregamento de configuraçãopackage: lanes nativas de artefato para pacote/atualização/reinicialização/plugin sem OpenWebUI ou ClawHub liveproduct: perfil de pacote mais canais MCP, limpeza de cron/subagente, busca web da OpenAI e OpenWebUIfull: blocos de caminho de lançamento Docker com OpenWebUIcustom: seleção exata dedocker_lanespara uma reexecução focada
- Execute o workflow manual
CIdiretamente quando precisar apenas da cobertura normal completa de CI para o candidato de lançamento. Disparos manuais de CI ignoram o escopo por alterações e forçam os shards Linux Node, shards de plugins empacotados, contratos de canal, compatibilidade com Node 22,check,check-additional, smoke de build, verificações de documentação, Skills Python, Windows, macOS, Android e lanes de i18n da UI de Controle. Exemplo:gh workflow run ci.yml --ref release/YYYY.M.D - Execute
pnpm qa:otel:smokeao validar telemetria de lançamento. Ele exercita o QA-lab por meio de um receptor OTLP/HTTP local e verifica os nomes de spans de trace exportados, atributos limitados e redação de conteúdo/identificador sem exigir Opik, Langfuse ou outro coletor externo. - Execute
pnpm release:checkantes de todo lançamento com tag - Execute
OpenClaw Release Publishpara a sequência mutável de publicação depois que a tag existir. Dispare-o a partir derelease/YYYY.M.D(oumainao publicar uma tag alcançável por main), passe a tag de lançamento e opreflight_run_idbem-sucedido do npm do OpenClaw, e mantenha o escopo padrão de publicação de pluginsall-publishable, a menos que você esteja executando deliberadamente um reparo focado. O workflow serializa a publicação npm de plugins, a publicação de plugins no ClawHub e a publicação npm do OpenClaw para que o pacote central não seja publicado antes de seus plugins externalizados. - As verificações de lançamento agora rodam em um workflow manual separado:
OpenClaw Release Checks OpenClaw Release Checkstambém executa a lane de paridade mock do QA Lab mais o perfil Matrix live rápido e a lane de QA do Telegram antes da aprovação de lançamento. As lanes live usam o ambienteqa-live-shared; o Telegram também usa leases de credenciais CI do Convex. Execute o workflow manualQA-Lab - All Lanescommatrix_profile=allematrix_shards=truequando quiser inventário completo de transporte Matrix, mídia e E2EE em paralelo.- A validação de runtime de instalação e upgrade entre SOs faz parte dos workflows públicos
OpenClaw Release CheckseFull Release Validation, que chamam diretamente o workflow reutilizável.github/workflows/openclaw-cross-os-release-checks-reusable.yml - Essa separação é intencional: mantenha o caminho real de lançamento npm curto, determinístico e focado em artefatos, enquanto verificações live mais lentas ficam em sua própria lane para que não travem nem bloqueiem a publicação
- Verificações de lançamento que carregam segredos devem ser disparadas por meio de
Full Release Validationou a partir da ref de workflowmain/release para que a lógica do workflow e os segredos permaneçam controlados OpenClaw Release Checksaceita uma branch, tag ou SHA completo de commit, desde que o commit resolvido seja alcançável a partir de uma branch do OpenClaw ou tag de lançamento- O preflight somente de validação
OpenClaw NPM Releasetambém aceita o SHA completo atual de 40 caracteres do commit da branch do workflow sem exigir uma tag enviada - Esse caminho por SHA é somente de validação e não pode ser promovido para uma publicação real
- No modo SHA, o workflow sintetiza
v<package.json version>apenas para a verificação de metadados do pacote; a publicação real ainda exige uma tag de lançamento real - Ambos os workflows mantêm o caminho real de publicação e promoção em runners hospedados pelo GitHub, enquanto o caminho de validação não mutável pode usar os runners Linux maiores da Blacksmith
- Esse workflow executa
OPENCLAW_LIVE_TEST=1 OPENCLAW_LIVE_CACHE_TEST=1 pnpm test:live:cacheusando os segredos de workflowOPENAI_API_KEYeANTHROPIC_API_KEY - O preflight de lançamento npm não espera mais pela lane separada de verificações de lançamento
- Antes de criar localmente a tag de um candidato de lançamento, execute
RELEASE_TAG=vYYYY.M.D-beta.N pnpm release:fast-pretag-check. O helper executa as proteções rápidas de lançamento, verificações de lançamento npm/ClawHub de plugins, build, build da UI erelease:openclaw:npm:checkna ordem que captura erros comuns que bloqueiam aprovação antes de o workflow de publicação do GitHub começar. - Execute
RELEASE_TAG=vYYYY.M.D node --import tsx scripts/openclaw-npm-release-check.ts(ou a tag beta/correção correspondente) antes da aprovação - Após a publicação npm, execute
node --import tsx scripts/openclaw-npm-postpublish-verify.ts YYYY.M.D(ou a versão beta/correção correspondente) para verificar o caminho de instalação do registro publicado em um prefixo temporário novo - Após uma publicação beta, execute
OPENCLAW_NPM_TELEGRAM_PACKAGE_SPEC=openclaw@YYYY.M.D-beta.N OPENCLAW_NPM_TELEGRAM_CREDENTIAL_SOURCE=convex OPENCLAW_NPM_TELEGRAM_CREDENTIAL_ROLE=ci pnpm test:docker:npm-telegram-livepara verificar onboarding de pacote instalado, configuração do Telegram e E2E real de Telegram contra o pacote npm publicado usando o pool compartilhado de credenciais leased do Telegram. Execuções locais pontuais de mantenedor podem omitir as variáveis do Convex e passar diretamente as três credenciais de ambienteOPENCLAW_QA_TELEGRAM_*. - Para executar o smoke beta completo pós-publicação a partir da máquina de um mantenedor, use
pnpm release:beta-smoke -- --beta betaN. O helper executa validação npm de atualização/novo alvo no Parallels, disparaNPM Telegram Beta E2E, faz polling da execução exata do workflow, baixa o artefato e imprime o relatório do Telegram. - Mantenedores podem executar a mesma verificação pós-publicação pelo GitHub Actions por meio do
workflow manual
NPM Telegram Beta E2E. Ele é intencionalmente apenas manual e não roda em todo merge. - A automação de lançamento de mantenedores agora usa preflight-depois-promover:
- a publicação npm real deve passar um
preflight_run_idnpm bem-sucedido - a publicação npm real deve ser disparada a partir da mesma branch
mainourelease/YYYY.M.Dda execução de preflight bem-sucedida - lançamentos npm estáveis usam
betapor padrão - a publicação npm estável pode mirar explicitamente em
latestpor meio da entrada do workflow - a mutação de dist-tag npm baseada em token agora vive em
openclaw/releases-private/.github/workflows/openclaw-npm-dist-tags.ymlpor segurança, porquenpm dist-tag addainda precisa deNPM_TOKEN, enquanto o repositório público mantém publicação somente via OIDC - o
macOS Releasepúblico é somente de validação; quando uma tag existe apenas em uma branch de lançamento, mas o workflow é disparado a partir demain, definapublic_release_branch=release/YYYY.M.D - a publicação privada real para Mac deve passar por
preflight_run_idevalidate_run_idprivados de Mac bem-sucedidos - os caminhos reais de publicação promovem artefatos preparados em vez de reconstruí-los novamente
- a publicação npm real deve passar um
- Para lançamentos estáveis de correção como
YYYY.M.D-N, o verificador pós-publicação também verifica o mesmo caminho de upgrade com prefixo temporário deYYYY.M.DparaYYYY.M.D-Npara que correções de lançamento não deixem silenciosamente instalações globais antigas no payload estável base - O preflight de lançamento npm falha fechado a menos que o tarball inclua tanto
dist/control-ui/index.htmlquanto um payload não vazio emdist/control-ui/assets/para que não enviemos novamente um painel de navegador vazio - A verificação pós-publicação também verifica se os entrypoints de plugins publicados e
os metadados de pacote estão presentes no layout instalado do registro. Um lançamento que
envia payloads de runtime de plugin ausentes falha no verificador pós-publicação e
não pode ser promovido para
latest. pnpm test:install:smoketambém aplica o orçamento deunpackedSizedo npm pack ao tarball candidato de atualização, para que o e2e do instalador capture inchaço acidental de pacote antes do caminho de publicação de lançamento- Se o trabalho de lançamento tocou no planejamento de CI, manifestos de temporização de extensões ou
matrizes de teste de extensões, regenere e revise as saídas de matriz
plugin-prerelease-extension-shard, pertencentes ao planejador, de.github/workflows/plugin-prerelease.ymlantes da aprovação para que as notas de lançamento não descrevam um layout de CI desatualizado - A prontidão de lançamento estável do macOS também inclui as superfícies do atualizador:
- o release do GitHub deve acabar com o
.zip,.dmge.dSYM.zipempacotados appcast.xmlemmaindeve apontar para o novo zip estável após a publicação; o workflow privado de publicação macOS faz o commit automaticamente ou abre um PR de appcast quando push direto é bloqueado- o app empacotado deve manter um bundle id não debug, uma URL de feed Sparkle
não vazia e um
CFBundleVersionigual ou superior ao piso canônico de build do Sparkle para essa versão de lançamento
- o release do GitHub deve acabar com o
Caixas de teste de lançamento
Full Release Validation é como operadores iniciam todos os testes de pré-lançamento a partir de
um único ponto de entrada. Para uma prova de commit fixado em um branch que se move rapidamente, use o
helper para que cada workflow filho seja executado a partir de um branch temporário fixado no SHA
alvo:
release-ci/<sha>-..., dispara Full Release Validation
a partir desse branch com ref=<sha>, verifica se cada headSha de workflow filho
corresponde ao alvo e, em seguida, exclui o branch temporário. Isso evita provar acidentalmente uma
execução filha de main mais nova.
Para validação de branch ou tag de lançamento, execute a partir da ref confiável de workflow main
e passe o branch ou a tag de lançamento como ref:
CI manual com
target_ref=<release-ref>, dispara OpenClaw Release Checks, prepara um
artefato pai release-package-under-test para verificações voltadas a pacote e
dispara o E2E de pacote Telegram autônomo quando release_profile=full com
rerun_group=all ou quando release_package_spec ou
npm_telegram_package_spec está definido. OpenClaw Release Checks então expande para smoke de instalação, verificações de lançamento entre sistemas operacionais, cobertura live/E2E do caminho de lançamento Docker quando o soak está habilitado, Package Acceptance com QA de pacote Telegram, paridade do QA Lab, Matrix live e Telegram live. Uma execução completa só é aceitável quando o
resumo de Full Release Validation
mostra normal_ci e release_checks como bem-sucedidos. No modo full/all,
o filho npm_telegram também deve ser bem-sucedido; fora de full/all, ele é ignorado
a menos que um release_package_spec ou npm_telegram_package_spec publicado tenha sido
fornecido. O resumo final do
verificador inclui tabelas dos jobs mais lentos para cada execução filha, para que o gerente de lançamento
possa ver o caminho crítico atual sem baixar logs.
Consulte Validação completa de lançamento para a
matriz completa de estágios, nomes exatos dos jobs de workflow, diferenças entre perfis stable e full,
artefatos e identificadores de reexecução focada.
Workflows filhos são disparados a partir da ref confiável que executa Full Release Validation, normalmente --ref main, mesmo quando a ref alvo aponta para um
branch ou tag de lançamento mais antigo. Não há uma entrada separada de ref de workflow para Full Release Validation; escolha o harness confiável escolhendo a ref de execução do workflow.
Não use --ref main -f ref=<sha> para prova exata de commit em main móvel;
SHAs de commit brutos não podem ser refs de dispatch de workflow, então use
pnpm ci:full-release --sha <sha> para criar o branch temporário fixado.
Use release_profile para selecionar a amplitude live/provedor:
minimum: caminho live e Docker OpenAI/core mais rápido e crítico para lançamentostable: minimum mais cobertura estável de provedor/backend para aprovação de lançamentofull: stable mais cobertura ampla de provedor/mídia consultiva
run_release_soak=true com stable quando as lanes bloqueadoras de lançamento estiverem
verdes e você quiser a varredura exaustiva live/E2E, de caminho de lançamento Docker e
de sobrevivência a upgrade publicado limitada antes da promoção. Essa varredura cobre
os quatro pacotes stable mais recentes, além das linhas de base fixadas 2026.4.23 e 2026.5.2
e da cobertura mais antiga 2026.4.15, com linhas de base duplicadas removidas e
cada linha de base fragmentada em seu próprio job de runner Docker. full implica
run_release_soak=true.
OpenClaw Release Checks usa a ref confiável do workflow para resolver a ref alvo
uma vez como release-package-under-test e reutiliza esse artefato nas verificações entre sistemas operacionais,
Package Acceptance e Docker de caminho de lançamento quando o soak é executado. Isso mantém
todas as caixas voltadas a pacote nos mesmos bytes e evita builds repetidos de pacote.
Depois que um beta já estiver no npm, defina release_package_spec=openclaw@YYYY.M.D-beta.N
para que as verificações de lançamento baixem o pacote enviado uma vez, extraiam seu SHA de origem de build
de dist/build-info.json e reutilizem esse artefato para lanes entre sistemas operacionais,
Package Acceptance, Docker de caminho de lançamento e Telegram de pacote.
O smoke de instalação OpenAI entre sistemas operacionais usa OPENCLAW_CROSS_OS_OPENAI_MODEL quando a
variável de repo/organização está definida; caso contrário, usa openai/gpt-5.4, porque essa lane está
provando instalação de pacote, onboarding, inicialização do Gateway e uma rodada live de agente,
não fazendo benchmark do modelo padrão mais lento. A matriz live de provedores mais ampla
continua sendo o lugar para cobertura específica de modelo.
Use estas variantes dependendo do estágio do lançamento:
Verify full validation com falha.
Para recuperação limitada, passe rerun_group ao guarda-chuva. all é a execução real de
candidato a lançamento, ci executa apenas o filho de CI normal, plugin-prerelease
executa apenas o filho de Plugin exclusivo de lançamento, release-checks executa todas as caixas de lançamento
e os grupos de lançamento mais estreitos são install-smoke, cross-os,
live-e2e, package, qa, qa-parity, qa-live e npm-telegram.
Reexecuções focadas de npm-telegram exigem release_package_spec ou
npm_telegram_package_spec; execuções full/all com release_profile=full usam o
artefato de pacote de release-checks. Reexecuções focadas
entre sistemas operacionais podem adicionar cross_os_suite_filter=windows/packaged-upgrade ou
outro filtro de sistema operacional/suíte. Falhas de QA em release-check são consultivas; uma falha somente de QA
não bloqueia a validação de lançamento.
Vitest
A caixa Vitest é o workflow filhoCI manual. A CI manual intencionalmente
ignora o escopo de alterações e força o grafo normal de testes para o candidato a lançamento:
shards Linux Node, shards de Plugin empacotado, contratos de canal, compatibilidade Node 22,
check, check-additional, smoke de build, verificações de docs, Skills Python, Windows, macOS, Android e i18n da Control UI.
Use esta caixa para responder “a árvore de código-fonte passou na suíte completa normal de testes?”
Ela não é o mesmo que validação de produto no caminho de lançamento. Evidências a manter:
- resumo de
Full Release Validationmostrando a URL da execuçãoCIdisparada - execução
CIverde no SHA alvo exato - nomes de shards com falha ou lentos dos jobs de CI ao investigar regressões
- artefatos de timing do Vitest, como
.artifacts/vitest-shard-timings.json, quando uma execução precisar de análise de desempenho
Docker
A caixa Docker fica emOpenClaw Release Checks por meio de
openclaw-live-and-e2e-checks-reusable.yml, além do workflow install-smoke
em modo de lançamento. Ela valida o candidato a lançamento por meio de ambientes Docker
empacotados, em vez de apenas testes em nível de código-fonte.
A cobertura Docker de lançamento inclui:
- smoke completo de instalação com o smoke lento de instalação global Bun habilitado
- preparação/reutilização da imagem de smoke do Dockerfile raiz por SHA alvo, com jobs de smoke de QR, raiz/Gateway e instalador/Bun executando como shards install-smoke separados
- lanes E2E de repositório
- chunks Docker de caminho de lançamento:
core,package-update-openai,package-update-anthropic,package-update-core,plugins-runtime-plugins,plugins-runtime-services,plugins-runtime-install-a,plugins-runtime-install-b,plugins-runtime-install-c,plugins-runtime-install-d,plugins-runtime-install-e,plugins-runtime-install-f,plugins-runtime-install-geplugins-runtime-install-h - cobertura OpenWebUI dentro do chunk
plugins-runtime-servicesquando solicitada - lanes divididas de instalação/desinstalação de Plugin empacotado
bundled-plugin-install-uninstall-0atébundled-plugin-install-uninstall-23 - suítes live/E2E de provedor e cobertura live de modelo Docker quando as verificações de lançamento incluem suítes live
.artifacts/docker-tests/ com logs de lanes, summary.json, failures.json,
timings de fases, JSON do plano do agendador e comandos de reexecução. Para recuperação focada,
use docker_lanes=<lane[,lane]> no workflow reutilizável live/E2E em vez de
reexecutar todos os chunks de lançamento. Comandos de reexecução gerados incluem
package_artifact_run_id anterior e entradas de imagem Docker preparada quando disponíveis, para que uma
lane com falha possa reutilizar o mesmo tarball e imagens GHCR.
QA Lab
A caixa QA Lab também faz parte deOpenClaw Release Checks. Ela é o gate de
lançamento de comportamento agentic e em nível de canal, separado da mecânica de pacote
do Vitest e do Docker.
A cobertura QA Lab de lançamento inclui:
- lane de paridade mock comparando a lane candidata OpenAI com a linha de base Opus 4.6 usando o pacote de paridade agentic
- perfil rápido de QA Matrix live usando o ambiente
qa-live-shared - lane de QA Telegram live usando leases de credenciais Convex CI
pnpm qa:otel:smokequando a telemetria de lançamento precisa de prova local explícita
Pacote
A caixa Package é o gate de produto instalável. Ela é apoiada porPackage Acceptance e pelo resolvedor
scripts/resolve-openclaw-package-candidate.mjs. O resolvedor normaliza um
candidato no tarball package-under-test consumido pelo Docker E2E, valida
o inventário do pacote, registra a versão do pacote e o SHA-256 e mantém a
ref do harness de workflow separada da ref de origem do pacote.
Origens de candidato compatíveis:
source=npm:openclaw@beta,openclaw@latestou uma versão exata de lançamento do OpenClawsource=ref: empacotar um branch, tag ou SHA completo de commit confiável depackage_refcom o harnessworkflow_refselecionadosource=url: baixar um.tgzHTTPS compackage_sha256obrigatóriosource=artifact: reutilizar um.tgzenviado por outra execução do GitHub Actions
OpenClaw Release Checks executa Package Acceptance com source=artifact, o
artefato do pacote de lançamento preparado, suite_profile=custom,
docker_lanes=doctor-switch update-channel-switch skill-install update-corrupt-plugin upgrade-survivor published-upgrade-survivor update-restart-auth plugins-offline plugin-update,
telegram_mode=mock-openai. Package Acceptance mantém a migração, a atualização,
a reinicialização de atualização com autenticação configurada, a instalação live de skill do ClawHub, a limpeza de dependência obsoleta de Plugin, os
fixtures de Plugin offline, a atualização de Plugin e a QA de pacote do Telegram no mesmo
tarball resolvido. As verificações bloqueantes de lançamento usam o baseline padrão do pacote publicado mais recente;
run_release_soak=true ou
release_profile=full expande para todos os baselines estáveis publicados no npm de
2026.4.23 até latest, além dos fixtures de problemas relatados. Use
Package Acceptance com source=npm para um candidato já lançado, ou
source=ref/source=artifact para um tarball npm local com respaldo em SHA antes da
publicação. Ele é o substituto nativo do GitHub para a maior parte da cobertura de pacote/atualização que antes exigia
Parallels. Verificações de lançamento entre sistemas operacionais ainda são importantes para onboarding,
instalador e comportamento de plataforma específicos do sistema operacional, mas a validação de produto de pacote/atualização deve
preferir Package Acceptance.
A checklist canônica para validação de atualização e Plugin é
Testando atualizações e plugins. Use-a ao
decidir qual lane local, Docker, Package Acceptance ou de verificação de lançamento prova uma
instalação/atualização de Plugin, limpeza do doctor ou alteração de migração de pacote publicado.
A migração exaustiva de atualização publicada de todos os pacotes estáveis 2026.4.23+ é
um workflow manual separado Update Migration, não parte do Full Release CI.
A leniência legada de aceitação de pacote é intencionalmente limitada no tempo. Pacotes até
2026.4.25 podem usar o caminho de compatibilidade para lacunas de metadados já publicadas
no npm: entradas privadas de inventário de QA ausentes no tarball, ausência de
gateway install --wrapper, arquivos de patch ausentes no fixture git derivado do tarball,
ausência de update.channel persistido, locais legados de registros de instalação de Plugin,
ausência de persistência de registros de instalação do marketplace e migração de metadados de configuração
durante plugins update. O pacote publicado 2026.4.26 pode avisar
sobre arquivos locais de carimbo de metadados de build que já foram lançados. Pacotes posteriores
devem satisfazer os contratos modernos de pacote; essas mesmas lacunas falham a
validação de lançamento.
Use perfis mais amplos de Package Acceptance quando a pergunta de lançamento for sobre um
pacote realmente instalável:
smoke: lanes rápidas de instalação de pacote/canal/agente, rede do Gateway e recarregamento de configuraçãopackage: contratos de pacote de instalação/atualização/reinicialização/Plugin mais prova de instalação live de skill do ClawHub; este é o padrão da verificação de lançamentoproduct:packagemais canais MCP, limpeza de cron/subagente, pesquisa web da OpenAI e OpenWebUIfull: blocos de caminho de lançamento Docker com OpenWebUIcustom: lista exata dedocker_lanespara reexecuções focadas
telegram_mode=mock-openai ou
telegram_mode=live-frontier em Package Acceptance. O workflow passa o
tarball package-under-test resolvido para a lane do Telegram; o workflow autônomo do
Telegram ainda aceita uma especificação npm publicada para verificações pós-publicação.
Automação de publicação de lançamento
OpenClaw Release Publish é o ponto de entrada mutável normal de publicação. Ele
orquestra os workflows de editor confiável na ordem que o lançamento precisa:
- Fazer checkout da tag de lançamento e resolver seu SHA de commit.
- Verificar se a tag é alcançável a partir de
mainourelease/*. - Executar
pnpm plugins:sync:check. - Disparar
Plugin NPM Releasecompublish_scope=all-publishableeref=<release-sha>. - Disparar
Plugin ClawHub Releasecom o mesmo escopo e SHA. - Disparar
OpenClaw NPM Releasecom a tag de lançamento, a dist-tag do npm e opreflight_run_idsalvo.
latest é explícita:
Plugin NPM Release e Plugin ClawHub Release
apenas para trabalho focado de reparo ou republicação. Para um reparo de Plugin selecionado, passe
plugin_publish_scope=selected e plugins=@openclaw/name para
OpenClaw Release Publish, ou dispare o workflow filho diretamente quando o
pacote OpenClaw não deve ser publicado.
Entradas do workflow NPM
OpenClaw NPM Release aceita estas entradas controladas pelo operador:
tag: tag de lançamento obrigatória, comov2026.4.2,v2026.4.2-1ouv2026.4.2-beta.1; quandopreflight_only=true, também pode ser o SHA de commit completo de 40 caracteres do branch do workflow atual para preflight somente de validaçãopreflight_only:trueapenas para validação/build/pacote,falsepara o caminho real de publicaçãopreflight_run_id: obrigatório no caminho real de publicação para que o workflow reutilize o tarball preparado da execução de preflight bem-sucedidanpm_dist_tag: tag alvo do npm para o caminho de publicação; o padrão ébeta
OpenClaw Release Publish aceita estas entradas controladas pelo operador:
tag: tag de lançamento obrigatória; já deve existirpreflight_run_id: id da execução de preflight bem-sucedida deOpenClaw NPM Release; obrigatório quandopublish_openclaw_npm=truenpm_dist_tag: tag alvo do npm para o pacote OpenClawplugin_publish_scope: o padrão éall-publishable; useselectedapenas para trabalho focado de reparoplugins: nomes de pacotes@openclaw/*separados por vírgula quandoplugin_publish_scope=selectedpublish_openclaw_npm: o padrão étrue; definafalseapenas ao usar o workflow como orquestrador de reparo somente de Pluginwait_for_clawhub: o padrão éfalse, para que a disponibilidade no npm não seja bloqueada pela sidecar do ClawHub; definatrueapenas quando a conclusão do workflow precisar incluir a conclusão do ClawHub
OpenClaw Release Checks aceita estas entradas controladas pelo operador:
ref: branch, tag ou SHA de commit completo a validar. Verificações que carregam segredos exigem que o commit resolvido seja alcançável a partir de um branch OpenClaw ou tag de lançamento.run_release_soak: optar por soak exaustivo live/E2E, caminho de lançamento Docker e upgrade-survivor desde todos os lançamentos em verificações de lançamento estável/padrão. É forçado porrelease_profile=full.
- Tags estáveis e de correção podem publicar para
betaoulatest - Tags beta de pré-lançamento podem publicar apenas para
beta - Para
OpenClaw NPM Release, entrada de SHA de commit completo é permitida apenas quandopreflight_only=true OpenClaw Release CheckseFull Release Validationsão sempre somente validação- O caminho real de publicação deve usar a mesma
npm_dist_tagusada durante o preflight; o workflow verifica esses metadados antes que a publicação continue
Sequência de lançamento npm estável
Ao preparar um lançamento npm estável:- Execute
OpenClaw NPM Releasecompreflight_only=true- Antes de uma tag existir, você pode usar o SHA de commit completo do branch do workflow atual para uma execução seca somente de validação do workflow de preflight
- Escolha
npm_dist_tag=betapara o fluxo normal beta-primeiro, oulatestapenas quando você intencionalmente quiser uma publicação estável direta - Execute
Full Release Validationno branch de lançamento, tag de lançamento ou SHA de commit completo quando quiser CI normal mais cache de prompt live, Docker, QA Lab, Matrix e cobertura do Telegram em um workflow manual - Se você intencionalmente só precisar do grafo de testes normal determinístico, execute o
workflow manual
CIna ref de lançamento - Salve o
preflight_run_idbem-sucedido - Execute
OpenClaw Release Publishcom a mesmatag, a mesmanpm_dist_tag, e opreflight_run_idsalvo; ele publica plugins externalizados no npm e no ClawHub antes de promover o pacote npm OpenClaw - Se o lançamento chegou em
beta, use o workflow privadoopenclaw/releases-private/.github/workflows/openclaw-npm-dist-tags.ymlpara promover essa versão estável debetaparalatest - Se o lançamento foi publicado intencionalmente diretamente em
latestebetadeve seguir imediatamente o mesmo build estável, use esse mesmo workflow privado para apontar ambas as dist-tags para a versão estável, ou deixe sua sincronização programada de autocorreção moverbetaposteriormente
NPM_TOKEN, enquanto o repositório público mantém publicação somente por OIDC.
Isso mantém o caminho de publicação direta e o caminho de promoção beta-primeiro
documentados e visíveis ao operador.
Se um mantenedor precisar recorrer à autenticação npm local, execute quaisquer comandos da
CLI 1Password (op) apenas dentro de uma sessão tmux dedicada. Não chame op
diretamente pelo shell principal do agente; mantê-lo dentro do tmux torna prompts,
alertas e tratamento de OTP observáveis e evita alertas repetidos do host.
Referências públicas
.github/workflows/full-release-validation.yml.github/workflows/package-acceptance.yml.github/workflows/openclaw-npm-release.yml.github/workflows/openclaw-release-checks.yml.github/workflows/openclaw-cross-os-release-checks-reusable.ymlscripts/resolve-openclaw-package-candidate.mjsscripts/openclaw-npm-release-check.tsscripts/package-mac-dist.shscripts/make_appcast.sh
openclaw/maintainers/release/README.md
para o runbook real.