Ошибки компиляции после обновления до WorkManager 1.0.0-alpha09

Я пытаюсь использовать WorkManager из компонентов архитектуры. Я обновил compileSdkVersion и targetSdkVersion с 27 до 28. Синхронизация gradle успешно выполнена. Но ошибка времени сборки продолжает появляться. Библиотеки android.support используют версию 28.0.0-rc02 из-за «android.support:design».

Я попытался добавить packageOptions, чтобы исключить proguard / androidx-annotations.pro. Но это не помогло. Но на этот раз я получил другое сообщение об ошибке:

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'

РЕДАКТИРОВАТЬ: я реализовал PackagingOptions в gradle как здесь

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

person Orcun Sevsay    schedule 23.09.2018    source источник


Ответы (3)


В соответствии с примечаниями к выпуску WorkManager 1.0.0-alpha09:

Известная проблема

Если вы столкнулись со следующей проблемой: было найдено более одного файла с независимым от ОС путем 'META-INF / proguard / androidx-annotations.pro', пожалуйста, поместите следующее в свой файл gradle в качестве временного обходного пути, пока мы исправим проблему в альфа10:

android {
    packagingOptions {
        exclude 'META-INF/proguard/androidx-annotations.pro'
    }
}

Изменить: Ваши дополнительные ошибки вызваны этой проблемой:

Это сделано специально: https://groups.google.com/forum/#!topic/guava-announce/Km82fZG68Sw

Скоро будет готов новый выпуск гуавы, который решит эту проблему автоматически.

На данный момент вы можете исключить "com.google.guava:listenablefuture" из своего файла gradle:

implementation("android.arch.work:work-runtime:1.0.0-alpha09") {
    exclude group: 'com.google.guava', module: 'listenablefuture' 
}
person ianhanniballake    schedule 23.09.2018
comment
Спасибо @ianhanniballake. Но на этот раз я получил 5 дополнительных ошибок. Я обновил свой вопрос выше. - person Orcun Sevsay; 23.09.2018
comment
Это совершенно другая проблема, не имеющая отношения к первой, поэтому, вероятно, это должен быть отдельный вопрос, но я также обновил свой ответ на этот вопрос. - person ianhanniballake; 23.09.2018
comment
Я обнаружил, что исключение listenablefuture необходимо и для компонента firebase, т.е. implementation("android.arch.work:work-firebase:1.0.0-alpha09") { exclude group: 'com.google.guava', module: 'listenablefuture' } - person zack; 28.09.2018
comment
Мне также понадобилось исключение из компонента firebase. Спасибо! - person Keith Holliday; 18.10.2018
comment
Я все еще вижу эту проблему в 1.0.0-alpha10, исправление все еще требуется. - person ThanksMister; 08.11.2018
comment
Я использую 1.0.0-alpha11, и я все еще вижу ошибку (Ошибка: тип программы уже присутствует: com.google.common.util.concurrent.ListenableFuture) !!! - person chebaby; 12.11.2018
comment
И вы будете видеть это до тех пор, пока не обновитесь до Guava 27.0, когда Guava начнет использовать ту же зависимость ListenableFuture, что и WorkManager. Одна из ваших зависимостей, вероятно, все еще использует более старую версию. - person ianhanniballake; 12.11.2018
comment
Думаю, в этом больше нет необходимости. Используйте это: final def work_version = "2.0.1" implementation "androidx.work:work-runtime-ktx:$work_version" implementation "androidx.work:work-rxjava2:$work_version" - person android developer; 20.05.2019

Все работает нормально, если у вас есть проект с Guava v27 и последней версией WorkManager. Я только что попробовал, и это исправляет мой проект.

Это отлично работает:

dependencies {
   implementation 'android.arch.work:work-runtime:1.0.0-beta01'
   implementation 'com.google.guava:guava:27.0.1-android'
}
person wiseminds    schedule 07.03.2019
comment
У меня это сработало после добавления всего одной зависимости, спасибо implementation 'com.google.guava:guava:27.0.1-android' - person dev90; 11.05.2020

В примечаниях к выпуску говорится, что эта ошибка была исправлена ​​в 1.0.0-alpha10:

Исправление ошибок

Исправлена ​​известная проблема от alpha09, касающаяся дублирования файлов androidx-annotations.pro. Вы можете удалить обходной путь из предыдущих примечаний к выпуску, удалив exclude 'META-INF / proguard / androidx-annotations.pro' из вашего файла gradle.

исходный код


Но ... по какой-то причине я все еще вижу эту ошибку в версии 1.0.0-alpha11.

обходной путь для этого - исключить модуль listenablefuture из компонента work-runtime, как указал @ianhanniballake в своем ответе.

И также исключите тот же модуль в компоненте work-firebase, который @Zack указал в разделе комментариев.


build.gradle

    /*
    |--------------------------------------------------------------------------
    | 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"
person chebaby    schedule 12.11.2018