Padrões avançados de localização em CI/CD — escolha de workflow, verificação da integridade das traduções e resolução de conflitos de merge.
Escolhendo um workflow#
Quatro padrões de workflow atendem à maioria das estruturas de equipe. Cada um traz trade-offs diferentes em automação, esforço de revisão e organização das branches.
| Workflow | Ideal para | Trade-off |
|---|---|---|
| Commit na main | Equipes pequenas, atualizações sem atrito | Sem etapa de revisão para traduções |
| PR a partir da main | Equipes que querem revisar as traduções | Exige aprovação manual do PR |
| Commit na feature branch | Feature branches de longa duração | Commits de tradução no histórico da branch |
| PR a partir da feature branch | Máximo controle por funcionalidade | Vários PRs por funcionalidade para gerenciar |
Se estiver em dúvida, comece com "Commit na main". É o workflow mais simples e evita totalmente conflitos de merge, já que não há divergência entre branches.
Verificando a integridade das traduções#
A flag --frozen verifica se todo o conteúdo está traduzido sem gerar novas traduções. Ela retorna um código de status diferente de zero se houver qualquer conteúdo faltando:
npx lingo.dev@latest run --frozenUse isso como gate de deploy para evitar publicar conteúdo sem tradução.
name: Check translations
on: [push, pull_request]
jobs:
check:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20
- run: npx lingo.dev@latest run --frozenResolvendo conflitos de merge#
Conflitos de merge acontecem quando o arquivo i18n.lock diverge entre branches — normalmente quando as traduções são atualizadas de forma independente em branches diferentes.
Prevenção#
Fazer commit das traduções diretamente em main (em vez de usar feature branches para traduções) elimina por completo os conflitos no lockfile.
Resolução via merge#
Inicie o merge
git merge <branch-name>Exclua o lockfile em conflito
rm i18n.lockConclua o merge
git add .
git merge --continueRegenere o lockfile
npx lingo.dev@latest lockfile --forceIsso recria o lockfile com base no estado atual dos arquivos-fonte, sem acionar novas traduções.
Resolução via rebase#
A mesma abordagem funciona com rebase — exclua i18n.lock em cada etapa de conflito, continue o rebase e depois regenere o lockfile no final:
git rebase <branch-name>
# On each conflict: rm i18n.lock && git add . && git rebase --continue
npx lingo.dev@latest lockfile --force