I set up Firebase Crashlytics according to Get started with Firebase Crashlytics for my Android app (using Android studio 3.1.3). On my own device as well as on the Emulator, everything works fine and my crashes appear correctly within the Firebase Console. So far so good.
However, there was a crash for one of my app users that was unexpected:
java.lang.IllegalStateException: Must Initialize Fabric before using singleton()
The exception was thrown in another Activity than the MainActivity.
I am aware that you could manually execute the initialization as described here by calling Fabric.with(this, new Crashlytics());
However, there is nothing said about one has to manually initialize the Crashlytics in the Getting Started article mentioned above. I was expecting this is done automatically since all my own tests run fine. So why is it that for some users Crashlytics is set up correctly and for some not?
You need to initialize Crashlytics in your application's onCreate
import android.app.Application;
import com.crashlytics.android.Crashlytics;
import io.fabric.sdk.android.Fabric;
public class TestApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
Fabric.with(this, new Crashlytics());
}
}
When you are using Firebase Crashlytics, you don't need to do any Fabric initialization. Everything is done automatically.
But if you want to do any custom logging, via (for example) Crashlytics.log("Custom log")
, you need to have FirebaseCrashlytics enabled in your manifest. Check the manifest if you have something like that:
<meta-data
android:name="firebase_crashlytics_collection_enabled"
android:value="${crashlyticsEnabled}" />
${crashlyticsEnabled}
can be set to true
or false
or via you app level build.gradle. This is typically used to disable Firebase Crashlytics when you are debugging the app.
If you used android:process
, then automatic initialization wouldn't work because it works by using a content provider in your manifest. In that case, you'll have to manually initialize Crashlytics.
In my case, The below checks helped to get rid of the error.
If you find code like below in your manifest, set it to true or remove it since it's true by default.
<meta-data
android:name="firebase_crashlytics_collection_enabled"
android:value="false" />
Also incase if the value is being pulled in from your build.gradle, check which buildType its in and consider not invoking any Crashlytics functions under that buildType.
Example:
build.gradle
android{
...
buildTypes {
debug{
manifestPlaceholders = [enableCrashReporting:"false"]
}
release {
manifestPlaceholders = [enableCrashReporting:"true"]
}
}
}
In this case you should have your Crashlytics calls wrapped like this -
if(!BuildConfig.DEBUG){
...
Crashlytics.setUserIdentifier(...)
...
}