Passer au contenu principal
Tutoriel

Tour Chaque Demande de Fusion en une Prévisualisation Exécutable

Arrêtez d'attendre le traitement de TestFlight. Les prévisualisations de demande de fusion Capgo permettent aux équipes QA, PM et aux parties prenantes de tester les fonctionnalités sur des appareils réels en moins d'une minute.

Martin Donadieu

Martin Donadieu

Spécialiste du Marketing de Contenu

Tour Chaque Demande de Fusion en une Prévisualisation Exécutable

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 :

  1. Le développeur ouvre une PR - Code est prêt à la revue
  2. Attendre TestFlight - 15-30 minutes de temps de traitement
  3. Trouvez et installez - Les testeurs recherchent la bonne build
  4. 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 :

  1. Une demande de tirage a été ouverte ou mise à jour - GitHub déclencheurs d'action
  2. Bundle téléchargé - Vos modifications JS/CSS sont envoyées à un canal spécifique à la demande de tirage
  3. Commentaire publié - Les testeurs reçoivent des instructions dans la demande de tirage
  4. 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

  1. Allez dans votre Capgo tableau de bord
  2. Naviguez jusqu'à Paramètres > Clés API
  3. Générez une nouvelle clé avec all permissions
  4. Ajoutez-le comme CAPGO_TOKEN dans 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 :

  1. Récupère tous les canaux auto-assignables via listChannels()
  2. Affiche les canaux avec recherche pour trouver des PR spécifiques
  3. Télécharge la mise à jour après sélection
  4. 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

AspectTestFlight/BêtaCapgo Prévision PR
Temps de construction15-30 minmoins d'1 min
Passer les PRs5+ min de reinstallation10 secondes
Complexité de mise en placeClés d'application StoreUn fichier de workflow
NettoyageManuelAutomatique
Modifications natives codeRequisFacultatif (JS uniquement)

Meilleures Pratiques

  1. Nommer les canaux clairement: Utilisez pr-{number} convention pour une identification facile
  2. Nettoyage automatique: Supprimez toujours les canaux lorsque les PR se ferment
  3. Restreindre l'accès: Activez uniquement le menu de secousses dans les builds de débogage/étape
  4. Documenter le processus: Ajoutez des instructions de test à votre modèle de PR
  5. 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 utilisateurs
  • beta - Un accès anticipé pour les utilisateurs qui ont opté pour cela
  • pr-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

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.

Mises à jour en temps réel pour les applications Capacitor

Lorsqu'un bug de couche web est en direct, expédiez la correction par Capgo au lieu d'attendre des jours pour l'approbation de la boutique d'applications. Les utilisateurs obtiennent la mise à jour en arrière-plan tandis que les modifications natives restent dans le chemin de revue normal.

Démarrer Maintenant

Dernières Nouvelles de notre Blog

Capgo vous donne les meilleures informations dont vous avez besoin pour créer une application mobile véritablement professionnelle.