Zum Inhalt springen

Breaking Changes

Diese Dokumentation erklärt, wie Sie bei Änderungen in Ihrer App mit kanalverteilten Versionen umgehen können. Diese Vorgehensweise ermöglicht es Ihnen, verschiedene Versionen Ihrer App zu pflegen, während sichergestellt wird, dass Benutzer kompatible Updates erhalten.

Lassen Sie uns sagen, Sie haben:

  • App-Version 1.2.3 (alte Version) - verwendet Produktionskanal
  • App-Version 2.0.0 (neue Version mit Änderungen, die den Kompatibilität gefährden) - verwendet Kanal v2
  • Live update 1.2.4 (kompatibel mit 1.2.3)
  • Live update 2.0.1 (kompatibel mit 2.0.0)

Strategie: Immer den defaultChannel für Hauptversionen verwenden

Sektion: Strategie: Immer den defaultChannel für Hauptversionen verwenden

Empfehlung: Einen defaultChannel pro jede Hauptversion. Dies stellt sicher, dass Sie immer Updates an bestimmte Benutzergruppen pushen können, ohne sich auf die dynamische Kanalzuweisung zu verlassen.

// Version 1.x releases
defaultChannel: 'v1'
// Version 2.x releases
defaultChannel: 'v2'
// Version 3.x releases (future)
defaultChannel: 'v3'
Terminal-Fenster
# Create channel for version 2.x
npx @capgo/cli channel create v2

Aktualisieren Sie Ihre Capacitor-Konfiguration, bevor Sie Version 2.0.0 für den App Store erstellen:

capacitor.config.ts
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'Example App',
plugins: {
CapacitorUpdater: {
// ... other options
defaultChannel: 'v2' // All 2.0.0 users will use v2 channel
}
}
};
export default config;

Erstellen Sie separate Git-Branches, um die Kompatibilität zwischen Anwendungsversionen aufrechtzuerhalten:

Fenster des Terminalfensters
# Create and maintain a branch for version 1.x updates
git checkout -b v1-maintenance
git push origin v1-maintenance
# Your main branch continues with version 2.x development
git checkout main

Wichtig: Nie JavaScript-Bundles an ältere Apps pushen, die native code/APIs erwarten, die sie nicht haben. Bauen Sie immer Updates von dem entsprechenden Branch ab:

  • Branch für Updates von 1.x-Anwendungen (Produktionskanal)Branch für Updates von 2.x-Anwendungen (v2-Kanal)
  • 4. Hochladen von Bundles in den entsprechenden KanälenAbschnitt mit dem Titel “4. Hochladen von Bundles in den entsprechenden Kanälen”
Terminalfenster
# For 1.x updates: Build from v1-maintenance branch
git checkout v1-maintenance
# Make your 1.x compatible changes here
npx @capgo/cli bundle upload --channel production
# For 2.x updates: Build from main branch
git checkout main
# Make your 2.x changes here
npx @capgo/cli bundle upload --channel v2
Terminalfenster
# Allow apps to self-assign to v2 channel
npx @capgo/cli channel set v2 --self-assign

Version 2.0.0 zum App Store bereitstellen. Alle Benutzer, die diese Version herunterladen (ob neue Benutzer oder bestehende Benutzer, die aktualisieren), werden automatisch die v2-Kanal verwenden, da dies im App-Bundle konfiguriert ist.

Wenn Sie Version 3.0.0 mit mehreren Bruchänderungen veröffentlichen:

Terminal-Fenster
# Create channel for version 3.x
npx @capgo/cli channel create v3
// capacitor.config.ts for version 3.0.0
const config: CapacitorConfig = {
// ...
plugins: {
CapacitorUpdater: {
defaultChannel: 'v3' // Version 3.x users
}
}
};

Jetzt können Sie Updates für jede Version pushen:

  • production Kanal → Version 1.x-Benutzer
  • v2 Kanal → Version 2.x-Benutzer
  • v3 Kanal → Version 3.x-Benutzer

Nachdem alle Benutzer auf Version 2.x migriert sind (ca. 3-4 Monate):

  1. Löschen defaultChannel aus Ihrem Capacitor-Konfiguration
  2. Löschen des v2-Kanals:
Terminal-Fenster
npx @capgo/cli channel delete v2
  1. Löschen des v1-Maintenance-Zweigs:
Terminal-Fenster
git branch -d v1-maintenance
git push origin --delete v1-maintenance

Jedes Update sollte sorgfältig in jedem Kanal getestet werden, bevor es veröffentlicht wird

Um Updates zu versenden, die mit Version 1.x kompatibel sind:

  1. Zum v1-Wartungsbranch wechseln:
Terminalfenster
git checkout v1-maintenance
  1. Machen Sie Ihre Änderungen und committen Sie:
Terminalfenster
# Make 1.x compatible changes
git add .
git commit -m "Fix for v1.x"
git push origin v1-maintenance
  1. Erstellen und hochladen Sie in den Produktionskanal:
Terminalfenster
npx @capgo/cli bundle upload --channel production

Wenn Sie Breaking Changes um das Kanalrouting und die rollierende Veröffentlichung zu planen, verbinden Sie es mit Kanäle für die Implementierungsdetails in Kanälen, Kanäle für die Implementierungsdetails in Kanälen, Kanäle für die Implementierungsdetails in Kanälen, Beta-Testlösung für den Produktworkflow in der Beta-Testlösung, und Versionziel-Lösung für den Produktworkflow in der Versionziel-Lösung.