Chaque équipe de développeurs mobiles a ressenti la douleur : une fonctionnalité est prête pour la revue, mais la faire passer aux mains des parties prenantes signifie naviguer dans le labyrinthe de TestFlight ou Google Play beta review. Ce qui devrait prendre des minutes tourne en heures d'attente, d'installation et de gestion de builds bêta.
Et si votre application de production pouvait récupérer les dernières modifications de n'importe quelle demande de fusion directement sur l'appareil, sans aucune réinstallation ou retard de l'App Store ?
C'est ce que les prévisualisations de demande de fusion permettent. Lorsqu'un développeur ouvre une demande de fusion, une GitHub Action crée un canal de mise à jour dédié et publie les modifications. N'importe qui avec l'application installée peut passer à ce canal, tester la fonctionnalité et revenir à la version précédente - tout cela sans quitter l'application qu'ils ont déjà.
Le problème de TestFlight
The workflow traditionnel pour tester les fonctionnalités mobiles ressemble à ceci :
- Le développeur ouvre une PR - Code est prêt à la revue
- Attendre TestFlight - 15-30 minutes de temps de traitement
- Trouvez et installez - Les testeurs recherchent la bonne build
- Testez et répétez - Chaque changement signifie une autre attente
Cela crée un goulet d'étranglement. Le QA est bloqué en attendant les builds. Les gestionnaires de produit ne peuvent pas vérifier rapidement les fonctionnalités. Les développeurs perdent de l'contexte en attendant les retours. L'industrie estime que cela coûte environ 340 $ par PR en productivité perdue.
Comment fonctionnent les prévisions de PR
Les prévisions de PR utilisent le système de canal de Capgo pour créer des flux d'actualisations par PR. Voici le flux :
- Une demande de tirage a été ouverte ou mise à jour - GitHub déclencheurs d'action
- Bundle téléchargé - Vos modifications JS/CSS sont envoyées à un canal spécifique à la demande de tirage
- Commentaire publié - Les testeurs reçoivent des instructions dans la demande de tirage
- Test instantané - Basculer entre les canaux, tester, basculer à nouveau
Aucune nouvelle installation d'application. Aucun retard de TestFlight. La même application de production peut récupérer des mises à jour de différents canaux.
Configuration des prévisualisations de demande de tirage
Avant de pouvoir mettre en œuvre les prévisualisations de demande de tirage, votre projet doit être configuré avec Capgo Mises à jour en direct. Suivez le guide de démarrage rapide de Capgo Avant de pouvoir mettre en œuvre les prévisualisations de demande de tirage, votre projet doit être configuré avec Capgo. Suivez le guide de démarrage rapide de Capgo Si vous n'avez pas déjà fait cela.
GitHub Flux de travail d'actions
Créer .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.'
})
La clé est le --self-assign flag lors de la création du canal. Cela permet aux testeurs de passer à ce canal à partir de l'application en utilisant le setChannel() API.
Configuration du jeton Capgo
- Allez dans votre Capgo tableau de bord
- Naviguez jusqu'à Paramètres > Clés API
- Générez une nouvelle clé avec
allpermissions - Ajoutez-le comme
CAPGO_TOKENdans vos secrets de votre référentiel GitHub
Comment les testeurs basculent les canaux
Il existe deux façons pour les testeurs de basculer vers un canal PR :
Option 1 : Menu de secousses (la plus simple)
Activez le menu de secousses avec sélection de canal dans votre Capacitor config :
// capacitor.config.ts
const config: CapacitorConfig = {
// ... your other config
plugins: {
CapacitorUpdater: {
shakeMenu: true,
allowShakeChannelSelector: true
}
}
};
Les testeurs secouent leur appareil pour ouvrir le menu de débogage, qui affiche une liste des canaux disponibles avec une barre de recherche. Ils trouvent leur canal PR (par exemple, pr-123), appuient dessus pour le sélectionner et l'application télécharge et applique automatiquement la mise à jour. Lorsqu'ils ont terminé les tests, ils secouent à nouveau et basculent vers la production.
Le menu de secousses gère l'ensemble de la flux automatiquement :
- Récupère tous les canaux auto-assignables via
listChannels() - Affiche les canaux avec recherche pour trouver des PR spécifiques
- Télécharge la mise à jour après sélection
- Prompts à recharger avec les options « Recharger maintenant » / « Plus tard »
Option 2 : Sélecteur de canal personnalisé
Construirez un sélecteur de canal dans votre application qui liste les canaux PR disponibles et permet aux testeurs de choisir un.
listChannels()Ces blocs de construction vous permettent de créer une interface utilisateur simple :setChannel()Pour un exemple de composant React complet, voir
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;
}
notre article sur la navigation de canaux
// 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');
Nettoyage des canaux PR Lorsqu'un PR est fusionné ou fermé, vous devrez nettoyer le canal. Ajoutez une autre workflow :.
Cela supprime le canal lorsque le PR est fermé, gardant ainsi votre liste de canaux propre.
Compatibilité de version
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 }}
__CAPGO_KEEP_0__
__CAPGO_KEEP_0__
PR previews ne fonctionnent que lorsque le bundle JavaScript est compatible avec la version native installée. Si votre PR inclut des modifications natives code (nouveaux plugins Capacitor, modifications iOS/Android), les testeurs auront besoin d'une nouvelle build native.
Capgo vérifie automatiquement la compatibilité de la version. Si un bundle de PR cible une version native différente de celle installée, l'update ne sera pas appliqué. Cela empêche les plantages dus à des code incompatibles.
Pour les PR qui nécessitent des modifications natives, vous devrez distribuer une nouvelle build TestFlight/Play Store. Les aperçus de PR fonctionnent mieux pour les modifications JavaScript, CSS et des assets qui ne touchent pas les modifications natives code.
Qui bénéficie des Aperçus de PR
Ingénieurs de test
- Testez les fonctionnalités immédiatement lorsque les PR sont ouverts
- Passer entre plusieurs PR sans réinstaller
- Vérifiez les corrections et les régressions sur des appareils réels
- Plus de temps d'attente pour le traitement TestFlight
Responsables de produit
- Révisez les fonctionnalités avant qu'elles soient fusionnées
- Faites des commentaires directement sur le PR
- Vérifiez que l'implémentation correspond aux exigences
- Réduisez le temps de revue
Développeurs
- Obtenez des retours rapides sur les modifications
- Démontrer les fonctionnalités aux parties prenantes instantanément
- Déboguer les problèmes avec des utilisateurs spécifiques
- Passer moins de temps à gérer les builds bêta
Comparaison : Traditionnel vs PR Prévisions
| Aspect | TestFlight/Bêta | Capgo Prévision PR |
|---|---|---|
| Temps de construction | 15-30 min | moins d'1 min |
| Passer les PRs | 5+ min de reinstallation | 10 secondes |
| Complexité de mise en place | Clés d'application Store | Un fichier de workflow |
| Nettoyage | Manuel | Automatique |
| Modifications natives code | Requis | Facultatif (JS uniquement) |
Meilleures Pratiques
- Nommer les canaux clairement: Utilisez
pr-{number}convention pour une identification facile - Nettoyage automatique: Supprimez toujours les canaux lorsque les PR se ferment
- Restreindre l'accès: Activez uniquement le menu de secousses dans les builds de débogage/étape
- Documenter le processus: Ajoutez des instructions de test à votre modèle de PR
- Gérer les échecs avec élégance: Vérifiez que la création de la chaîne réussit avant d'ajouter des commentaires
Quand ne pas utiliser les aperçus de PR
Les aperçus de PR sont pour les modifications JavaScript/CSS. Si votre PR inclut :
- Nouveaux Capacitor plugins
- Changements natifs iOS code
- Changements natifs Android code
- Mises à jour de dépendances qui affectent les builds natifs
Vous aurez besoin de la distribution traditionnelle TestFlight/Play Store pour ces changements.
Combinaison avec Channel Surfing
Les aperçus de PR fonctionnent le mieux lorsqu'ils sont combinés avec Channel Surfing. Votre application peut avoir :
production- Des versions stables pour tous les utilisateursbeta- Un accès anticipé pour les utilisateurs qui ont opté pour celapr-123- Des aperçus de fonctionnalités pour des PR spécifiques
Les testeurs avec des builds de production peuvent passer à n'importe quel canal PR, tester la fonctionnalité, puis revenir à - tout cela avec la même application installée.
Ressources
- Capgo Mises à jour en temps réel Documentation
- Documentation des canaux
- Guide de navigation entre les canaux
- CLI Référence des commandes
- Page de solutions pour les aperçus de PR
Conclusion
Les aperçus de PR transforment la façon dont votre équipe examine et test les fonctionnalités mobiles. Au lieu d'attendre le traitement de TestFlight et de gérer plusieurs versions bêta, les testeurs peuvent passer à n'importe quel canal de PR en quelques secondes à l'aide de l'application qu'ils ont déjà installée.
La mise en place est minimale - un fichier de flux de travail Actions GitHub - et les avantages s'accumulent au fil de votre équipe. La QA reste bloquée, les responsables de produit passent en revue plus rapidement et les développeurs obtiennent des retours plus rapides.
Commencez par ajouter le flux de travail à un seul dépôt et voyez comment cela change votre processus de revue.
Continuez de Turn Every Pull Request Into an Installable Preview
Si vous utilisez Turn Every Pull Request Into an Installable Preview pour planifier la mise en route des canaux et la mise en œuvre étalée, connectez-le avec Channels pour les détails d'implémentation dans Channels, Channels pour les détails d'implémentation dans Channels, Channels pour les détails d'implémentation dans les canaux, Solution de test bêta pour le flux de travail du produit dans la Solution de test bêta, et Solution de ciblage de version pour le flux de travail du produit dans la Solution de ciblage de version.