Lompat ke konten

Perubahan Break

Dokumentasi ini menjelaskan cara mengatasi perubahan yang memecah dalam aplikasi Anda menggunakan saluran versi. Pendekatan ini memungkinkan Anda untuk menjaga versi aplikasi yang berbeda sambil memastikan pengguna menerima pembaruan yang kompatibel.

Bayangkan Anda memiliki:

  • Aplikasi versi 1.2.3 (versi lama) - menggunakan saluran produksi
  • Versi aplikasi 2.0.0 (versi baru dengan perubahan yang mengganggu) - menggunakan saluran v2
  • Pembaruan hidup 1.2.4 (kompatibel dengan 1.2.3)
  • Pembaruan hidup 2.0.1 (kompatibel dengan 2.0.0)

Strategi: Selalu Gunakan defaultChannel untuk Versi Utama

Judul Bagian: Strategi: Selalu Gunakan defaultChannel untuk Versi Utama

Saran yang disarankan: Tetapkan defaultChannel untuk setiap versi utama. Dengan demikian, Anda dapat selalu memperbarui aplikasi untuk kelompok pengguna tertentu tanpa bergantung pada penugasan saluran dinamis.

// Version 1.x releases
defaultChannel: 'v1'
// Version 2.x releases
defaultChannel: 'v2'
// Version 3.x releases (future)
defaultChannel: 'v3'
Jendela Terminal
# Create channel for version 2.x
npx @capgo/cli channel create v2

2. Perbarui Capacitor Konfigurasi untuk Versi 2.0.0

Judul Bagian: “2. Perbarui Capacitor Konfigurasi untuk Versi 2.0.0”

Perbarui konfigurasi Capacitor Anda sebelum membangun versi 2.0.0 untuk toko aplikasi:

capacitor.config.ts
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'Example App',
plugins: {
CapacitorUpdater: {
// ... other options
defaultChannel: 'v2' // All 2.0.0 users will use v2 channel
}
}
};
export default config;

Buat cabang git terpisah untuk menjaga konsistensi antara versi aplikasi:

Jendela Terminal
# Create and maintain a branch for version 1.x updates
git checkout -b v1-maintenance
git push origin v1-maintenance
# Your main branch continues with version 2.x development
git checkout main

Kritis: Hindari selalu mengunggah bundle JavaScript ke aplikasi yang lebih tua yang mengharapkan code/API native yang tidak ada. Selalu bangun update dari cabang yang tepat:

  • cabang v1-maintenance: Untuk update ke aplikasi 1.x (saluran produksi)
  • cabang utama: Untuk update ke aplikasi 2.x (saluran v2)
Jendela Terminal
# For 1.x updates: Build from v1-maintenance branch
git checkout v1-maintenance
# Make your 1.x compatible changes here
npx @capgo/cli bundle upload --channel production
# For 2.x updates: Build from main branch
git checkout main
# Make your 2.x changes here
npx @capgo/cli bundle upload --channel v2
Jendela Terminal
# Allow apps to self-assign to v2 channel
npx @capgo/cli channel set v2 --self-assign

Rilis dan rilis versi 2.0.0 ke toko aplikasi. Semua pengguna yang mengunduh versi ini (baik pengguna baru maupun pengguna yang sudah ada yang mengupgrade) akan secara otomatis menggunakan saluran v2 karena sudah diatur dalam paket aplikasi.

Ketika Anda merilis versi 3.0.0 dengan perubahan yang lebih berisiko:

Jendela terminal
# Create channel for version 3.x
npx @capgo/cli channel create v3
// capacitor.config.ts for version 3.0.0
const config: CapacitorConfig = {
// ...
plugins: {
CapacitorUpdater: {
defaultChannel: 'v3' // Version 3.x users
}
}
};

Sekarang Anda dapat memperbarui versi apa pun:

  • production saluran → Pengguna versi 1.x
  • v2 saluran → Pengguna versi 2.x
  • v3 saluran → Pengguna Versi 3.x

Setelah semua pengguna telah bermigrasi ke versi 2.x (hitung 3-4 bulan):

  1. Hapus defaultChannel dari konfigurasi Capacitor Anda
  2. Hapus saluran v2:
Jendela Terminal
npx @capgo/cli channel delete v2
  1. Hapus cabang v1-maintenance:
Jendela Terminal
git branch -d v1-maintenance
git push origin --delete v1-maintenance

Selalu tes pembaruan secara menyeluruh di setiap saluran sebelum di-deploy

Mengelola Pembaruan Versi 1.x

Mengelola Pembaruan Versi 1.x

Untuk mengirim pembaruan yang kompatibel dengan versi 1.x:

  1. Pindah ke cabang v1-maintenance:
Terminal
git checkout v1-maintenance
  1. Buat perubahan Anda dan commit:
Jendela terminal
# Make 1.x compatible changes
git add .
git commit -m "Fix for v1.x"
git push origin v1-maintenance
  1. Buat dan unggah ke saluran produksi:
Jendela terminal
npx @capgo/cli bundle upload --channel production

Jika Anda menggunakan Perubahan Perubahan untuk merencanakan routing saluran dan peluncuran tahap, hubungkannya dengan Saluran untuk detail implementasi di Saluran, Saluran untuk detail implementasi di Saluran, Saluran untuk detail implementasi di Saluran, Solusi Pengujian Beta untuk alur kerja produk di Solusi Pengujian Beta, dan Solusi Target Versi untuk alur produk dalam Solusi Targeting Versi.