Android Crashlytics-无法上传符号

问题描述 投票:0回答:1

Crashlytics已经为我的Android应用设置了一段时间,并且对于正常的Java / Kotlin代码也可以正常工作。我现在正尝试使用以下指南来让Crashlytics记录NDK崩溃:https://firebase.google.com/docs/crashlytics/ndk-reports

我使C ++崩溃,并且确实出现在Crashlytics中,如下面的屏幕快照所示。但是stacktrace缺少很多信息。

enter image description here

顶级Gradle文件

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    ext.kotlin_version = '1.3.61'
    ext.ktlint_version = '0.33.0'
    ext.spotless_version = '3.25.0'

    repositories {
        mavenCentral()
        google()
        jcenter()
        maven { url 'https://maven.fabric.io/public' }
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.5.3'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath 'com.google.gms:google-services:4.3.3'
        classpath 'io.fabric.tools:gradle:1.31.2'
        classpath "com.diffplug.spotless:spotless-plugin-gradle:$spotless_version"
    }
}

apply plugin: "com.diffplug.gradle.spotless"

allprojects {
    repositories {
        mavenCentral()
        google()
        jcenter()
        maven { url 'https://jitpack.io' }
    }
}

spotless {
    kotlin {
        target "**/*.kt"
        ktlint(ktlint_version)
    }
}

其他Gradle文件。带注释的行是我尝试过的。

apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'com.google.gms.google-services'
apply plugin: 'io.fabric'

def superpowered_sdk_path = new File(projectDir, '../../Superpowered/Superpowered')

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.something.app"
        minSdkVersion 21
        targetSdkVersion 28
        versionCode 51
        versionName "51"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"

        ndk { // these platforms cover 99% percent of all Android devices
            abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64'
        }

        externalNativeBuild {
            cmake {
                arguments '-DANDROID_PLATFORM=android-19', '-DANDROID_TOOLCHAIN=clang', '-DANDROID_ARM_NEON=TRUE', '-DANDROID_STL=c++_static', "-DPATH_TO_SUPERPOWERED:STRING=${superpowered_sdk_path}"
                cFlags '-O3', '-fsigned-char' // full optimization, char data type is signed
                cppFlags '-fsigned-char', "-I${superpowered_sdk_path}"
            }
        }
    }

    compileOptions {
        targetCompatibility JavaVersion.VERSION_1_8
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

    externalNativeBuild {
        cmake {
            path file('CMakeLists.txt')
        }
    }

    afterEvaluate {
        assembleDebug.finalizedBy(crashlyticsUploadSymbolsDebug)
        assembleRelease.finalizedBy(crashlyticsUploadSymbolsRelease)
    }

//    android.applicationVariants.all { variant ->
//        def variantName = variant.name.capitalize()
//        if(variant.buildType.name=="release") {
//            println('Calling crashlyticsUploadSymbolsRelease...')
//            variant.assemble.finalizedBy(project.("crashlyticsUploadSymbols${variantName}"))
//        }
//    }

//    tasks.whenTaskAdded { task ->
//        if (task.name == "externalNativeBuildRelease") {
//            println('Calling crashlyticsUploadSymbolsRelease...')
//            task.finalizedBy "crashlyticsUploadSymbolsRelease"
////            crashlyticsUploadSymbolsRelease
//        } else if (task.name == "externalNativeBuildDebug") {
//            println('Calling crashlyticsUploadSymbolsDebug...')
//            task.finalizedBy "crashlyticsUploadSymbolsDebug"
////            crashlyticsUploadSymbolsRelease
//        }
//    }
}

crashlytics {
    enableNdk true
//    androidNdkOut 'build/intermediates/cmake/debug/obj'
//    androidNdkLibsOut 'build/intermediates/stripped_native_libs/debug/out/lib'
//    androidNdkOut 'build/intermediates/cmake/release/obj'
//    androidNdkLibsOut 'build/intermediates/merged_native_libs/debug/out/lib'
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.3"
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-android:1.3.3"
    implementation 'androidx.appcompat:appcompat:1.1.0'
    implementation 'androidx.gridlayout:gridlayout:1.0.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'androidx.legacy:legacy-support-v4:1.0.0'
    testImplementation 'junit:junit:4.12'
    testImplementation 'androidx.test:core:1.2.0'
    testImplementation "io.mockk:mockk:1.9.3"
    androidTestImplementation 'androidx.test:runner:1.2.0'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
    implementation 'com.karumi:dexter:6.0.2'
    implementation 'org.koin:koin-android:0.9.2'
    implementation 'com.android.billingclient:billing:1.1'
    implementation 'com.google.android.exoplayer:exoplayer:2.11.1'
    implementation('com.github.bumptech.glide:glide:4.10.0') {
        exclude group: "com.android.support"
    }
    annotationProcessor 'com.github.bumptech.glide:compiler:4.8.0'
    implementation 'com.google.firebase:firebase-ads:18.3.0'
    implementation 'com.google.firebase:firebase-core:17.2.0' //17.2.1 Has a bug
    implementation 'com.crashlytics.sdk.android:crashlytics:2.10.1'
    implementation('com.crashlytics.sdk.android:crashlytics-ndk:2.1.1')
    implementation "android.arch.navigation:navigation-fragment-ktx:1.0.0"
    implementation "android.arch.navigation:navigation-ui-ktx:1.0.0"
    implementation 'com.beust:klaxon:5.0.1'
    implementation 'com.h6ah4i.android.widget.verticalseekbar:verticalseekbar:1.0.0'
    implementation 'us.belka:androidtoggleswitch:1.2.2'
    implementation 'com.shawnlin:number-picker:2.4.8'
    implementation 'com.github.Triggertrap:SeekArc:v1.1'
    implementation 'com.sdsmdg.harjot:croller:1.0.7'
    implementation 'com.jaredrummler:material-spinner:1.3.1'
    implementation 'com.jakewharton.threetenabp:threetenabp:1.2.1'
    debugImplementation 'com.squareup.leakcanary:leakcanary-android:2.0-beta-3'
}

我认为问题在于“上传本机符号”步骤。我读过另一篇post,在运行./gradlew crashlyticsUploadSymbolsRelease./gradlew crashlyticsUploadSymbolsDebug之后,应该有一行像“成功上传符号”。运行任务后,我没有看到这一行,也没有看到任何错误(我使用了--info和--debug)。我搜索了其他帖子中建议的不同类型的解决方案,但似乎没有任何效果。

版本

  • Android Gradle插件:3.5.3
  • Gradle版本:5.4.1
  • io.fabric.tools:gradle:1.31.2

上传符号之前还有其他需要做的事情吗?有没有办法检查它们是否成功上传?

谢谢!

android c++ android-ndk crashlytics
1个回答
0
投票

与Crashlytics帮助中心联系时,我采取了一些步骤来为他们提供一些日志。在执行这些步骤的同时,一切都正常进行了,堆栈跟踪正按预期显示在Crashlytics中。

[如果有人遇到任何问题。检查crashlytics日志(感谢帮助台提供以下步骤!):

Linux / Windows:〜/ .crashlytics / com.crashlytics.tools / crashlytics.log

Mac:〜/ Library / Caches / com.crashlytics / com.crashlytics.tools / crashlytics.log

  1. 删除crashlytics.log文件
  2. 运行符号上载gradle任务
  3. 构建并运行应用,遇到测试崩溃

检查crashlytics.log,它应包含以下内容:

[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - Manifest and properties apiKey is empty. Looking for google_app_id
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - Google-services res dir: /Users/xxx/AndroidStudioProjects/Looper/app/build/generated/res/google-services/release/values/values.xml
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - Found google_app_id: 1:12341234123:android:34h43h2k423342kb
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - apiKey is 123412341234fdsfds12312321321dsfsd
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - Crashlytics attempting to upload cSYM files.
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST file: /Users/xxx/Library/Caches/com.crashlytics/com.crashlytics.tools/app-afdsfdsfdsfds/release/csyms/superpowered-aarch64-b4jk32bkl2b5b4b543.cSYM.gz to URL: https://cm.crashlytics.com/api/v3/platforms/android/code_mappings
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST response: [reqId= 123412341234fdsfds12312321321dsfsd] 202
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST file: /Users/xxx/Library/Caches/com.crashlytics/com.crashlytics.tools/app-af3ed5c17e31fe86dd60a032b9674cb18b65334d/release/csyms/superpowered-x86_64-123412341234fdsfds12312321321dsfsd.cSYM.gz to URL: https://cm.crashlytics.com/api/v3/platforms/android/code_mappings
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST response: [reqId=123412341234fdsfds12312321321dsfsd] 202
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST file: /Users/xxx/Library/Caches/com.crashlytics/com.crashlytics.tools/app-af3ed5c17e31fe86dd60a032b9674cb18b65334d/release/csyms/superpowered-x86-123412341234fdsfds12312321321dsfsd.cSYM.gz to URL: https://cm.crashlytics.com/api/v3/platforms/android/code_mappings
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST response: [reqId=123412341234fdsfds12312321321dsfsd] 202
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST file: /Users/xxx/Library/Caches/com.crashlytics/com.crashlytics.tools/app-123412341234fdsfds12312321321dsfsd/release/csyms/superpowered-armv7-123412341234fdsfds12312321321dsfsd to URL: https://cm.crashlytics.com/api/v3/platforms/android/code_mappings
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - POST response: [reqId=123412341234fdsfds12312321321dsfsd] 202
[DEBUG] (Execution worker for ':' Thread 6) com.crashlytics  - cSYM file(s) uploaded.
© www.soinside.com 2019 - 2024. All rights reserved.