Setiap tim pengembang mobile pasti merasakan sakit: fitur sudah siap untuk dinilai, tapi untuk memasukkannya ke tangan stakeholders berarti harus menavigasi labirin pengujian TestFlight atau Google Play beta. Apa yang seharusnya memakan waktu menit-menit berubah menjadi jam-jam menunggu, menginstal, dan mengelola build beta.
Apa jika aplikasi produksi Anda dapat menarik perubahan terbaru dari setiap permintaan pull secara langsung ke perangkat, tanpa ada penginstalan ulang atau gangguan toko aplikasi?
Itu adalah PR Pratinjau mengaktifkan. Ketika seorang pengembang membuka permintaan pull, sebuah GitHub Action menciptakan saluran pembaruan khusus dan menerbitkan perubahan-perubahan tersebut. Siapa pun yang memiliki aplikasi terpasang dapat beralih ke saluran tersebut, menguji fitur, dan kembali - semua tanpa meninggalkan aplikasi yang sudah mereka miliki.
Masalah TestFlight
Alur kerja tradisional untuk menguji fitur mobile tampak seperti ini:
- Pengembang membuka PR - Code siap untuk tinjauan
- Tunggu TestFlight - 15-30 menit waktu pengolahan
- Cari dan instal - Tester mencari build yang tepat
- Uji dan ulangi - Setiap perubahan berarti menunggu lagi
Hal ini menciptakan bottleneck. QA terblokir menunggu build. Manajer produk tidak dapat memverifikasi fitur dengan cepat. Pengembang kehilangan konteks sambil menunggu umpan balik. Industri memperkirakan biaya ini sekitar $340 per PR dalam produktivitas yang hilang.
Bagaimana PR Previews Bekerja
PR previews menggunakan sistem kanal Capgo untuk membuat aliran pembaruan per-PR. Berikut adalah alurannya:
- PR dibuka atau diperbarui - Aksi GitHub diaktifkan
- Bundle diunggah - Perubahan JS/CSS Anda dikirim ke kanal PR khusus
- Komentar diposting - Tester mendapatkan instruksi di PR
- Pengujian instan - Ganti kanal, lakukan pengujian, ganti kembali
Tidak ada instalasi aplikasi baru. Tidak ada penundaan TestFlight. Aplikasi produksi yang sama dapat mengambil dari kanal pembaruan yang berbeda.
Mengatur PR Previews
Sebelum Anda dapat menerapkan pratinjau PR, proyek Anda harus dikonfigurasi dengan Capgo Live Updates. Ikuti panduan cepat Capgo jika Anda belum melakukannya. Capgo panduan cepat __CAPGO_KEEP_0__
GitHub Workflow Aksi
Buat .github/workflows/pr-preview.yml:
name: PR Preview
on:
pull_request:
types: [opened, synchronize]
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- name: Setup Bun
uses: oven-sh/setup-bun@v2
- name: Install Dependencies
run: bun install
- name: Build
run: bun run build
# Create a channel named after your PR (may already exist on synchronize)
- name: Create PR Channel
id: create_channel
continue-on-error: true
run: bunx @capgo/cli@latest channel add pr-${{ github.event.pull_request.number }} --self-assign
env:
CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
# Upload the build to that channel
- name: Upload to Capgo
run: bunx @capgo/cli@latest bundle upload --channel pr-${{ github.event.pull_request.number }}
env:
CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
# Post a comment with testing instructions (only on PR open)
- name: Comment on PR
if: github.event.action == 'opened'
uses: actions/github-script@v7
with:
script: |
github.rest.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: ${{ github.event.pull_request.number }},
body: '📱 **Test this PR on device:**\n\nOpen your app and switch to channel: `pr-${{ github.event.pull_request.number }}`\n\nUse the shake menu or call `setChannel()` from your app.'
})
Kunci adalah flag ketika membuat saluran. Ini memungkinkan tester untuk beralih ke saluran dari dalam aplikasi menggunakan __CAPGO_KEEP_0__. --self-assign Mengatur Token __CAPGO_KEEP_0__ setChannel() Lihat ke halaman API Anda
Navigasikan ke Pengaturan > Capgo Kunci
- Panduan Cepat __CAPGO_KEEP_0__ Workflow Aksi Capgo
- Navigate to Settings > API Keys
- Buat kunci baru dengan
allizin - Tambahkan sebagai
CAPGO_TOKENdi repositori rahasia GitHub Anda
Bagaimana Tester Mengganti Saluran
Ada dua cara bagi tester untuk berganti ke saluran PR:
Pilihan 1: Menu Guncang (Paling Sederhana)
Aktifkan menu guncang dengan pilihan saluran di konfigurasi Capacitor Anda:
// capacitor.config.ts
const config: CapacitorConfig = {
// ... your other config
plugins: {
CapacitorUpdater: {
shakeMenu: true,
allowShakeChannelSelector: true
}
}
};
Tester mengguncang perangkat mereka untuk membuka menu debug, yang menampilkan daftar saluran yang tersedia dengan bar pencarian. Mereka menemukan saluran PR mereka (misalnya, pr-123)
mengetuk untuk memilihnya, dan aplikasi secara otomatis mengunduh dan menerapkan update. Ketika selesai melakukan tes, mereka mengguncang lagi dan berganti ke produksi.
- Menu guncang menghandle alur seluruhnya secara otomatis:
listChannels() - Menampilkan saluran dengan pencarian untuk menemukan PR spesifik
- Mengunduh pembaruan setelah pemilihan
- Mengajak untuk memulai ulang dengan pilihan “Mulai Ulang Sekarang” / “Nanti”
Pilihan 2: Pilih Saluran yang Dikustomkan
Buat pengubah saluran ke dalam aplikasi Anda yang menampilkan saluran PR yang tersedia dan memungkinkan tester memilih salah satu. Ini menggunakan dua API utama:
listChannels()- Mengambil semua saluran dengan pengaturan self assignment diaktifkansetChannel()- Mengubah perangkat ke saluran yang dipilih
import { CapacitorUpdater } from '@capgo/capacitor-updater';
// Get all available channels (including PR channels)
async function getAvailableChannels() {
const { channels } = await CapacitorUpdater.listChannels();
// Filter to show only PR channels
const prChannels = channels.filter(c => c.name.startsWith('pr-'));
return prChannels;
}
// Switch to a specific PR channel
async function switchToChannel(channelName: string) {
await CapacitorUpdater.setChannel({
channel: channelName,
triggerAutoUpdate: true // Immediately check for updates
});
}
// Return to production
async function switchBackToProduction() {
await CapacitorUpdater.unsetChannel({});
}
// Get current channel
async function getCurrentChannel() {
const { channel } = await CapacitorUpdater.getChannel();
return channel;
}
Dengan blok bangunan ini, Anda dapat membuat UI sederhana:
// Example: List PR channels and let user select
const channels = await getAvailableChannels();
const current = await getCurrentChannel();
// Display channels in your UI
channels.forEach(channel => {
console.log(`${channel.name} ${channel.name === current ? '(current)' : ''}`);
});
// When user selects a channel
await switchToChannel('pr-123');
Untuk contoh komponen React yang lengkap, lihat artikel surfing saluran kami.
Membersihkan Saluran PR
Ketika PR disatukan atau ditutup, Anda ingin membersihkan saluran. Tambahkan workflow lain:
name: Cleanup PR Preview
on:
pull_request:
types: [closed]
jobs:
cleanup:
runs-on: ubuntu-latest
steps:
- name: Delete PR Channel
run: bunx @capgo/cli@latest channel delete pr-${{ github.event.pull_request.number }}
env:
CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
Menghapus saluran ketika PR ditutup, menjaga daftar saluran Anda tetap bersih.
Kemampuan Versi
Penglihatan PR hanya berfungsi ketika bundle JavaScript kompatibel dengan versi native yang terinstal. Jika PR Anda termasuk perubahan native code (plugin baru Capacitor, modifikasi iOS/Android), tester akan memerlukan build native baru.
Capgo secara otomatis memeriksa kemampuan versi. Jika bundle PR sasaran versi native yang berbeda dengan yang terinstal, update tidak akan diterapkan. Ini mencegah crash dari code yang tidak kompatibel.
Untuk PR yang memerlukan perubahan native, Anda perlu mendistribusikan build TestFlight/Play Store baru. Penglihatan PR berfungsi terbaik untuk perubahan JavaScript, CSS, dan asset yang tidak menyentuh native code.
Siapa yang Manfaat dari Penglihatan PR
Insinyur QA
- Menguji fitur secara langsung ketika PR dibuka
- Mengganti antara PR yang berbeda tanpa harus menginstal ulang
- Mengverifikasi perbaikan dan regresi pada perangkat nyata
- Tidak perlu menunggu proses TestFlight lagi
Manajer Produk
- Ulasan fitur sebelum mereka diintegrasikan
- Berikan umpan balik langsung pada PR
- Pastikan implementasi sesuai dengan spesifikasi
- Mengurangi waktu siklus tinjauan
Para Pengembang
- Dapatkan umpan balik yang lebih cepat atas perubahan
- Tunjukkan fitur-fitur kepada stakeholders secara instan
- Debug masalah dengan pengguna tertentu
- Gunakan waktu yang lebih sedikit untuk mengelola versi beta
Perbandingan: Tradisional vs Previews PR
| Aspek | TestFlight/Beta | Pratinjau PR Capgo |
|---|---|---|
| Waktu pembangunan | 15-30 menit | < 1 menit |
| Berpindah PR | 5+ menit reinstall | 10 detik |
| Kemudahan pengaturan | Kredensial App Store | Satu file aliran |
| Pembersihan | Menggunakan tangan | Otomatis |
| Perubahan code native secara otomatis | Diperlukan | Diperbolehkan (hanya JS) |
Praktik Terbaik
- Berikan nama saluran dengan jelas: Gunakan
pr-{number}konvensi untuk identifikasi yang mudah - Pembersihan Otomatis: Selalu hapus saluran ketika PR ditutup
- Batasi Akses: Hanya aktifkan menu shake pada build debug/staging
- Dokumentasikan proses: Tambahkan instruksi pengujian ke template PR Anda
- Tangani kegagalan dengan sopan: Pastikan pembuatan channel berhasil sebelum mengirim komentar
Kapan Tidak Menggunakan Pratinjau PR
Pratinjau PR adalah untuk perubahan JavaScript/CSS. Jika PR Anda termasuk:
- Plugin baru Capacitor
- Perubahan native iOS code
- Perubahan native Android code
- Pembaruan dependensi yang mempengaruhi build native
Anda akan membutuhkan distribusi TestFlight/Play Store tradisional untuk perubahan-perubahan tersebut.
Menggabungkan dengan Channel Surfing
PR pra-previews bekerja paling baik ketika dikombinasikan dengan mencari saluran TV. Aplikasi Anda dapat memiliki:
production- Rilis stabil untuk semua penggunabeta- Akses awal untuk pengguna yang mendaftarpr-123- Pra-rilis fitur untuk PR tertentu
Pengujian dengan build produksi dapat beralih ke saluran PR mana saja, menguji fitur, kemudian kembali - semua dengan aplikasi yang terpasang yang sama.
Sumber Daya
- Capgo Live Updates Dokumentasi
- Channels Dokumentasi
- Panduan Surfing Saluran
- CLI Referensi Perintah
- Halaman Pratinjau PR
Kesimpulan
Pratinjau PR mengubah cara tim Anda melakukan tinjauan dan tes fitur mobile. Sebaliknya, Anda tidak perlu menunggu proses TestFlight dan mengelola beberapa versi beta, tester dapat beralih ke saluran PR mana saja dalam beberapa detik menggunakan aplikasi yang sudah terinstal.
Pengaturan minimal - satu file kerja Actions GitHub - dan manfaatnya berkumpul di seluruh tim. QA tetap tidak terblokir, manajer produk melakukan tinjauan lebih cepat, dan pengembang mendapatkan feedback lebih cepat.
Mulai dengan menambahkan kerjaan workflow ke satu repositori dan lihat bagaimana hal itu mengubah proses tinjauan Anda.