-
Notifications
You must be signed in to change notification settings - Fork 1.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Crashlytics no longer bucketing correctly for builds to device #14218
Comments
I couldn't figure out how to label this issue, so I've labeled it for a human to triage. Hang tight. |
Hello @lilidotshi could you provide a complete sample in a separate repository so I can reproduce this? Thanks |
@Lyokone here you go: https://github.com/lilidotshi/CrashlyticsDemo Copy your own google-service.plist file into |
@Lyokone do you need any more info from me? This is a blocking issue for us using Firebase if we can't get properly symbolicated crashes. |
Hey @lilidotshi, Thank you for reaching out and providing the reproducible sample app. I did take a look this week and this is probably work as intend. Essentially, the dynamic framework is being treated as a 3rd party library because it's not in the main app's compilation stage. The reason you can see it marks as blamed for such frame in simulator is because that on simulator framework symbols are not completely removed. We can still extract symbol information from simulator runtime while crash happening. So on backend we are able to mark such frame as developer frame. But when build on a real device, dynamic framework symbols are completely redacted so it is treated as a 3rd party library. For some potential solutions I wonder if you could include that library's code directly, or make as a static library instead to see if it solves the problem? |
Description
I'm running into an issue where it looks like both fatal and non-fatals are not being bucketed correctly, but only when i build to a device. I have an app that references another dynamic framework of mine, where I'm calling fatalError("some message"). I also tried with non-fatals with the same effect. In the simulator, these crashes/nonfatals are logged correctly (see images below). However, with the same code, and same build settings, building to an actual device logs the issue as part of the main app as opposed to the dylib. This is causing everything to be bucketed together across my various modules, which is bad because I can't identify individual crashes easily from the dash.
I've heard there are issues with the
Enable Debug dylib support
setting but that's off for me.Reproducing the issue
Create a vanilla SwiftUI app, and a dynamic framework. Have the app depend on the framework and call fatalError somewhere within the framework. On a simulator, crash stacktrace looks good and buckets correctly. On a device it buckets incorrectly and is all bucketed within
App.main
and greyed out stack traces to the actual crashFirebase SDK Version
11.6.0
Xcode Version
16.1
Installation Method
Swift Package Manager
Firebase Product(s)
Crashlytics
Targeted Platforms
iOS
Relevant Log Output
No response
If using Swift Package Manager, the project's Package.resolved
Expand
Package.resolved
snippetReplace this line with the contents of your Package.resolved.
If using CocoaPods, the project's Podfile.lock
Expand
Podfile.lock
snippetReplace this line with the contents of your Podfile.lock!
The text was updated successfully, but these errors were encountered: