Chuyển đến nội dung chính

Tích hợp CI/CD

Tự động hóa các bản dịch trong build pipeline của bạn.

GitHub Actions: Đồng bộ khi Push

Thêm đồng bộ bản dịch vào build pipeline hiện tại của bạn:

.github/workflows/deploy.yml
jobs:
build:
steps:
- uses: actions/checkout@v4
- run: npm ci
- name: Sync translations
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
run: npx i18n-rosetta sync
- run: npm run build

GitHub Actions: Đồng bộ theo lịch trình

Chạy các bản dịch theo lịch trình và tự động commit:

.github/workflows/i18n-sync.yml
name: Sync translations
on:
schedule:
- cron: '0 6 * * *'
workflow_dispatch:

jobs:
sync:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20
- run: npm ci
- name: Sync translations
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
run: npx i18n-rosetta sync
- name: Commit updated translations
run: |
git config user.name "i18n-rosetta"
git config user.email "bot@example.com"
git add i18n/ content/ locales/ messages/
git diff --staged --quiet || git commit -m "chore: sync translations"
git push

Phương thức Google Translate

Nếu sử dụng phương thức Google Translate tích hợp sẵn thay vì OpenRouter:

- name: Sync translations
env:
GOOGLE_TRANSLATE_API_KEY: ${{ secrets.GOOGLE_TRANSLATE_API_KEY }}
run: npx i18n-rosetta sync

Các nhà cung cấp LLM trực tiếp

Nếu sử dụng trực tiếp các phương thức openai, anthropic, hoặc gemini:

# OpenAI
- name: Sync translations
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
run: npx i18n-rosetta sync --method openai

# Anthropic
- name: Sync translations
env:
ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}
run: npx i18n-rosetta sync --method anthropic

# Gemini (free tier available)
- name: Sync translations
env:
GEMINI_API_KEY: ${{ secrets.GEMINI_API_KEY }}
run: npx i18n-rosetta sync --method gemini

DeepL

- name: Sync translations
env:
DEEPL_API_KEY: ${{ secrets.DEEPL_API_KEY }}
run: npx i18n-rosetta sync --method deepl

Remote Translation API

Nếu sử dụng một remote translation endpoint (ví dụ: một dịch vụ dịch thuật dạng hosted):

- name: Sync translations
env:
ROSETTA_API_KEY: ${{ secrets.ROSETTA_API_KEY }}
run: npx i18n-rosetta sync

CI Pipeline 3 lớp

Để đạt độ bao phủ i18n tối đa, hãy kiểm soát pipeline của bạn bằng cả ba công cụ:

jobs:
i18n:
steps:
- uses: actions/checkout@v4
- run: npm ci

# 1. Catch hardcoded strings before they ship
- run: npx i18n-rosetta lint

# 2. Translate missing keys
- run: npx i18n-rosetta sync
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}

# 3. Fail if any locale is incomplete
- run: npx i18n-rosetta audit
LớpLệnhKhi nàoMục đích
LintlintPre-commitChặn các commit chứa hardcoded string
SyncsyncPost-commit / CIDịch các key bị thiếu và đã thay đổi
AuditauditBuild stepĐánh rớt deployment nếu có bất kỳ locale nào chưa hoàn chỉnh

Xem thêm