My FeedDiscussionsHashnode Enterprise
New
Sign in
Log inSign up
Learn more about Hashnode Headless CMSHashnode Headless CMS
Collaborate seamlessly with Hashnode Headless CMS for Enterprise.
Upgrade ✨Learn more
Firebase Crashlytics in React Native

Firebase Crashlytics in React Native

Umair Saleem's photo
Umair Saleem
·Sep 27, 2021·

3 min read

Applications that are buggy can make your user unhappy and they might uninstall your app. Apps can generate a lot of crashes and manually tracking them is time consuming. Firebase Crashlytics helps you in collecting these crashes, analyze them and organize the crash reports. It also helps in setting the priority of these crashes so you can fix them as per the priority. With Firebase Crashlytics you can see the crashes at a glance on a dashboard view.

Setup Firebase Project

Go To Firebase console and create a new project

https://console.firebase.google.com/

image.png

Write your project name, accept terms & conditions and click on continue

image.png

Choose your Google account and continue.

image.png

Install react-native dependencies for Firebase Crashlytics

Install the following react native firebase crashlytics dependencies

Install & set up the app module

yarn add @react-native-firebase/app

Install the Crashlytics module

yarn add @react-native-firebase/crashlytics

If you're developing your app using iOS, run this command

cd ios/ && pod install

Configure Android with Firebase

  1. Click on the android icon on the firebase dashboard to setup application Write your app name and register

image.png

  1. Download the google-services.json file and put it on your — projectname/android/app — folder.

image.png

  1. Add google-service dependency in your android/build.gradle file.

image.png

  1. Add firebase crashlytics plugin dependency in your android/build.gradle file.

image.png

  1. Apply the com.google.firebase.crashlytics plugin by adding the following to the top of your android/app/build.gradle file:

image.png

Once the above steps have been completed, rebuild your Android project: npx react-native run-android

Configure iOS with Firebase

  1. Click on the iOS icon on the firebase dashboard to setup application Write your app name and register

  2. Download the GoogleService-Info.plist file and move it into the root of your Xcode project and add it to all targets.

image.png

  1. Make sure to import firebase and firebase crashlytics module is imported in App.Delegate.m.
#import <Firebase.h>
#import <FirebaseCrashlytics.h>

Also, configure the firebase module in App.Delegate.m inside didFinishLaunchingWithOptions

 [FIRApp configure];

Time to see crashlytics in action

First, import the module into your file.

import crashlytics from '@react-native-firebase/crashlytics';

Now, crashlytics provide us several useful methods that we can use to track app errors easily.

log

We can use the log method throughout our app to accumulate extra context for possible crashes that can happen.

crashlytics().log('App mounted.');

image.png

Now move to the crashlytics window, under the events section you will see the log appearing.

image.png

crash

To test Crashlytics we can use the crash method to crash the app forcefully.

crashlytics().crash();

As an example, I have forcefully crashed my testing app on login method.

image.png

On login, my testing app crashed, firebase crashlytics collect this crash and will send this to the firebase console, so If I open my firebase console, under the crashlytics window I can see the crash reports.

image.png

image.png

image.png

recordError

With crashlytics, you can also send javascript stack traces to the firebase console to better know where a crash has happened in the stack tree.

crashlytics().log(''Updating user name");
try {
  if (name) {
    // The name property did not exist, so this code will crashed and you can see the error in console.
    setUserName(name);
  }
} catch (error) {
  crashlytics().recordError(error);
  console.log(error);
}

setCrashlyticsCollectionEnabled To stop collecting the crashlytics, we can use setCrashlyticsCollectionEnabled to disable the crashlytics.

crashlytics().setCrashlyticsCollectionEnabled(false)

References

rnfirebase.io rnfirebase.io/crashlytics/usage