Nombre de rapports de crash reçus de Firebase Crashlytics. C'est lié à Firebase-perf je pense.
Fatal Exception: Java.lang.NoClassDefFoundError: com.google.Android.gms.internal.firebase-perf.zzw
at com.google.firebase.perf.metrics.Trace.start(Unknown Source:44)
at com.google.Android.gms.internal.firebase-perf.zze.onActivityStarted(Unknown Source:48)
at Android.app.Application.dispatchActivityStarted(Application.Java:205)
at Android.app.Activity.onStart(Activity.Java:1150)
Vous utilisez déjà la dernière version de Firebase et des services Google Play.
Il ne se bloque pas sur les appareils de Firebase Test Lab. Mais ~ 1% des utilisateurs rencontrent ce problème.
Est-ce lié à l'absence de GMS Core? Si oui, comment le gérer correctement, sans provoquer de plantage sur ces appareils?
--- Mise à jour ---
projet build.gradle
buildscript {
repositories {
google()
maven {
url 'https://maven.fabric.io/public'
}
jcenter()
}
dependencies {
classpath 'com.Android.tools.build:gradle:3.3.0-alpha04'
classpath 'com.google.gms:google-services:4.0.1' // google-services plugin
classpath 'com.google.firebase:firebase-plugins:1.1.5'
classpath 'io.fabric.tools:gradle:1.25.4'
}
}
allprojects {
repositories {
google()
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
App build.gradle
apply plugin: 'com.Android.application'
apply plugin: 'com.google.firebase.firebase-perf'
apply plugin: 'com.google.Android.gms.oss-licenses-plugin'
apply plugin: 'io.fabric'
Android {
compileSdkVersion 28
buildToolsVersion '28.0.2'
useLibrary 'org.Apache.http.legacy'
defaultConfig {
applicationId "MASKED"
minSdkVersion 18
targetSdkVersion 28
versionCode "MASKED"
versionName "MASKED"
resConfigs "en"
multiDexEnabled true
vectorDrawables.useSupportLibrary = true
dataBinding {
enabled = true
}
}
buildTypes {
release {
minifyEnabled true
shrinkResources false
proguardFiles getDefaultProguardFile('proguard-Android.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
lintOptions {
abortOnError false
textReport true
textOutput 'stdout'
checkReleaseBuilds false
}
}
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
testImplementation 'junit:junit:4.12'
implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0-rc01'
implementation 'androidx.annotation:annotation:1.0.0-rc01'
implementation 'androidx.appcompat:appcompat:1.0.0-rc01'
implementation 'androidx.leanback:leanback:1.0.0-rc01'
implementation 'androidx.cardview:cardview:1.0.0-rc01'
implementation 'androidx.gridlayout:gridlayout:1.0.0-rc01'
implementation 'androidx.multidex:multidex:2.0.0'
implementation 'androidx.constraintlayout:constraintlayout:1.1.2'
implementation 'com.google.firebase:firebase-core:16.0.1'
implementation 'com.google.firebase:firebase-ads:15.0.1'
implementation 'com.google.firebase:firebase-config:16.0.0'
implementation 'com.google.firebase:firebase-perf:16.0.0'
implementation 'com.google.Android.material:material:1.0.0-rc01'
implementation 'com.google.Android.gms:play-services-oss-licenses:16.0.0'
implementation 'com.google.Android:flexbox:1.0.0'
implementation 'com.google.code.gson:gson:2.8.2'
implementation 'com.crashlytics.sdk.Android:crashlytics:2.9.4'
}
// ADD THIS AT THE BOTTOM
apply plugin: 'com.google.gms.google-services'
Le support Firebase vient de me confirmer qu'il s'agit d'un bug. Ils y travaillent actuellement (bien qu'ils n'aient pas encore pu le reproduire). Nous devons donc nous attendre à ce que cela soit corrigé dans une future version de Firebase.
Mise à jour: veuillez mettre à jour vers Firebase Performance Version 16.2.5 pour résoudre ce problème.