Saltare al contenuto

Risolvere i problemi

Soluzioni per problemi comuni quando si costruiscono app native con Capgo Cloud Build.

Sintomi:

  • Il caricamento del progetto fallisce
  • Error di timeout dopo 60 secondi

Soluzioni:

  1. Controlla la tua connessione internet

    Finestra del terminale
    # Test connection to Capgo
    curl -I https://api.capgo.app
  2. Riduci la dimensione del progetto

    • Assicurati node_modules/ __CAPGO_KEEP_0__ non sta venendo caricato (dovrebbe essere escluso automaticamente)
    • Controlla i file grandi nel tuo progetto:
    Finestra del terminale
    find . -type f -size +10M
  3. Controlla la scadenza dell'URL di caricamento

    • Le URL di caricamento scadono dopo 1 ora
    • Se ricevi un errore di URL scaduto, esegui nuovamente il comando di costruzione

Sintomi:

  • La costruzione supera il tempo massimo consentito
  • Lo stato mostra timeout

Soluzioni:

  1. Optimizza le dipendenze

    • Elimina le dipendenze non utilizzate npm
    • Usa npm prune --production prima di costruire
  2. Verifica le problematiche di rete durante la costruzione

    • Alcune dipendenze possono scaricare file grandi durante la costruzione
    • Considera il pre-caching con un file di blocco
  3. Verifica le dipendenze native

    Finestra del terminale
    # iOS - check Podfile for heavy dependencies
    cat ios/App/Podfile
    # Android - check build.gradle
    cat android/app/build.gradle
  4. Contatta il supporto

    • If il tuo app ha effettivamente bisogno di più tempo
    • Potremmo regolare i limiti per casi d'uso specifici

Sintomi:

  • La costruzione fallisce immediatamente con un errore di autenticazione
  • Errori 401 o 403

Soluzioni:

  1. Verifica che la API chiave sia corretta

    Fenestra del terminale
    # Test with a simple command
    bunx @capgo/cli@latest app list
  2. Verifica le autorizzazioni della chiave API

    • La chiave deve avere write o all autorizzazioni
    • Verifica nella dashboard di Capgo sotto la sezione API Chiavi
  3. Assicurati che la chiave API stia venendo letta

    Finestra del terminale
    # Check environment variable
    echo $CAPGO_TOKEN
    # Or check your saved credentials file
    cat ~/.capgo-credentials/credentials.json # global
    cat .capgo-credentials.json # local (--local)
  4. Riaccredita

    Finestra del terminale
    bunx @capgo/cli@latest login

”App non trovata” o “Nessuna autorizzazione per questa app”

Sezione intitolata “”App non trovata” o “Nessuna autorizzazione per questa app””

Sintomi:

  • L'autenticazione funziona ma si verifica un errore specifico dell'app

Soluzioni:

  1. Verifica che l'app sia registrata

    Finestra del terminale
    bunx @capgo/cli@latest app list
  2. Verifica che l'ID dell'app corrisponda

    • Verifica capacitor.config.json appId
    • Assicurati che il comando utilizzi l'ID dell'app corretto
  3. Verifica l'accesso dell'organizzazione

    • Controlla di essere nella organizzazione corretta
    • API chiave deve avere accesso all'organizzazione dell'app

Sintomi:

  • La costruzione fallisce durante la fase di firma code
  • Errori di Xcode sui certificati o sui profili

Soluzioni:

  1. Verifica che il tipo di certificato corrisponda al tipo di costruzione

    • Costruiscono bisogno di certificati di sviluppo
    • Costruiscono bisogno di certificati di distribuzione
  2. Controlla che il certificato e il profilo corrispondano

    Fenestra del terminale
    # Decode and inspect your certificate
    echo $BUILD_CERTIFICATE_BASE64 | base64 -d > cert.p12
    openssl pkcs12 -in cert.p12 -nokeys -passin pass:$P12_PASSWORD | openssl x509 -noout -subject
  3. Assicurati che il profilo di provisioning sia valido

    • Controlla la data di scadenza
    • Verifica che includa il tuo ID App
    • Conferma che includa il certificato
  4. Regenera le credenziali

    • Cancella il vecchio certificato/profilo
    • Creane nuovi nel portale dello sviluppatore Apple
    • Ricodifica e aggiorna le variabili di ambiente

”Il profilo di provisioning non include il certificato di firma”

Sezione intitolata “”Il profilo di provisioning non include il certificato di firma””

Sintomi:

  • Xcode non riesce a trovare il certificato nel profilo

Soluzioni:

  1. Scarica il profilo più recente da Apple

    • Vai su Apple Developer → Certificati, ID e Profili
    • Scarica il profilo di provisioning
    • Assicurati che includa il tuo certificato
  2. Verifica che il certificato sia nel profilo

    Fenestra del terminale
    # Extract profile
    echo $BUILD_PROVISION_PROFILE_BASE64 | base64 -d > profile.mobileprovision
    # View profile contents
    security cms -D -i profile.mobileprovision
  3. Ricrea il profilo con il certificato corretto

    • In portallo dello sviluppatore Apple, modifica il profilo
    • Assicurati di aver selezionato il certificato di distribuzione
    • Scarica e ricodifica

Sintomi:

  • L'upload a TestFlight fallisce
  • Errori di chiave API

Soluzioni:

  1. Verifica le credenziali della chiave API

    • Controlla APPLE_KEY_ID (dovrebbe essere 10 caratteri)
    • Controlla APPLE_ISSUER_ID (formato UUID)
    • Verifica che APPLE_KEY_CONTENT sia correttamente codificato in base64
  2. Testa la chiave API localmente

    Fermata del terminale
    # Decode key
    echo $APPLE_KEY_CONTENT | base64 -d > AuthKey.p8
    # Test with fastlane (if installed)
    fastlane pilot list
  3. Controlla le autorizzazioni della chiave API

    • La chiave richiede il ruolo 'Developer' o superiore
    • Verifica in App Store Connect → Utenti e accessi → Chiavi
  4. Sicura che la chiave non sia revocata

    • Controlla in App Store Connect
    • Genera una nuova chiave se necessario

Sintomi:

  • L'installazione fallisce durante l'installazione di CocoaPods
  • Errori nel file Podfile

Soluzioni:

  1. Verifica che il file Podfile.lock sia stato commesso

    Finestra del terminale
    git status ios/App/Podfile.lock
  2. Testa l'installazione pod localmente

    Finestra del terminale
    cd ios/App
    pod install
  3. Controlla per eventuali pod incompatibili

    • Verifica Podfile per conflitti di versione
    • Assicurati che tutti i pod supportino il tuo target di distribuzione iOS
  4. Pulisci cache dei pod

    Finestra del terminale
    cd ios/App
    rm -rf Pods
    rm Podfile.lock
    pod install
    # Then commit new Podfile.lock

Sintomi:

  • La costruzione fallisce durante la firma
  • Error di Gradle sul keystore

Soluzioni:

  1. Verifica la password del keystore

    Finestra del terminale
    # Test keystore locally
    keytool -list -keystore my-release-key.keystore
    # Enter password when prompted
  2. Verifica le variabili di ambiente

    Finestra del terminale
    # Ensure no extra spaces or special characters
    echo "$KEYSTORE_STORE_PASSWORD" | cat -A
    echo "$KEYSTORE_KEY_PASSWORD" | cat -A
  3. Verifica l'encoding base64

    Finestra del terminale
    # Decode and test
    echo $ANDROID_KEYSTORE_FILE | base64 -d > test.keystore
    keytool -list -keystore test.keystore

Sintomi:

  • La firma fallisce con errore di alias

Soluzioni:

  1. Elenco degli alias del keystore

    Finestra del terminale
    keytool -list -keystore my-release-key.keystore
  2. Verifica che l'alias corrisponda esattamente

    • L'alias è case-sensitive
    • Controlla di non aver commesso errori di battitura in KEYSTORE_KEY_ALIAS
  3. Usa l'alias corretto dal keystore

    Finestra del terminale
    # Update environment variable to match
    export KEYSTORE_KEY_ALIAS="the-exact-alias-name"

Sintomi:

  • Errori di build Gradle generici
  • Problemi di compilazione o di dipendenze

Soluzioni:

  1. Testa prima il build locale

    Finestra del terminale
    cd android
    ./gradlew clean
    ./gradlew assembleRelease
  2. Controlla le dipendenze mancanti

    • Verifica i file build.gradle
    • Assicurarsi che tutti i plugin siano elencati nelle dipendenze
  3. Verificare la compatibilità della versione di Gradle

    Fermata del terminale
    # Check gradle version
    cat android/gradle/wrapper/gradle-wrapper.properties
  4. Pulisci cache di Gradle

    Fermata del terminale
    cd android
    ./gradlew clean
    rm -rf .gradle build

Sintomi:

  • La costruzione ha successo ma l'upload fallisce
  • Errori di account di servizio

Solutions:

  1. Verifica il file JSON dell'account di servizio

    Fermata del terminale
    # Decode and check format
    echo $PLAY_CONFIG_JSON | base64 -d | jq .
  2. Controlla le autorizzazioni dell'account di servizio

    • Vai a Console di gioco → Impostazioni → API Accesso
    • Assicurati che l'account di servizio abbia accesso all'app
    • Concedi la
  3. Rilascio ai percorsi di testing

    • autorizzazione
    • Verifica che l'app sia configurata nella Console di gioco
  4. Check API is enabled

    • Google Play Developer API deve essere abilitato
    • Verifica nel Console di Google Cloud

”Lavoro non trovato” o “Stato di costruzione non disponibile”

Sezione intitolata “”Lavoro non trovato” o “Stato di costruzione non disponibile””

Sintomi:

  • Non è possibile verificare lo stato di costruzione
  • Errori di ID di lavoro

Soluzioni:

  1. Aspetta un momento e riprova

    • I job di costruzione possono richiedere alcuni secondi per inizializzare
  2. Controlla che l'ID del lavoro sia corretto

    • Verifica l'ID del lavoro dalla risposta di costruzione iniziale
  3. Controlla che la costruzione non sia scaduta

    • Il dato di costruzione è disponibile per 24 ore

Sintomi:

  • La costruzione fallisce prima dell'avvio della compilazione
  • Errori di file mancanti

Soluzioni:

  1. Esegui Capacitor sincronizzazione localmente

    Fenestra del terminale
    bunx cap sync
  2. Assicurati che tutti i file nativi siano commessi

    Finestra del terminale
    git status ios/ android/
  3. Controlla i file nativi ignorati da Git

    • Revisiona .gitignore
    • Assicurati che i file di configurazione importanti non siano ignorati

Sintomi:

  • Il build mostra successo ma non c’è il link di download

Soluzioni:

  1. Verifica la configurazione di costruzione

    • Il magazzino degli artefatti potrebbe non essere configurato
    • Contatta il supporto se l'accesso agli artefatti non è disponibile per la tua costruzione
  2. Per la sottoscrizione di TestFlight per iOS

    • Verifica App Store Connect
    • Il processo potrebbe richiedere 5-30 minuti dopo l'upload
  3. Per la Play Store Android

    • Verifica Play Console → Testing → Test interni
    • Il processo potrebbe richiedere alcuni minuti

Sintomi:

  • bunx @capgo/cli@latest … fallisce in CI con “comando non trovato”

Soluzioni:

  1. Configura Bun prima di tutto così bunx è disponibile:

    - uses: oven-sh/setup-bun@v2
  2. Poi esegui il CLIbunx lo scarica a richiesta, non è necessaria l'installazione globale:

    - run: bunx @capgo/cli@latest build request com.example.app --platform android

Sintomi:

  • Variabili di ambiente vuote in fase di build

Soluzioni:

  1. Verifica che i segreti siano impostati

    • Vai ai repo Impostazioni → Segreti e variabili → Azioni
    • Aggiungi tutti i segreti richiesti
  2. Utilizza la sintassi corretta

    env:
    CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
  3. Controlla che i nomi dei segreti corrispondano

    • Il nome è case-sensitive
    • Assicurati di non avere errori di ortografia nelle referenze ai segreti
Finestra del terminale
# Add debug flag (when available)
bunx @capgo/cli@latest build request com.example.app --verbose

Quando si contatta il supporto, includere:

  1. Comando di costruzione utilizzato

    Finestra del terminale
    bunx @capgo/cli@latest build request com.example.app --platform ios
  2. Messaggio di errore (output completo)

  3. ID del lavoro (dal output di costruzione)

  4. Log di costruzione (copia l'output completo del terminale)

  5. Informazioni sull'ambiente

    Finestra del terminale
    node --version
    npm --version
    bunx @capgo/cli@latest --version

Limitazioni correnti:

  • Tempo di costruzione massimo: 10 minuti
  • Dimensione di caricamento massima: ~500MB
  • I build iOS richiedono leasing Mac di 24 ore, costruisci su Mac per garantire l'uso ottimale
  • La disponibilità del download degli artefatti di costruzione dipende dalla destinazione di costruzione e dalla configurazione di archiviazione degli artefatti

Queste limitazioni possono essere aggiustate in base alle risposte degli utenti.