Cada equipo de desarrollo móvil ha sentido el dolor: una característica está lista para la revisión, pero hacer que llegue a las manos de las partes interesadas significa navegar por el laberinto de revisión de TestFlight o Google Play beta. ¿Qué debería tomar minutos se convierte en horas de espera, instalación y gestión de versiones beta.
¿Y si tu aplicación de producción pudiera extraer los últimos cambios de cualquier solicitud de extracción directamente en el dispositivo, sin reinstalaciones ni retrasos en la tienda de aplicaciones?
Eso es lo que Vistas previas de PR enable. Cuando un desarrollador abre una solicitud de extracción, una acción GitHub crea un canal de actualización dedicado y publica los cambios. Cualquiera con la aplicación instalada puede cambiar a ese canal, probar la característica y cambiar de nuevo - todo sin dejar la aplicación que ya tienen.
El Problema de TestFlight
El flujo de trabajo tradicional para probar características móviles se parece a esto:
- Desarrollador abre PR - Code está listo para revisión
- Espera a TestFlight - 15-30 minutos de tiempo de procesamiento
- Encuentra e instala - Los probadores buscan la construcción correcta
- Prueba y repite - Cada cambio significa otra espera
Esto crea una botella de cuello. QA se bloquea esperando construcciones. Los gerentes de producto no pueden verificar características rápidamente. Los desarrolladores pierden contexto mientras esperan retroalimentación. La industria estima que esto cuesta alrededor de $340 por PR en productividad perdida.
Cómo Funcionan las Previsualizaciones de PR
Las previsualizaciones de PR utilizan el sistema de canales de Capgo para crear flujos de actualizaciones por PR. Aquí está el flujo:
- Se abre o se actualiza un PR - Se activa la acción de GitHub
- Se sube el paquete - Los cambios de JS/CSS se envían a un canal específico para el PR
- Se publica un comentario - Los probadores reciben instrucciones en el PR
- Pruebas instantáneas - Cambiar a un canal, probar, cambiar de nuevo
Sin nuevas instalaciones de aplicaciones. Sin retrasos de TestFlight. La misma aplicación de producción puede obtener actualizaciones de diferentes canales de actualización.
Configuración de Previsualizaciones de PR
Antes de que puedas implementar vistas previas de PR, tu proyecto necesita estar configurado con Capgo Actualizaciones en vivo. Sigue el Capgo guía de inicio rápido si no lo has hecho antes.
GitHub flujo de trabajo de acciones
Crear .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 clave es la --self-assign bandera cuando se crea el canal. Esto permite a los probadores cambiar al canal desde dentro de la aplicación utilizando el setChannel() API.
Configuración de Capgo Token
- Ve a tu Capgo panel de control
- Navega a Configuración > API Claves
- Genera una nueva clave con
allpermisos - Añádelo como
CAPGO_TOKENen tus secretos de repositorio GitHub
Cómo los probadores cambian de canal
Hay dos formas para que los probadores cambien a un canal de PR:
Opción 1: Menú de sacudida (Más sencillo)
Habilita el menú de sacudida con selector de canal en tu configuración Capacitor:
// capacitor.config.ts
const config: CapacitorConfig = {
// ... your other config
plugins: {
CapacitorUpdater: {
shakeMenu: true,
allowShakeChannelSelector: true
}
}
};
Los probadores sacuden su dispositivo para abrir el menú de depuración, que muestra una lista de canales disponibles con una barra de búsqueda. Encuentran su canal de PR (por ejemplo, pr-123tapan para seleccionarlo y la aplicación descarga y aplica automáticamente la actualización. Cuando terminen de probar, sacuden de nuevo y cambian a producción.
El menú de sacudida maneja el flujo completo automáticamente:
- Obtiene todos los canales autoasignables mediante
listChannels() - Muestra canales con búsqueda para encontrar PRs específicos
- Descarga la actualización después de la selección
- Pide recargar con opciones de “Recargar Ahora” / “Más Tarde”
Opción 2: Selector de Canales Personalizado
Construye un selector de canales en tu aplicación que enumere los canales de PR disponibles y permita a los probadores elegir uno. Esto utiliza dos APIs clave:
listChannels()- Obtiene todos los canales con autogestión habilitadasetChannel()- Cambia el dispositivo al canal seleccionado
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;
}
Con estos bloques de construcción, puedes crear una interfaz de usuario simple:
// 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');
Para un ejemplo completo de componente de React, consulta nuestro artículo sobre navegación de canales.
Limpiar Canales de PR
Cuando un PR se fusiona o cierra, querrás limpiar el canal. Agrega otro flujo de trabajo:
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 }}
Esto elimina el canal cuando se cierra la solicitud de extracción, manteniendo tu lista de canales limpia.
Compatibilidad de Versión
Las previsualizaciones de solicitudes de extracción solo funcionan cuando el paquete de JavaScript es compatible con la versión nativa instalada. Si tu solicitud de extracción incluye cambios nativos code (nuevos plugins Capacitor, modificaciones de iOS/Android), los probadores necesitarán una nueva compilación nativa.
Capgo verifica automáticamente la compatibilidad de versiones. Si el paquete de una solicitud de extracción apunta a una versión nativa diferente a la instalada, la actualización no se aplicará. Esto previene los errores de incompatibilidad code.
Para las solicitudes de extracción que requieren cambios nativos, necesitarás distribuir una nueva compilación de TestFlight/Play Store. Las previsualizaciones de solicitudes de extracción funcionan mejor para cambios de JavaScript, CSS y recursos que no tocan el code nativo.
¿Quién se beneficia de las previsualizaciones de solicitudes de extracción
Ingenieros de Pruebas de Calidad
- Verifica características de prueba inmediatamente cuando se abren las solicitudes de extracción
- Pasa entre múltiples solicitudes de extracción sin reinstalar
- Verifica arreglos y regresiones en dispositivos reales
- No más espera por el procesamiento de TestFlight
Gerentes de Producto
- Revisa características antes de que se fusionen
- Propor feedback directamente en la solicitud de revisión
- Verifica que la implementación coincide con los requisitos
- Reduce el tiempo de ciclo de revisión
Desarrolladores
- Obtén feedback más rápido sobre cambios
- Muestra características a partes interesadas de inmediato
- Depura problemas con usuarios específicos
- Pasa menos tiempo gestionando versiones beta
Comparación: Versión tradicional vs Previsualizaciones de solicitudes de revisión
| Aspecto | TestFlight/Beta | Capgo Vista de revisión |
|---|---|---|
| Tiempo de construcción | 15-30 min | Menos de 1 minuto |
| Cambiar entre PRs | 5+ minuto reinstalar | 10 segundos |
| Complejidad de configuración | Credenciales de la Tienda de Aplicaciones | Un archivo de flujo de trabajo |
| Limpiar | Manual | Automático |
| Cambios nativos code | Requerido | Opcional (solo JS) |
Prácticas recomendadas
- Nombra los canales de manera clara: Utilice
pr-{number}convención para una fácil identificación - Auto-borrado: Siempre elimine los canales cuando se cierren PRs
- Limitar acceso: Solo habilite el menú de sacudida en builds de depuración/producción
- Documentar el proceso: Agregar instrucciones de prueba a tu plantilla de PR
- Manejar fracasos con amabilidad: Verificar que la creación de canales tenga éxito antes de publicar comentarios
Cuándo No Usar Previsualizaciones de PR
Las previsualizaciones de PR están diseñadas para cambios en JavaScript/CSS. Si tu PR incluye:
- Nuevos Capacitor plugins
- Cambios nativos de iOS code
- Cambios nativos de Android code
- Actualizaciones de dependencias que afectan compilaciones nativas
Necesitarás distribución tradicional a través de TestFlight/Play Store para esos cambios.
Combina con Channel Surfing
Las pruebas de PR funcionan mejor cuando se combinan con surf de canalesSu aplicación puede tener:
production- Lanzamientos estables para todos los usuariosbeta- Acceso temprano para usuarios que optan por ellopr-123- Pruebas de características para PR específicos
Los probadores con compilaciones de producción pueden cambiar a cualquier canal de PR, probar la característica, luego cambiar de nuevo - todo con la misma aplicación instalada.
Recursos
- Capgo Actualizaciones en vivo Documentación
- Documentación de canales
- Guía de Surf de Canales
- CLI Referencia de Comandos
- Página de vista previa de PR
Conclusión
Las vistas previas de PR transforman la forma en que su equipo revisa y prueba características móviles. En lugar de esperar a que se procese TestFlight y gestionar múltiples versiones beta, los probadores pueden cambiar a cualquier canal de PR en segundos utilizando la aplicación que ya tienen instalada.
La configuración es mínima - un archivo de flujo de trabajo GitHub Actions - y los beneficios se acumulan en su equipo. La QA permanece sin bloqueos, los gerentes de producto revisan más rápido y los desarrolladores reciben retroalimentación más rápida.
Comience agregando el flujo de trabajo a un repositorio y vea cómo cambia su proceso de revisión.