首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >单元测试目标的FirebaseApp.configure()崩溃

单元测试目标的FirebaseApp.configure()崩溃
EN

Stack Overflow用户
提问于 2018-04-18 11:03:18
回答 3查看 3K关注 0票数 17

我遇到了一个奇怪的问题,FirebaseApp.configure()调用导致我的应用程序为我的单元测试目标立即崩溃。对于我的标准版本来说,它运行得很好。

知道为什么会这样吗?

下面是堆栈跟踪:

代码语言:javascript
复制
2018-04-18 11:42:57.252405+0100 Avalanche[14289:124354] 4.8.1 - [Firebase/Analytics][I-ACS023007] Firebase Analytics v.40007000 started
2018-04-18 11:42:57.252454+0100 Avalanche[14289:124361] 4.8.1 - [Firebase/Core][I-COR000005] No app has been configured yet.
2018-04-18 11:42:57.252712+0100 Avalanche[14289:124354] 4.8.1 - [Firebase/Analytics][I-ACS023008] To enable debug logging set the following application argument: -FIRAnalyticsDebugEnabled (see http://googl/RfcP7r)
2018-04-18 11:42:57.371588+0100 Avalanche[14289:124278] [Crashlytics] Version 3.9.3 (128)
2018-04-18 11:42:57.390507+0100 Avalanche[14289:124278] *** Terminating app due to uncaught exception 'FABException', reason: '[Fabric] Value of Info.plist key "Fabric" must be a NSDictionary.'
*** First throw call stack:
(
    0   CoreFoundation                      0x0000000113c0a1e6 __exceptionPreprocess + 294
    1   libobjc.A.dylib                     0x000000011329f031 objc_exception_throw + 48
    2   CoreFoundation                      0x0000000113c7f975 +[NSException raise:format:] + 197
    3   Avalanche                           0x000000010f654dec -[Fabric validFabricConfigFromInfoPlist:] + 353
    4   Avalanche                           0x000000010f654a16 -[Fabric fabricConfig] + 127
    5   Avalanche                           0x000000010f654bce -[Fabric APIKey] + 392
    6   Avalanche                           0x000000010f61e6d7 -[Crashlytics APIKey] + 55
    7   Avalanche                           0x000000010f62a087 -[CLSCrashReportingController APIKey] + 57
    8   Avalanche                           0x000000010f62977f -[CLSCrashReportingController startWithProfilingMark:betaToken:] + 257
    9   Avalanche                           0x000000010f61e088 __20-[Crashlytics start]_block_invoke + 637
    10  libdispatch.dylib                   0x0000000114b93779 _dispatch_client_callout + 8
    11  libdispatch.dylib                   0x0000000114b94c0a dispatch_once_f + 55
    12  Avalanche                           0x000000010f61de05 -[Crashlytics start] + 106
    13  Avalanche                           0x000000010f61e23a +[Crashlytics initializeIfNeeded] + 48
    14  Avalanche Tests                     0x0000000129cd440a __15+[Fabric with:]_block_invoke + 538
    15  libdispatch.dylib                   0x0000000114b93779 _dispatch_client_callout + 8
    16  libdispatch.dylib                   0x0000000114b94c0a dispatch_once_f + 55
    17  Avalanche Tests                     0x0000000129cd41ee +[Fabric with:] + 222
    18  Avalanche Tests                     0x0000000129cd5dea __14+[Fabric load]_block_invoke + 580
    19  Foundation                          0x0000000112cc0324 -[__NSObserver _doit:] + 298
    20  CoreFoundation                      0x0000000113ba5b8c __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 12
    21  CoreFoundation                      0x0000000113ba5a65 _CFXRegistrationPost + 453
    22  CoreFoundation                      0x0000000113ba57a1 ___CFXNotificationPost_block_invoke + 225
    23  CoreFoundation                      0x0000000113b67422 -[_CFXNotificationRegistrar find:object:observer:enumerator:] + 1826
    24  CoreFoundation                      0x0000000113b665a1 _CFXNotificationPost + 609
    25  Foundation                          0x0000000112c80e57 -[NSNotificationCenter postNotificationName:object:userInfo:] + 66
    26  Avalanche                           0x000000010f6d41a7 +[FIRApp sendNotificationsToSDKs:] + 393
    27  Avalanche                           0x000000010f6d309e +[FIRApp configureDefaultAppWithOptions:sendingNotifications:] + 302
    28  Avalanche                           0x000000010f6d2eda +[FIRApp configure] + 380
    29  Avalanche                           0x000000010f609490 _T09Avalanche11AppDelegateCACycfc + 192
    30  Avalanche                           0x000000010f6094c3 _T09Avalanche11AppDelegateCACycfcTo + 19
    31  UIKit                               0x00000001109eb6c4 _UIApplicationMainPreparations + 1491
    32  UIKit                               0x00000001109eb087 UIApplicationMain + 111
    33  Avalanche                           0x000000010f60b447 main + 55
    34  libdyld.dylib                       0x0000000114c08955 start + 1
)
li

bc++abi.dylib:以NSException类型的未明确例外结束

在崩溃之前,我还看到大量日志条目,如:

代码语言:javascript
复制
objc[14289]: Class RCNKeyValue is implemented in both /Users/sammcneilly/Library/Developer/CoreSimulator/Devices/E62EC87E-0B07-4A83-A165-819E693AEB87/data/Containers/Bundle/Application/6C3F993F-4CEB-462F-9257-0F3C8E088BC0/Avalanche.app/Avalanche (0x10f7bdd50) and /Users/sammcneilly/Library/Developer/Xcode/DerivedData/Avalanche-ewiqmxxekhpknrhhfuyljlekgzat/Build/Products/Development-iphonesimulator/Avalanche.app/PlugIns/Avalanche Tests.xctest/Avalanche Tests (0x129e075d8). One of the two will be used. Which one is undefined.

我已经通过CocoaPods安装了Firebase和Firebase/Crashlytics。我不确定这是否与Xcode 9.3有关--这是在两个单独的项目上发生的,而且我相当肯定,在以前的项目中没有发生过这种情况。

我已经打印出了包的内容,GoogleService-Info.plist文件似乎就在那里。

任何帮助都将不胜感激!

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-04-18 13:34:47

好的,这原来是由配置不当的Pod文件引起的。我的主要目标和单元测试目标被配置为使用以下吊舱:

代码语言:javascript
复制
pod 'Crashlytics', '~> 3.10.1'
pod 'Fabric', '~> 1.7.6'
pod 'Firebase/Core', '~> 4.8'
pod 'FirebaseRemoteConfig', '~> 2.1'

只删除测试目标的附加Firebase荚(Firebase/Core除外),并再次运行pod install也有帮助。

我不太清楚为什么这样做,所以如果有人能给我解释一下,我会非常感激的。

"${PODS_ROOT}/Fabric/run"构建阶段脚本是在我的主要目标上配置的,详见Google的文档:https://firebase.google.com/docs/crashlytics/get-started,并将它添加到测试目标中也没有任何帮助.

感谢每个人的输入,但是手动将Fabric细节添加到Info.plist文件中只会导致构建错误。我相信这个步骤是自动为Firebase处理的。

票数 10
EN

Stack Overflow用户

发布于 2019-03-22 20:59:43

在运行XCTest时,我们也发生了同样的崩溃。我们用下面的方法来绕过它。

代码语言:javascript
复制
        if NSClassFromString("XCTest") != nil {
            return true
        } else {
            FirebaseApp.configure()
        }
票数 3
EN

Stack Overflow用户

发布于 2018-04-18 11:17:59

将此代码放入info.plist

代码语言:javascript
复制
<key>Fabric</key>
    <dict>
        <key>APIKey</key>
        <string>YOUR APIKEY</string>
        <key>Kits</key>
        <array>
            <dict>
                <key>KitInfo</key>
                <dict/>
                <key>KitName</key>
                <string>Crashlytics</string>
            </dict>
        </array>
    </dict>

希望能帮上忙!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49898101

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档