アーキテクチャコンポーネントからWorkManagerを使用しようとしています。 compileSdkVersionとtargetSdkVersionを27から28にアップグレードしました。gradle同期は正常に完了しました。ただし、ビルド時エラーがポップアップし続けます。 「Android.support:design」のため、Android.supportライブラリはバージョン28.0.0-rc02を使用しています。
「proguard/androidx-annotations.pro」を除外するために、packageingOptionsを追加しようとしました。しかし、それは助けにはなりませんでした。しかし、今回は別のエラーメッセージが表示されました。
Program type already present: com.google.common.util.concurrent.ListenableFuture
何が悪いのかわかりませんでした。
build.gradle:
apply plugin: 'com.Android.application'
apply plugin: 'kotlin-Android'
apply plugin: 'kotlin-Android-extensions'
apply plugin: 'io.fabric'
Android {
compileSdkVersion 28
defaultConfig {
applicationId "com.apps.test"
minSdkVersion 16
targetSdkVersion 28
versionCode 5
versionName "1.0"
testInstrumentationRunner "Android.support.test.runner.AndroidJUnitRunner"
multiDexEnabled true
}
signingConfigs {
release
}
buildTypes {
release {
signingConfig signingConfigs.release
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-Android.txt'), 'proguard-rules.pro'
resValue "bool", "enableFirebase", "true"
}
debug {
minifyEnabled false
resValue "bool", "enableFirebase", "false"
}
}
}
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
implementation 'com.Android.support:appcompat-v7:28.0.0-rc02'
// implementation 'com.Android.support:design:27.1.1'
implementation 'com.Android.support:design:28.0.0-rc02'
implementation 'com.Android.support:recyclerview-v7:28.0.0-rc02'
implementation 'com.Android.support:support-v4:28.0.0-rc02'
implementation 'com.Android.support.constraint:constraint-layout:1.1.3'
implementation 'com.Android.support:multidex:1.0.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.Android.support.test:runner:1.0.2'
androidTestImplementation 'com.Android.support.test.espresso:espresso-core:3.0.2'
implementation 'com.google.Android.gms:play-services-maps:15.0.1'
implementation 'com.google.Android.gms:play-services-location:15.0.1'
implementation 'com.google.firebase:firebase-core:16.0.3'
implementation 'com.google.firebase:firebase-auth:16.0.3'
implementation 'com.google.Android.gms:play-services-auth:16.0.0'
implementation 'com.google.firebase:firebase-firestore:17.1.0'
implementation 'com.firebaseui:firebase-ui-firestore:4.1.0'
implementation 'com.crashlytics.sdk.Android:crashlytics:2.9.5'
//Arch
implementation 'Android.Arch.core:runtime:1.1.1'
implementation 'Android.Arch.core:common:1.1.1'
implementation 'com.google.code.gson:gson:2.8.5'
implementation "Android.Arch.work:work-runtime-ktx:1.0.0-alpha09"
// implementation "Android.Arch.work:work-firebase:1.0.0-alpha09"
}
apply plugin: 'com.google.gms.google-services'
編集:gradleでPackagingOptionsを実装しました ここのように
packagingOptions {
exclude 'META-INF/proguard/androidx-annotations.pro'
}
しかし、今回はさらに5つのエラーが発生しました。
1:
Program type already present: com.google.common.util.concurrent.ListenableFuture
Message{kind=ERROR, text=Program type already present: com.google.common.util.concurrent.ListenableFuture, sources=[Unknown source file], tool name=Optional.of(D8)}
2:
Caused by: Java.lang.RuntimeException: com.Android.builder.dexing.DexArchiveMergerException: Error while merging dex archives: ...
3:
Caused by: com.Android.builder.dexing.DexArchiveMergerException: Error while merging dex archives: ...
4:
Caused by: com.Android.tools.r8.CompilationFailedException: Compilation failed to complete
5:
Caused by: com.Android.tools.r8.utils.AbortException
WorkManager 1.0.0-alpha09リリースノート :
既知の問題
次の問題が発生した場合:「OSに依存しないパス 'META-INF/proguard/androidx-annotations.pro'で複数のファイルが見つかりました」を修正する間、一時的な回避策としてgradleファイルに以下を入力してくださいalpha10の問題:
Android {
packagingOptions {
exclude 'META-INF/proguard/androidx-annotations.pro'
}
}
編集:追加のエラーは この問題 :によって引き起こされます
それは意図的に行われます: https://groups.google.com/forum/#!topic/guava-announce/Km82fZG68Sw
グアバの新しいリリースはまもなく準備が整い、その問題は自動的に解決されます。
今のところ、gradleファイルから
"com.google.guava:listenablefuture"
を除外できます:
implementation("Android.Arch.work:work-runtime:1.0.0-alpha09") {
exclude group: 'com.google.guava', module: 'listenablefuture'
}
Guava v27とWorkManagerの最新バージョンを使用したプロジェクトがある場合は、すべて正常に機能します。試してみたところ、プロジェクトが修正されました。
これはうまくビルドされます:
dependencies {
implementation 'Android.Arch.work:work-runtime:1.0.0-beta01'
implementation 'com.google.guava:guava:27.0.1-Android'
}
リリースノートには、このバグは1.0.0-alpha10で修正されたと書かれています。
バグの修正
Androidx-annotations.proファイルの重複に関するalpha09の既知の問題を修正しました。 gradleファイルからexclude 'META-INF/proguard/androidx-annotations.pro'を削除すると、以前のリリースノートから回避策を削除できます。
しかし......何らかの理由で、1.0.0-alpha11バージョンではこのエラーがまだ見られます。
この回避策は、listenablefutureモジュールをwork-runtimeコンポーネントから@ianhanniballakeが指すように除外することです彼の答え。
また、alsowork-firebaseコンポーネントの@Zackがコメントセクションで指摘したものと同じモジュールを除外します。
/*
|--------------------------------------------------------------------------
| WorkManager
|--------------------------------------------------------------------------
*/
def work_version = "1.0.0-alpha11"
implementation("Android.Arch.work:work-runtime:$work_version") {
exclude group: 'com.google.guava', module: 'listenablefuture'
}
// optional - Firebase JobDispatcher support
implementation("Android.Arch.work:work-firebase:$work_version") {
exclude group: 'com.google.guava', module: 'listenablefuture'
}
// optional - Test helpers
androidTestImplementation "Android.Arch.work:work-testing:$work_version"