Setiap tim pengembang mobile telah merasakan sakitnya: fitur sudah siap untuk tinjauan, tapi untuk mendapatkannya ke tangan stakeholders berarti menavigasi labirin tinjauan TestFlight atau Google Play. 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 instalasi ulang atau gangguan toko aplikasi?
Itu adalah apa Pratinjau PR mengizinkan. Ketika seorang pengembang membuka permintaan pull, sebuah GitHub Action menciptakan saluran update khusus dan menerbitkan perubahan. Siapa pun yang telah menginstal aplikasi dapat beralih ke saluran tersebut, menguji fitur, dan kembali - semua tanpa harus meninggalkan aplikasi yang sudah mereka miliki.
Masalah TestFlight
Alur kerja tradisional untuk menguji fitur mobile terlihat seperti ini:
- Developer 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 bisa memverifikasi fitur dengan cepat. Pengembang kehilangan konteks sambil menunggu feedback. Industri memperkirakan biaya ini sekitar $340 per PR dalam produktivitas yang hilang.
Bagaimana Cara Kerja PR Previews
PR previews menggunakan sistem kanal Capgo untuk membuat aliran update per-PR. Berikut adalah alurannya:
- PR dibuka atau diperbarui - GitHub Aksi trigger
- Bundle diunggah - Perubahan JS/CSS Anda masuk ke saluran PR khusus
- Komentar diposting - Tester mendapatkan instruksi di PR
- Pengujian instan - Ganti saluran, uji, ganti kembali
Tidak ada instalasi aplikasi baru. Tidak ada penundaan TestFlight. Aplikasi produksi yang sama dapat mengunduh dari saluran pembaruan yang berbeda.
Mengatur Pratinjau PR
Sebelum Anda dapat menerapkan pratinjau PR, proyek Anda harus dikonfigurasi dengan Capgo Live Updates. Ikuti panduan cepat Capgo Capgo quickstart guide Jika Anda belum melakukannya.
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 --self-assign flag ketika membuat saluran. Ini memungkinkan tester untuk beralih ke saluran dari dalam aplikasi menggunakan setChannel() API.
Mengatur Token Capgo
- Pergi ke dashboard Anda Capgo
- Navigasikan ke Pengaturan > Kunci API
- Buat kunci baru dengan
allizin - Tambahkan ke sebagai
CAPGO_TOKENdalam repositori rahasia GitHub Anda
Bagaimana Tester Mengganti Saluran
Ada dua cara bagi tester untuk mengganti 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 pembaruan. Ketika selesai melakukan tes, mereka mengguncang lagi dan kembali ke produksi.
Menu guncang menghandle seluruh alur secara otomatis:
- Mengambil semua saluran yang dapat di-assign sendiri melalui
listChannels() - Mengampilkan saluran dengan pencarian untuk menemukan PR tertentu
- Mengunduh pembaruan setelah pemilihan
- Prompt untuk memulai ulang dengan pilihan “Mulai Ulang Sekarang” / “Nanti”
Pilihan 2: Pemilih Saluran Custom
Buatlah 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 pengasosiasi sendiri 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-blok 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 lengkap, lihat artikel surfing saluran kami.
Menghapus Saluran PR
Ketika PR ditutup atau diintegrasikan, 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 }}
Ini menghapus saluran ketika PR ditutup, menjaga daftar saluran Anda tetap bersih.
Kompatibilitas Versi
PR hanya berfungsi jika bundle JavaScript kompatibel dengan versi native yang terinstal. Jika PR Anda termasuk perubahan native code (plugin baru Capacitor, modifikasi iOS/Android), tester memerlukan build native baru.
Capgo secara otomatis memeriksa kompatibilitas 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. PR preview berfungsi terbaik untuk perubahan JavaScript, CSS, dan asset yang tidak menyentuh native code.
Siapa yang Manfaat dari PR Previews
Pengembang QA
- Uji fitur secara langsung ketika PR dibuka
- Switch antara PR multiple tanpa harus menginstal ulang
- Verifikasi perbaikan dan regresi pada perangkat nyata
- Tidak perlu menunggu proses TestFlight
Pengelola Produk
- Uji fitur sebelumnya sebelum diintegrasikan
- Berikan feedback langsung pada PR
- Pastikan implementasi sesuai dengan persyaratan
- Mengurangi waktu siklus tinjauan
Pengembang
- Dapatkan umpan balik yang lebih cepat atas perubahan
- Tunjukkan fitur demo kepada stakeholders secara langsung
- Debug masalah dengan pengguna tertentu
- Menghabiskan waktu yang lebih sedikit untuk mengelola build beta
Perbandingan: Tradisional vs PR Previews
| Aspek | TestFlight/Beta | Capgo PR Preview |
|---|---|---|
| Waktu pembangunan | 15-30 menit | < 1 menit |
| Mengganti PRs | 5+ menit reinstall | 10 detik |
| Kompleksitas setup | Kredensial App Store | Satu file workflow |
| Pembersihan | Manual | Otomatis |
| Perubahan native code | Wajib | Opsional (JS hanya) |
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 di build debug/staging
- Dokumentasikan Proses: Tambahkan instruksi testing ke template PR Anda
- Menangani gagal dengan sopan: Pastikan pembuatan saluran berhasil sebelum memposting komentar
Kapan Tidak Menggunakan Pratinjau PR
Pratinjau PR digunakan untuk perubahan JavaScript/CSS. Jika PR Anda termasuk:
- Plugin baru Capacitor
- Perubahan native iOS code
- Perubahan native Android code
- Pembaruan dependensi yang mempengaruhi bangun native
Anda akan memerlukan distribusi tradisional TestFlight/Play Store untuk perubahan-perubahan tersebut.
Menggabungkan dengan Surfing Channel
Pratinjau PR bekerja dengan baik ketika digabungkan dengan surfing channel. Aplikasi Anda dapat memiliki:
production- Rilis stabil untuk semua penggunabeta- Akses awal untuk pengguna yang memilihpr-123- Pratinjau fitur untuk PR tertentu
Pengujian dengan build produksi dapat beralih ke saluran PR mana saja, menguji fitur, kemudian kembali - semua dengan aplikasi yang sama terpasang.
Sumber Daya
- Capgo Live Updates Dokumentasi
- Dokumentasi Saluran
- Petunjuk Berlayar Saluran
- CLI Referensi Perintah
- Halaman Solusi Pratinjau PR
Kesimpulan
PR pra-previews mengubah cara tim Anda memeriksa dan menguji fitur mobile. Sebaliknya, Anda tidak perlu menunggu proses TestFlight dan mengelola beberapa versi beta, tester dapat beralih ke mana-mana PR channel dalam beberapa detik menggunakan aplikasi yang sudah terpasang.
Setupnya minimal - satu file workflow GitHub Actions - dan manfaatnya berkembang secara berkelanjutan di tim Anda. QA tetap tidak terblokir, manajer produk memeriksa lebih cepat, dan pengembang mendapatkan feedback lebih cepat.
Mulai dengan menambahkan workflow ke satu repositori dan lihat bagaimana hal itu mengubah proses review Anda.
Teruskan dari Membuat Setiap Permintaan Pull Menjadi Pratinjau Instalasi
Jika Anda menggunakan Membuat Setiap Permintaan Pull Menjadi Pratinjau Instalasi untuk merencanakan routing kanal dan peluncuran tahap, hubungkannya dengan Saluran untuk detail implementasi di Saluran, Saluran untuk detail implementasi di Saluran, Saluran untuk detail implementasi di Channels, Solusi Pengujian Beta untuk alur produk di Solusi Pengujian Beta, dan Solusi Target Versi untuk alur produk di Solusi Target Versi.