CI/CD 통합
빌드 파이프라인에서 번역을 자동화해 보세요.
GitHub Actions: 푸시 시 동기화
기존 빌드 파이프라인에 번역 동기화를 추가해 보세요:
.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: 예약 동기화
정해진 일정에 따라 번역을 실행하고 자동 커밋해 보세요:
.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
Google Translate 방식
OpenRouter 대신 내장된 Google Translate 방식을 사용하는 경우:
- name: Sync translations
env:
GOOGLE_TRANSLATE_API_KEY: ${{ secrets.GOOGLE_TRANSLATE_API_KEY }}
run: npx i18n-rosetta sync
Direct LLM 제공자
openai, anthropic 또는 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
원격 번역 API
원격 번역 엔드포인트를 사용하는 경우(예: 호스팅되는 번역 서비스):
- name: Sync translations
env:
ROSETTA_API_KEY: ${{ secrets.ROSETTA_API_KEY }}
run: npx i18n-rosetta sync
3계층 CI 파이프라인
i18n 커버리지를 극대화하려면, 세 가지 도구를 모두 사용하여 파이프라인을 검증해 보세요:
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
| 계층 | 명령어 | 시점 | 목적 |
|---|---|---|---|
| Lint | lint | Pre-commit | 하드코딩된 문자열이 포함된 커밋 차단 |
| Sync | sync | Post-commit / CI | 누락되거나 변경된 키 번역 |
| Audit | audit | 빌드 단계 | 불완전한 로케일이 있는 경우 배포 실패 처리 |
참고 자료
- CLI 레퍼런스 — 전체 명령어 레퍼런스
- Sync 작동 방식 — 점진적 동기화 이해하기
- 번역 방식 — 언어 쌍별 방식 선택
- Quality Gate — 번역 실패 시 발생하는 일
- 설정 — 설정 레퍼런스