从 Android 个插桩测试发送 Crashlytics 报告

Send Crashlytics reports from Android instrumented tests

我 运行 我在 Firebase 测试实验室进行了仪器化测试,希望 non-fatal 向 Crashlytics 报告异常。

但是,调用 Crashlytics.logException() 不会立即发送报告。启用 core.debuggable(true) 后,我在发送报告时看到了这个:

D/CrashlyticsCore: Crashlytics is logging non-fatal exception "java.lang.Throwable: java.lang.Throwable" from thread main

但在我重新启动应用程序之前,该报告在 Crashlytics 仪表板上不可见,然后我看到:

D/CrashlyticsCore: Checking for crash reports...
D/CrashlyticsCore: Found crash report /data/user/0/.../files/.Fabric/com.crashlytics.sdk.android.crashlytics-core/nonfatal-sessions/....cls
D/CrashlyticsCore: Attempting to send 1 report(s)
D/CrashlyticsCore: Adding single file ....cls to report ...
D/CrashlyticsCore: Sending report to: https://reports.crashlytics.com/spi/v1/platforms/android/apps/org.dasfoo.delern.instrumented/reports
D/CrashlyticsCore: Create report request ID: null
D/CrashlyticsCore: Result was: 202
I/CrashlyticsCore: Crashlytics report upload complete: ...
D/CrashlyticsCore: Removing report at /data/user/0/.../files/.Fabric/com.crashlytics.sdk.android.crashlytics-core/nonfatal-sessions/....cls
D/CrashlyticsCore: Checking for crash reports...
D/CrashlyticsCore: No reports found.

这对于生产用例来说并不理想,但至少在用户重新启动应用程序时它会起作用。在测试中,这永远不会起作用,因为 Firebase 测试实验室不会重新启动应用程序(重新启动应用程序意味着测试将失败)。

是否有任何解决方法允许 Crashlytics 发送来自仪器测试的 non-fatal 报告?

已用包:

com.crashlytics.sdk.android:crashlytics:2.6.8@aar
io.fabric.tools:gradle:1.24.0

UPD:改写了问题和标题。我正在寻找改变 Crashlytics 默认行为的选项,因为它似乎是一个合理的功能。

无法报告当前会话中的非致命事件。需要重新启动应用程序才能将非致命事件报告给 Crashlytics。

import com.google.firebase.crash.FirebaseCrash;

FirebaseCrash.report(new Exception("Error in CreateMobileAlertNative "+e.getStackTrace()));

我曾经使用这个 FirebaseCrash class 在 crashlytics 上得到非致命异常,我把一些代码放在我的 catch 上,通过它我用来获得那些报告,试试这个。