Integrasi Pipa Bitbucket
Copas prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Integrasikan Capgo Live Updates dengan Bitbucket Pipelines untuk memperbarui otomatis aplikasi Anda setiap kali Anda mendorong code perubahan. Panduan ini mencakup pengaturan build otomatis, pengujian, dan alur kerja pengiriman.
Prasyarat
Judul bagian “Prasyarat”Sebelum mengatur integrasi Bitbucket Pipelines, pastikan Anda memiliki:
- Akun Bitbucket dengan repositori
- Akun Capgo dengan aplikasi yang dikonfigurasi
- Node.js dan npm/yarn dikonfigurasi di proyek Anda
Mengatur Bitbucket Pipelines
Judul bagian “Mengatur Bitbucket Pipelines”Langkah 1: Konfigurasi Variabel Repositori
Bagian berjudul “Langkah 1: Konfigurasi Variabel Repositori”Pertama-tama, atur variabel-variabel yang diperlukan di repositori Bitbucket Anda:
- Navigasikan ke repositori Bitbucket Anda
- Pergi ke Pengaturan Repositori → Pipelines → Variabel Repositori
- Tambahkan variabel-variabel berikut:
| Nama Variabel | Nilai | Ditandatangani |
|---|---|---|
CAPGO_TOKEN | Token Anda Capgo API | ✅ Ya |
Bagian berjudul “Sederhana”
Konfigurasi dasar yang mengirimkan ke produksi setiap kali push ke cabang utama:Salin ke clipboard
# bitbucket-pipelines.yml - Simple Configurationimage: node:22
pipelines: branches: main: - step: name: Build and Deploy to Production script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production artifacts: - dist/**Lanjutan
Bagian TertinggiDeployan Cabang Fitur
Bagian Tertinggi: Deployan Cabang FiturDeploy cabang fitur ke saluran uji untuk tinjauan dan pengujian:
# Feature branch deploymentpipelines: branches: feature/*: - step: name: Deploy Feature Branch script: - npm ci - npm run test - npm run build - BRANCH_NAME=$(echo $BITBUCKET_BRANCH | sed 's/[^a-zA-Z0-9-]/-/g') - CHANNEL_NAME="feature-$BRANCH_NAME" - npm install -g @capgo/cli - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Menggunakan Enkripsi
Bagian Tertinggi: Menggunakan EnkripsiJika Anda menggunakan Capgo's fitur enkripsi, Anda perlu menyimpan kunci pribadi Anda dengan aman di lingkungan CI/CD Anda.
Setelah mengatur kunci enkripsi secara lokal, tambahkan kunci pribadi Anda ke variabel Bitbucket:
# Display your private key content (copy this output)cat .capgo_key_v2Tambahkan konten ini sebagai CAPGO_PRIVATE_KEY dalam variabel repository Bitbucket Anda (tandai sebagai terlindungi), lalu gunakan di pipeline:
# Deploy with encryption- step: name: Deploy to Capgo with Encryption script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel productionKonfigurasi Multi-Kanal
Bagian berjudul “Konfigurasi Multi-Kanal”Untuk informasi yang lebih komprehensif tentang pengaturan dan pengelolaan saluran pengiriman yang berbeda, lihat dokumentasi Saluran.
Konfigurasi lengkap dengan lingkungan yang berbeda dan pengiriman permintaan pull:
# bitbucket-pipelines.yml - Advanced Multi-Channel Configurationimage: node:22
definitions: steps: - step: &build-step name: Build Application script: - npm ci - npm run test - npm run build artifacts: - dist/**
- step: &deploy-step name: Deploy to Capgo script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
pipelines: branches: main: - step: <<: *build-step - step: <<: *deploy-step name: Deploy to Production deployment: production trigger: manual script: - export CHANNEL_NAME=production - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
develop: - step: <<: *build-step - step: <<: *deploy-step name: Deploy to Development deployment: development script: - export CHANNEL_NAME=development - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
pull-requests: '**': - step: <<: *build-step - step: name: Deploy PR to Test Channel script: - CHANNEL_NAME="pr-$BITBUCKET_PR_ID" - npm install -g @capgo/cli - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Pipelining Multi-Environment
Judul Bagian “Pipelining Multi-Environment”Untuk skenario pengiriman kompleks dengan lingkungan pengujian dan produksi:
# Multi-environment pipelineimage: node:22
pipelines: branches: main: - step: name: Build script: - npm ci - npm run test - npm run build artifacts: - dist/** - step: name: Deploy to Staging deployment: staging script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel staging - step: name: Deploy to Production deployment: production trigger: manual script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production
develop: - step: name: Build and Deploy to Development script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel development artifacts: - dist/**Strategi Pengiriman Berdasarkan Cabang
Judul Bagian “Strategi Pengiriman Berdasarkan Cabang”Tetapkan cabang yang berbeda untuk saluran yang tepat secara otomatis:
# Dynamic channel deploymentimage: node:22
definitions: scripts: - script: &determine-channel | if [ "$BITBUCKET_BRANCH" = "main" ]; then export CHANNEL_NAME="production" elif [ "$BITBUCKET_BRANCH" = "develop" ]; then export CHANNEL_NAME="staging" else export CHANNEL_NAME="development" fi echo "Deploying to channel: $CHANNEL_NAME"
pipelines: default: - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - *determine-channel - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Eksekusi Pipelining Paralel
Judul Bagian “Eksekusi Pipelining Paralel”Optimalkan waktu pembangunan dengan langkah-langkah paralel:
# Parallel execution pipelineimage: node:22
pipelines: branches: main: - parallel: - step: name: Run Tests script: - npm ci - npm run test - step: name: Lint Code script: - npm ci - npm run lint - step: name: Build Application script: - npm ci - npm run build artifacts: - dist/** - step: name: Deploy to Production deployment: production script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionPraktik Keamanan Terbaik
Judul Bagian “Praktik Keamanan Terbaik”Variabel Repositori
Judul Bagian “Variabel Repositori”- Variabel Terlindungi: Selalu tandai token API sebagai terlindungi
- Variabel Lingkungan: Gunakan variabel spesifik penggunaan saat diperlukan
- Kontrol Akses: Batasi akses repositori hanya untuk anggota tim yang berwenang
- Rotasi Token: Rotasi secara teratur token Capgo API Anda
Lingkungan Pengembangan
Judul Bagian “Lingkungan Pengembangan”Konfigurasi lingkungan pengembangan untuk keamanan yang lebih baik:
# Deployment with environment restrictionspipelines: branches: main: - step: name: Deploy to Production deployment: production trigger: manual script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionPengawasan dan Pemberitahuan
Judul Bagian “Pengawasan dan Pemberitahuan”Integrasi Slack
Judul Bagian “Integrasi Slack”Tambahkan pemberitahuan Slack ke pipa Anda:
# Pipeline with Slack notificationspipelines: branches: main: - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production after-script: - | if [ $BITBUCKET_EXIT_CODE -eq 0 ]; then curl -X POST -H 'Content-type: application/json' \ --data '{"text":"✅ Capgo deployment successful for '$BITBUCKET_BRANCH'"}' \ $SLACK_WEBHOOK_URL else curl -X POST -H 'Content-type: application/json' \ --data '{"text":"❌ Capgo deployment failed for '$BITBUCKET_BRANCH'"}' \ $SLACK_WEBHOOK_URL fiPemberitahuan Email
Judul Bagian “Pemberitahuan Email”Konfigurasi notifikasi email melalui fitur bawaan Bitbucket atau menggunakan layanan eksternal:
# Email notification step- step: name: Send Notification script: - | curl -X POST \ -H "Content-Type: application/json" \ -d '{ "to": "team@yourcompany.com", "subject": "Capgo Deployment Status", "body": "Deployment of '$BITBUCKET_BRANCH' completed with status: '$BITBUCKET_EXIT_CODE'" }' \ $EMAIL_SERVICE_URL condition: result: [successful, failed]Pengaturan Perbaikan
Judul bagian “Pengaturan Perbaikan”Masalah Umum
Judul bagian “Masalah Umum”Pipelain gagal dengan “Capgo CLI tidak ditemukan”:
# Debug CLI installation- step: name: Debug CLI script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --versionMasalah Autentikasi:
# Verify token configuration- step: name: Debug Auth script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"Arsip bangunan tidak ditemukan:
# List build outputs- step: name: Debug Build script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"Pipeliner Debug
Judul Bagian “Pipeliner Debug”Tambahkan informasi debugging untuk menyelesaikan masalah:
# Debug pipelinepipelines: branches: main: - step: name: Debug Information script: - echo "Branch: $BITBUCKET_BRANCH" - echo "Commit: $BITBUCKET_COMMIT" - echo "Build: $BITBUCKET_BUILD_NUMBER" - env | grep BITBUCKET_ | sort - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionValidasi Pipeliner
Judul Bagian “Validasi Pipeliner”Aktifkan validasi pipeliner untuk menangkap kesalahan konfigurasi:
# Enable pipeline validationoptions: docker: true size: 2x
pipelines: branches: main: - step: name: Validate Pipeline script: - echo "Pipeline validation successful" - step: name: Build and Deploy script: # ... deployment stepsLangkah-Langkah Selanjutnya
Judul Bagian “Langkah-Langkah Selanjutnya”- Pelajari tentang Saluran untuk mengelola berbagai lingkungan pengiriman
- Explore Penyimpanan Kustom untuk skenario pengiriman lanjutan
- Set up Enkripsi untuk pengiriman yang aman
- Konfigurasi Pengaturan Pembaruan untuk mengatur cara pembaruan diterapkan
Dengan integrasi Bitbucket Pipelines, Anda dapat mengotomatisasi Capgo pengiriman Anda dan memastikan pembaruan yang konsisten dan dapat diandalkan untuk pengguna aplikasi seluler Anda.