Forcer un crash pour tester votre implémentation
Ajoutez du code à votre application que vous pouvez utiliser pour forcer un crash de test.
Vous pouvez utiliser le code suivant pour ajouter un bouton à votre application qui, lorsqu'il est enfoncé, provoque un crash. Le bouton est intitulé "Test Crash".
SwiftUI
Button("Crash") { fatalError("Crash was triggered") }
KitUI
Rapide
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. let button = UIButton(type: .roundedRect) button.frame = CGRect(x: 20, y: 50, width: 100, height: 30) button.setTitle("Test Crash", for: []) button.addTarget(self, action: #selector(self.crashButtonTapped(_:)), for: .touchUpInside) view.addSubview(button) } @IBAction func crashButtonTapped(_ sender: AnyObject) { let numbers = [0] let _ = numbers[1] } }
Objectif c
#import "ViewController.h" @implementation ViewController ‐ (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. UIButton* button = [UIButton buttonWithType:UIButtonTypeRoundedRect]; button.frame = CGRectMake(20, 50, 100, 30); [button setTitle:@"Test Crash" forState:UIControlStateNormal]; [button addTarget:self action:@selector(crashButtonTapped:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:button]; } ‐ (IBAction)crashButtonTapped:(id)sender { @[][1]; } @end
Créez et exécutez votre application dans Xcode avec le débogueur Xcode déconnecté.
Cliquez sur
Build, puis exécutez le schéma actuel pour créer votre application sur un appareil de test ou un simulateur.Attendez que votre application soit en cours d'exécution, puis cliquez sur
Arrêtez d'exécuter le schéma ou l'action pour fermer l'instance initiale de votre application. Cette instance initiale incluait le débogueur qui interfère avec Crashlytics.
Forcez le crash du test afin d'envoyer le premier rapport de crash de votre application :
Ouvrez votre application depuis l'écran d'accueil de votre appareil de test ou de votre simulateur.
Dans votre application, appuyez sur le bouton "Test Crash" que vous avez ajouté à l'aide du code ci-dessus.
Après le crash de votre application, exécutez-la à nouveau depuis Xcode afin que votre application puisse envoyer le rapport de crash à Firebase.
Accédez au tableau de bord Crashlytics de la console Firebase pour voir votre crash de test.
Si vous avez actualisé la console et que vous ne voyez toujours pas le crash du test après cinq minutes, essayez d'activer la journalisation du débogage (section suivante).
Activer la journalisation du débogage pour Crashlytics
Si vous ne voyez pas votre crash de test dans le tableau de bord Crashlytics, vous pouvez utiliser la journalisation de débogage pour Crashlytics pour vous aider à localiser le problème.
Activer la journalisation du débogage :
Dans Xcode, sélectionnez Produit > Schéma > Modifier le schéma .
Sélectionnez Exécuter dans le menu de gauche, puis sélectionnez l'onglet Arguments .
Dans la section Arguments transmis au lancement , ajoutez
-FIRDebugEnabled
.
Forcez un crash test. La première section de cette page décrit comment procéder.
Dans vos journaux, recherchez un message de journal de Crashlytics contenant la chaîne suivante, qui vérifie que votre application envoie des plantages à Firebase.
Completed report submission
Si vous ne voyez pas ce journal ou votre crash de test dans le tableau de bord Crashlytics de la console Firebase après cinq minutes, contactez l'assistance Firebase avec une copie de la sortie de votre journal afin que nous puissions vous aider à résoudre davantage le problème.
Prochaines étapes
- Personnalisez la configuration de votre rapport d'erreur en ajoutant des rapports opt-in, des journaux, des clés et un suivi des erreurs non fatales.