---
description: Unofficial Capacitor plugin for Firebase Crashlytics SDK to report app crashes and non-fatal errors.
title: Capacitor Firebase Crashlytics Plugin for Android & iOS - Capawesome
image: https://capawesome.io/docs/assets/images/social/plugins/firebase/crashlytics.png
---

[ Skip to content](#capacitor-firebasecrashlytics) 

[ 🎉 Introducing **Capawesome Platform** — one platform for Live Updates, Native Builds, App Store Publishing, and Insider SDKs.](https://capawesome.io) 

* [  iOS ](#ios)
* [  Configuration ](#configuration)
* [  Demo ](#demo)
* [  Starter templates ](#starter-templates)
* [  Usage ](#usage)
* [  API ](#api)
* [  Type Aliases ](#type-aliases)
* [  Test your implementation ](#test-your-implementation)
* [  Changelog ](#changelog)
* [  License ](#license)
* [  Credits ](#credits)
* [  Cloud Firestore ](/docs/plugins/firebase/cloud-firestore/)
* [  Cloud Functions ](/docs/plugins/firebase/cloud-functions/)
* [  Cloud Messaging ](/docs/plugins/firebase/cloud-messaging/)
* [  Cloud Storage ](/docs/plugins/firebase/cloud-storage/)
* [  Performance Monitoring ](/docs/plugins/firebase/performance-monitoring/)
* [  Remote Config ](/docs/plugins/firebase/remote-config/)
* [  Formbricks ](/docs/plugins/formbricks/)
* [  Geocoder ](/docs/plugins/geocoder/)
* [  Google Sign-In ](/docs/plugins/google-sign-in/)
* [  libSQL ](/docs/plugins/libsql/)
* [  Live Update ](/docs/plugins/live-update/)
* [  Managed Configurations ](/docs/plugins/managed-configurations/)
* [  Media Session ](/docs/plugins/media-session/)
* [  ML Kit ](/docs/plugins/mlkit/)
* [  NFC ](/docs/plugins/nfc/)
* [  OAuth ](/docs/plugins/oauth/)
* [  Pedometer ](/docs/plugins/pedometer/)
* [  Photo Editor ](/docs/plugins/photo-editor/)
* [  PostHog ](/docs/plugins/posthog/)
* [  Printer ](/docs/plugins/printer/)
* [  Purchases ](/docs/plugins/purchases/)
* [  RealtimeKit ](/docs/plugins/realtimekit/)
* [  Screen Orientation ](/docs/plugins/screen-orientation/)
* [  Screenshot ](/docs/plugins/screenshot/)
* [  Secure Preferences ](/docs/plugins/secure-preferences/)
* [  Speech Recognition ](/docs/plugins/speech-recognition/)
* [  Speech Synthesis ](/docs/plugins/speech-synthesis/)
* [  Share Target ](/docs/plugins/share-target/)
* [  Square Mobile Payments ](/docs/plugins/square-mobile-payments/)
* [  SQLite ](/docs/plugins/sqlite/)
* [  Superwall ](/docs/plugins/superwall/)
* [  Torch ](/docs/plugins/torch/)
* [  Wifi ](/docs/plugins/wifi/)
* [  Zip ](/docs/plugins/zip/)
* [  Cloud ](/docs/cloud/)
* [  Live Updates ](/docs/cloud/live-updates/)
* Advanced
* Integrations
* [  Native Builds ](/docs/cloud/native-builds/)
* [  Configuration ](/docs/cloud/native-builds/configuration/)
* [  Environments ](/docs/cloud/native-builds/environments/)
* Guides
* [  Sample Projects ](/docs/cloud/native-builds/sample-projects/)
* [  Troubleshooting ](/docs/cloud/native-builds/troubleshooting/)
* [  Automations ](/docs/cloud/automations/)
* [  Assist ](/docs/cloud/assist/)
* Account
* Organizations
* [  Organization and User Management ](/docs/cloud/organizations/memberships/)
* [  Single Sign-On (SSO) ](/docs/cloud/organizations/sso/)
* [  Teams ](/docs/cloud/organizations/teams/)
* [  Two-Factor Authentication ](/docs/cloud/organizations/two-factor-authentication/)
* [  Integrations ](/docs/cloud/integrations/)
* [  License Keys ](/docs/cloud/license-keys/)
* [  Webhooks ](/docs/cloud/webhooks/)
* [  Pricing ](https://capawesome.io/pricing/)
* [  FAQ ](/docs/cloud/faq/)
* [  Support ](/docs/cloud/support/)
* [  Contributing ](/docs/contributing/)
* [  LLMs ](/docs/llms/)
* [  Insiders ](/docs/insiders/)
* [  License ](https://capawesome.io/legal/eula/)
* [  Support ](/docs/insiders/support/)
* [  FAQ ](/docs/insiders/faq/)
* [  Blog ](/blog/)
* Categories

* [  iOS ](#ios)
* [  Configuration ](#configuration)
* [  Demo ](#demo)
* [  Starter templates ](#starter-templates)
* [  Usage ](#usage)
* [  API ](#api)
* [  Type Aliases ](#type-aliases)
* [  Test your implementation ](#test-your-implementation)
* [  Changelog ](#changelog)
* [  License ](#license)
* [  Credits ](#credits)

# @capacitor-firebase/crashlytics[¶](#capacitor-firebasecrashlytics "Permanent link")

Unofficial Capacitor plugin for [Firebase Crashlytics](https://firebase.google.com/docs/crashlytics/).[1](#fn:1)

[ ![Deliver Live Updates to your Capacitor app with Capawesome Cloud](../../../assets/external/cloud.capawesome.io/assets/banners/cloud-build-and-deploy-capacitor-apps.69628c3f.png) ](https://cloud.capawesome.io/) 

## Newsletter[¶](#newsletter "Permanent link")

Stay up to date with the latest news and updates about the Capawesome, Capacitor, and Ionic ecosystem by subscribing to our [Capawesome Newsletter](https://cloud.capawesome.io/newsletter/).

## Compatibility[¶](#compatibility "Permanent link")

| Plugin Version | Capacitor Version | Status         |
| -------------- | ----------------- | -------------- |
| 8.x.x          | \>=8.x.x          | Active support |
| 7.x.x          | 7.x.x             | Deprecated     |
| 6.x.x          | 6.x.x             | Deprecated     |
| 5.x.x          | 5.x.x             | Deprecated     |
| 1.x.x          | 4.x.x             | Deprecated     |

## Installation[¶](#installation "Permanent link")

You can use our **AI-Assisted Setup** to install the plugin. Add the [Capawesome Skills](https://github.com/capawesome-team/skills) to your AI tool using the following command:

`[](#%5F%5Fcodelineno-0-1)npx skills add capawesome-team/skills --skill capacitor-plugins
`

Then use the following prompt:

`` [](#%5F%5Fcodelineno-1-1)Use the `capacitor-plugins` skill from `capawesome-team/skills` to install the `@capacitor-firebase/crashlytics` plugin in my project.
 ``

If you prefer **Manual Setup**, install the plugin by running the following commands and follow the platform-specific instructions below:

`[](#%5F%5Fcodelineno-2-1)npm install @capacitor-firebase/crashlytics
[](#%5F%5Fcodelineno-2-2)npx cap sync
`

Add Firebase to your project if you haven't already ([Android](https://github.com/capawesome-team/capacitor-firebase/blob/main/docs/firebase-setup.md#android) / [iOS](https://github.com/capawesome-team/capacitor-firebase/blob/main/docs/firebase-setup.md#ios)).

### Android[¶](#android "Permanent link")

#### Crashlytics Gradle plugin[¶](#crashlytics-gradle-plugin "Permanent link")

First, add the dependency for the Crashlytics Gradle plugin to your root-level (project-level) Gradle file (`<project>/build.gradle`):

`[](#%5F%5Fcodelineno-3-1)buildscript {
[](#%5F%5Fcodelineno-3-2)    dependencies {
[](#%5F%5Fcodelineno-3-3)+       // Add the dependency for the Crashlytics Gradle plugin
[](#%5F%5Fcodelineno-3-4)+       classpath 'com.google.firebase:firebase-crashlytics-gradle:2.9.9'
[](#%5F%5Fcodelineno-3-5)    }
[](#%5F%5Fcodelineno-3-6)}
`

Add the Crashlytics Gradle plugin to your module (app-level) Gradle file (usually `<project>/<app-module>/build.gradle`):

`[](#%5F%5Fcodelineno-4-1)apply plugin: 'com.google.firebase.crashlytics'
`

#### Variables[¶](#variables "Permanent link")

If needed, you can define the following project variable in your app’s `variables.gradle` file to change the default version of the dependency:

* `$firebaseCrashlyticsVersion` version of `com.google.firebase:firebase-crashlytics` (default: `20.0.3`)

This can be useful if you encounter dependency conflicts with other plugins in your project.

### iOS[¶](#ios "Permanent link")

To generate human readable crash reports, Crashlytics needs your project's debug symbol (dSYM) files. The following steps describe how to automatically upload dSYM files to Firebase whenever you build your app:

1. Open your project's Xcode workspace, then select its project file in the left navigator.
2. From the **TARGETS** list, select your main build target.
3. Click the **Build Settings** tab, then complete the following steps so that Xcode produces dSYMs for your builds.
4. Click **All**, then search for `debug information format`.
5. Set **Debug Information Format** to `DWARF with dSYM File` for all your build types.
6. Click the **Build Phases** tab and complete the following steps:
7. Click the **+** button, then select **New Run Script Phase**.  
Make sure this new **Run Script** phase is your project's last build phase; otherwise, Crashlytics can't properly process dSYMs. 2\. Expand the new **Run Script** section. 3\. In the script field (located under the _Shell_ label), add the run script based on your package manager:  
**CocoaPods:**  
`[](#%5F%5Fcodelineno-5-1)"${PODS_ROOT}/FirebaseCrashlytics/run"  
`  
**Swift Package Manager:**  
`[](#%5F%5Fcodelineno-6-1)"${BUILD_DIR%/Build/*}/SourcePackages/checkouts/firebase-ios-sdk/Crashlytics/run"  
`
8. In the **Input Files** section, add the paths for the locations of the following files based on your package manager:  
**CocoaPods:**  
`[](#%5F%5Fcodelineno-7-1)${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${TARGET_NAME}  
`  
`[](#%5F%5Fcodelineno-8-1)$(SRCROOT)/$(BUILT_PRODUCTS_DIR)/$(INFOPLIST_PATH)  
`  
**Swift Package Manager:**  
`[](#%5F%5Fcodelineno-9-1)${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}  
`  
`[](#%5F%5Fcodelineno-10-1)${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${PRODUCT_NAME}  
`  
`[](#%5F%5Fcodelineno-11-1)${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Info.plist  
`  
`[](#%5F%5Fcodelineno-12-1)$(TARGET_BUILD_DIR)/$(UNLOCALIZED_RESOURCES_FOLDER_PATH)/GoogleService-Info.plist  
`  
`[](#%5F%5Fcodelineno-13-1)$(TARGET_BUILD_DIR)/$(EXECUTABLE_PATH)  
`  
If you have `ENABLE_USER_SCRIPT_SANDBOXING=YES` and `ENABLE_DEBUG_DYLIB=YES` in your project build settings, also include:  
`[](#%5F%5Fcodelineno-14-1)${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${PRODUCT_NAME}.debug.dylib  
`

## Configuration[¶](#configuration "Permanent link")

No configuration required for this plugin.

## Demo[¶](#demo "Permanent link")

A working example can be found here: [robingenz/capacitor-firebase-plugin-demo](https://github.com/robingenz/capacitor-firebase-plugin-demo)

## Starter templates[¶](#starter-templates "Permanent link")

The following starter templates are available:

* [Ionstarter Angular Firebase](https://ionstarter.dev/)

## Usage[¶](#usage "Permanent link")

`[](#%5F%5Fcodelineno-15-1)import { FirebaseCrashlytics } from '@capacitor-firebase/crashlytics';
[](#%5F%5Fcodelineno-15-2)
[](#%5F%5Fcodelineno-15-3)const crash = async () => {
[](#%5F%5Fcodelineno-15-4)  await FirebaseCrashlytics.crash({ message: 'Test' });
[](#%5F%5Fcodelineno-15-5)};
[](#%5F%5Fcodelineno-15-6)
[](#%5F%5Fcodelineno-15-7)const setCustomKey = async () => {
[](#%5F%5Fcodelineno-15-8)  await FirebaseCrashlytics.setCustomKey({
[](#%5F%5Fcodelineno-15-9)    key: 'page',
[](#%5F%5Fcodelineno-15-10)    value: 'home',
[](#%5F%5Fcodelineno-15-11)    type: 'string',
[](#%5F%5Fcodelineno-15-12)  });
[](#%5F%5Fcodelineno-15-13)};
[](#%5F%5Fcodelineno-15-14)
[](#%5F%5Fcodelineno-15-15)const setUserId = async () => {
[](#%5F%5Fcodelineno-15-16)  await FirebaseCrashlytics.setUserId({
[](#%5F%5Fcodelineno-15-17)    userId: '123',
[](#%5F%5Fcodelineno-15-18)  });
[](#%5F%5Fcodelineno-15-19)};
[](#%5F%5Fcodelineno-15-20)
[](#%5F%5Fcodelineno-15-21)const log = async () => {
[](#%5F%5Fcodelineno-15-22)  await FirebaseCrashlytics.log({
[](#%5F%5Fcodelineno-15-23)    message: 'Test',
[](#%5F%5Fcodelineno-15-24)  });
[](#%5F%5Fcodelineno-15-25)};
[](#%5F%5Fcodelineno-15-26)
[](#%5F%5Fcodelineno-15-27)const setEnabled = async () => {
[](#%5F%5Fcodelineno-15-28)  await FirebaseCrashlytics.setEnabled({
[](#%5F%5Fcodelineno-15-29)    enabled: true,
[](#%5F%5Fcodelineno-15-30)  });
[](#%5F%5Fcodelineno-15-31)};
[](#%5F%5Fcodelineno-15-32)
[](#%5F%5Fcodelineno-15-33)const isEnabled = async () => {
[](#%5F%5Fcodelineno-15-34)  const { enabled } = await FirebaseCrashlytics.isEnabled();
[](#%5F%5Fcodelineno-15-35)  return enabled;
[](#%5F%5Fcodelineno-15-36)};
[](#%5F%5Fcodelineno-15-37)
[](#%5F%5Fcodelineno-15-38)const didCrashOnPreviousExecution = async () => {
[](#%5F%5Fcodelineno-15-39)  const { crashed } = await FirebaseCrashlytics.didCrashOnPreviousExecution();
[](#%5F%5Fcodelineno-15-40)  return crashed;
[](#%5F%5Fcodelineno-15-41)};
[](#%5F%5Fcodelineno-15-42)
[](#%5F%5Fcodelineno-15-43)const sendUnsentReports = async () => {
[](#%5F%5Fcodelineno-15-44)  await FirebaseCrashlytics.sendUnsentReports();
[](#%5F%5Fcodelineno-15-45)};
[](#%5F%5Fcodelineno-15-46)
[](#%5F%5Fcodelineno-15-47)const deleteUnsentReports = async () => {
[](#%5F%5Fcodelineno-15-48)  await FirebaseCrashlytics.deleteUnsentReports();
[](#%5F%5Fcodelineno-15-49)};
[](#%5F%5Fcodelineno-15-50)
[](#%5F%5Fcodelineno-15-51)const recordException = async () => {
[](#%5F%5Fcodelineno-15-52)  await FirebaseCrashlytics.recordException({
[](#%5F%5Fcodelineno-15-53)    message: 'This is a non-fatal message.',
[](#%5F%5Fcodelineno-15-54)  });
[](#%5F%5Fcodelineno-15-55)};
[](#%5F%5Fcodelineno-15-56)
[](#%5F%5Fcodelineno-15-57)import * as StackTrace from 'stacktrace-js';
[](#%5F%5Fcodelineno-15-58)const recordExceptionWithStacktrace = async (error: Error) => {
[](#%5F%5Fcodelineno-15-59)  const stacktrace = await StackTrace.fromError(error);
[](#%5F%5Fcodelineno-15-60)  await FirebaseCrashlytics.recordException({
[](#%5F%5Fcodelineno-15-61)    message: 'This is a non-fatal message.',
[](#%5F%5Fcodelineno-15-62)    stacktrace,
[](#%5F%5Fcodelineno-15-63)  });
[](#%5F%5Fcodelineno-15-64)};
`

## API[¶](#api "Permanent link")

* [crash(...)](#crash)
* [setCustomKey(...)](#setcustomkey)
* [setUserId(...)](#setuserid)
* [log(...)](#log)
* [setEnabled(...)](#setenabled)
* [isEnabled()](#isenabled)
* [didCrashOnPreviousExecution()](#didcrashonpreviousexecution)
* [sendUnsentReports()](#sendunsentreports)
* [deleteUnsentReports()](#deleteunsentreports)
* [recordException(...)](#recordexception)
* [Interfaces](#interfaces)
* [Type Aliases](#type-aliases)

### crash(...)[¶](#crash "Permanent link")

`[](#%5F%5Fcodelineno-16-1)crash(options: CrashOptions) => Promise<void>
`

Forces a crash to test the implementation.

Only available for Android and iOS.

| Param       | Type                          |
| ----------- | ----------------------------- |
| **options** | [CrashOptions](#crashoptions) |

**Since:** 0.1.0

---

### setCustomKey(...)[¶](#setcustomkey "Permanent link")

`[](#%5F%5Fcodelineno-17-1)setCustomKey(options: SetCustomKeyOptions) => Promise<void>
`

Sets a custom key and value that is associated with subsequent fatal and non-fatal reports.

Only available for Android and iOS.

| Param       | Type                                    |
| ----------- | --------------------------------------- |
| **options** | [CustomKeyAndValue](#customkeyandvalue) |

**Since:** 0.1.0

---

### setUserId(...)[¶](#setuserid "Permanent link")

`[](#%5F%5Fcodelineno-18-1)setUserId(options: SetUserIdOptions) => Promise<void>
`

Sets a user ID (identifier) that is associated with subsequent fatal and non-fatal reports.

Only available for Android and iOS.

| Param       | Type                                  |
| ----------- | ------------------------------------- |
| **options** | [SetUserIdOptions](#setuseridoptions) |

**Since:** 0.1.0

---

### log(...)[¶](#log "Permanent link")

`[](#%5F%5Fcodelineno-19-1)log(options: LogOptions) => Promise<void>
`

Adds a custom log message that is sent with your crash data to give yourself more context for the events leading up to a crash.

Only available for Android and iOS.

| Param       | Type                      |
| ----------- | ------------------------- |
| **options** | [LogOptions](#logoptions) |

**Since:** 0.1.0

---

### setEnabled(...)[¶](#setenabled "Permanent link")

`[](#%5F%5Fcodelineno-20-1)setEnabled(options: SetEnabledOptions) => Promise<void>
`

Enables/disables automatic data collection. The value does not apply until the next run of the app.

Only available for Android and iOS.

| Param       | Type                                    |
| ----------- | --------------------------------------- |
| **options** | [SetEnabledOptions](#setenabledoptions) |

**Since:** 0.1.0

---

### isEnabled()[¶](#isenabled "Permanent link")

`[](#%5F%5Fcodelineno-21-1)isEnabled() => Promise<IsEnabledResult>
`

Returns whether or not automatic data collection is enabled.

Only available for iOS.

**Returns:** `Promise<[IsEnabledResult](#isenabledresult)>`

**Since:** 0.1.0

---

### didCrashOnPreviousExecution()[¶](#didcrashonpreviousexecution "Permanent link")

`[](#%5F%5Fcodelineno-22-1)didCrashOnPreviousExecution() => Promise<DidCrashOnPreviousExecutionResult>
`

Returns whether the app crashed during the previous execution.

Only available for Android and iOS.

**Returns:** `Promise<[DidCrashOnPreviousExecutionResult](#didcrashonpreviousexecutionresult)>`

**Since:** 0.1.0

---

### sendUnsentReports()[¶](#sendunsentreports "Permanent link")

`[](#%5F%5Fcodelineno-23-1)sendUnsentReports() => Promise<void>
`

Uploads any unsent reports to Crashlytics at next startup.

When automatic data collection is enabled, Crashlytics automatically uploads reports at startup.

Only available for Android and iOS.

**Since:** 0.1.0

---

### deleteUnsentReports()[¶](#deleteunsentreports "Permanent link")

`[](#%5F%5Fcodelineno-24-1)deleteUnsentReports() => Promise<void>
`

Deletes any unsent reports on the device.

Only available for Android and iOS.

**Since:** 0.1.0

---

### recordException(...)[¶](#recordexception "Permanent link")

`[](#%5F%5Fcodelineno-25-1)recordException(options: RecordExceptionOptions) => Promise<void>
`

Records a non-fatal report to send to Crashlytics.

Only available for Android and iOS.

| Param       | Type                                              |
| ----------- | ------------------------------------------------- |
| **options** | [RecordExceptionOptions](#recordexceptionoptions) |

**Since:** 0.1.0

---

### Interfaces[¶](#interfaces "Permanent link")

#### CrashOptions[¶](#crashoptions "Permanent link")

| Prop        | Type   | Since |
| ----------- | ------ | ----- |
| **message** | string | 0.1.0 |

#### CustomKeyAndValue[¶](#customkeyandvalue "Permanent link")

| Prop      | Type                  | Since   |          |       |         |       |
| --------- | --------------------- | ------- | -------- | ----- | ------- | ----- |
| **key**   | string                | 7.1.0   |          |       |         |       |
| **value** | string \| number      | boolean | 7.1.0    |       |         |       |
| **type**  | 'string' \| 'boolean' | 'long'  | 'double' | 'int' | 'float' | 7.1.0 |

#### SetUserIdOptions[¶](#setuseridoptions "Permanent link")

| Prop       | Type   | Since |
| ---------- | ------ | ----- |
| **userId** | string | 0.1.0 |

#### LogOptions[¶](#logoptions "Permanent link")

| Prop        | Type   | Since |
| ----------- | ------ | ----- |
| **message** | string | 0.1.0 |

#### SetEnabledOptions[¶](#setenabledoptions "Permanent link")

| Prop        | Type    | Since |
| ----------- | ------- | ----- |
| **enabled** | boolean | 0.1.0 |

#### IsEnabledResult[¶](#isenabledresult "Permanent link")

| Prop        | Type    | Since |
| ----------- | ------- | ----- |
| **enabled** | boolean | 0.1.0 |

#### DidCrashOnPreviousExecutionResult[¶](#didcrashonpreviousexecutionresult "Permanent link")

| Prop        | Type    | Since |
| ----------- | ------- | ----- |
| **crashed** | boolean | 0.1.0 |

#### RecordExceptionOptions[¶](#recordexceptionoptions "Permanent link")

| Prop              | Type                  | Description                                                                                                                                                                                  | Since |
| ----------------- | --------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----- |
| **message**       | string                | The message to record as a non-fatal exception.                                                                                                                                              | 0.1.0 |
| **code**          | number                | Error code within a specific error domain. **Attention:** This option is ignored on iOS if stacktrace is provided. Only available for iOS.                                                   | 0.1.0 |
| **domain**        | string                | A string containing the error domain. **Attention:** This option is ignored on iOS if stacktrace is provided. Only available for iOS.                                                        | 0.1.0 |
| **keysAndValues** | CustomKeyAndValue\[\] | An array of keys and the values to associate with the non fatal exception, in addition to the app level custom keys. **Attention:** This option is ignored on iOS if stacktrace is provided. | 7.1.0 |
| **stacktrace**    | StackFrame\[\]        | A stacktrace generated by stacktrace.js.                                                                                                                                                     | 1.1.0 |

#### StackFrame[¶](#stackframe "Permanent link")

Subset of the Stacktrace generated by stacktrace.js.

| Prop             | Type   |
| ---------------- | ------ |
| **lineNumber**   | number |
| **fileName**     | string |
| **functionName** | string |

### Type Aliases[¶](#type-aliases "Permanent link")

#### SetCustomKeyOptions[¶](#setcustomkeyoptions "Permanent link")

`[CustomKeyAndValue](#customkeyandvalue)`

## Test your implementation[¶](#test-your-implementation "Permanent link")

[Here](https://firebase.google.com/docs/crashlytics/force-a-crash) you can find more information on how to test the Firebase Crashlytics implementation. Among other things, you will find information on how to correctly [adjust the project's debug settings](https://firebase.google.com/docs/crashlytics/force-a-crash?platform=ios#adjust%5Fyour%5Fprojects%5Fdebug%5Fsettings) under iOS and how to [test it out](https://firebase.google.com/docs/crashlytics/force-a-crash?platform=ios#test%5Fit%5Fout).

If you get obfuscated crash reports for iOS, make sure you have [initialized Crashlytics](https://firebase.google.com/docs/crashlytics/get-started?platform=ios#initialize-crashlytics) correctly and take a look at [this guide](https://firebase.google.com/docs/crashlytics/get-deobfuscated-reports?platform=ios), which provides some ways to troubleshoot if Crashlytics can't find your app's dSYM.

## Changelog[¶](#changelog "Permanent link")

See [CHANGELOG.md](https://github.com/capawesome-team/capacitor-firebase/blob/main/packages/crashlytics/CHANGELOG.md).

## License[¶](#license "Permanent link")

See [LICENSE](https://github.com/capawesome-team/capacitor-firebase/blob/main/packages/crashlytics/LICENSE).

## Credits[¶](#credits "Permanent link")

This plugin is based on the [Capacitor Community Firebase Crashlytics](https://github.com/capacitor-community/firebase-crashlytics) plugin. Thanks to everyone who contributed to the project!

---

1. This project is not affiliated with, endorsed by, sponsored by, or approved by Google LLC or any of their affiliates or subsidiaries. [↩](#fnref:1 "Jump back to footnote 1 in the text")

May 17, 2026 

 Back to top 