API 'option.getExternalNativeBuildTasks()' устарел и был заменен на 'option.getExternalNativeBuildProviders()

Использование Android Studio 3.3 Canary 11 с версией плагина gradle 3.3.0-alpha11, Выдает следующую ошибку при попытке синхронизировать Gradle

WARNING: API 'variant.getExternalNativeBuildTasks()' is obsolete and has been 
replaced with 'variant.getExternalNativeBuildProviders()'.
It will be removed at the end of 2019.
For more information, see https://d.android.com/r/tools/task-configuration- 
avoidance
Affected Modules: app

Нажатие на ошибку приводит меня к этой строке в файле Gradle

applicationVariants.all { variant ->
            variant.outputs.all {
                outputFileName = "${variant.name}-${variant.versionName}.apk"
            }
        }

Что именно мне нужно изменить здесь?

проект build.gradle

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

buildscript {
    repositories {
        jcenter()
        mavenCentral() // jcenter() works as well because it pulls from Maven Central
        maven { url "https://maven.google.com" }
        google()
    }

    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0-alpha11'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
        classpath "io.realm:realm-gradle-plugin:4.1.1"
        classpath 'com.google.gms:google-services:3.2.1'
        classpath 'com.google.firebase:firebase-plugins:1.1.5'
    }
}

allprojects {
    repositories {
        jcenter()
        maven { url "https://maven.google.com" }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

// Define versions in a single place
ext {
    // Sdk and tools
    minSdkVersion = 21
    targetSdkVersion = 27
    compileSdkVersion = 27
    buildToolsVersion = '27.0.3'

    // App dependencies
    supportLibraryVersion = '27.1.1'
    appCompactLibraryVersion = '27.1.1'
    playServicesVersion = '15.0.1'
    firebaseVersionCore = '16.0.1'
    firebaseVersionPerf = '16.0.0'
    firebaseVersionMessaging = '17.1.0'

    //lottie
    lottieVersion = '2.5.0'
}

приложение build.gradle

buildscript {
    repositories {
        maven { url 'https://maven.fabric.io/public' }
    }

    dependencies {
        classpath 'io.fabric.tools:gradle:1.25.4'
    }
    buildscript {
        repositories {
            maven { url "https://maven.google.com" }
            maven { url 'https://maven.fabric.io/public' }
            mavenCentral()

        }

        dependencies {
            // These docs use an open ended version so that our plugin
            // can be updated quickly in response to Android tooling updates

            // We recommend changing it to the latest version from our changelog:
            // https://docs.fabric.io/android/changelog.html#fabric-gradle-plugin
            classpath 'io.fabric.tools:gradle:'
        }
    }
}
apply plugin: 'com.android.application'
apply plugin: 'com.google.firebase.firebase-perf'
repositories {
    maven { url 'https://maven.fabric.io/public' }
}

apply plugin: 'io.fabric'
apply plugin: 'realm-android'

android {

    realm {
        syncEnabled = false
    }

    dexOptions {
        javaMaxHeapSize "4g"
    }

    compileSdkVersion rootProject.ext.compileSdkVersion

    defaultConfig {
        applicationId "example.com"
        minSdkVersion rootProject.ext.minSdkVersion
        multiDexEnabled true
        versionCode mVersionCode
        versionName mVersionName
        vectorDrawables.useSupportLibrary = true

    }

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

    buildTypes {

        applicationVariants.all { variant ->
            variant.outputs.all {
                outputFileName = "${variant.name}-${variant.versionName}.apk"
            }
        }

        release {
            shrinkResources true
            minifyEnabled true
            useProguard true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

            lintOptions {
                disable 'MissingTranslation'
            }

            applicationVariants.all { variant ->
                variant.outputs.all {
                    outputFileName = "${variant.name}-${variant.versionName}.apk"
                }
            }

        }
        debug {
            shrinkResources true
            minifyEnabled true
            useProguard true
            debuggable true
            versionNameSuffix '-DEBUG'
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'debug-proguard-rules.pro'

            ext.enableCrashlytics = false
            crunchPngs false

        }
    }

    flavorDimensions "default"

    lintOptions {

        checkReleaseBuilds false

    }

    packagingOptions {
        exclude 'META-INF/DEPENDENCIES.txt'
        exclude 'META-INF/LICENSE.txt'
        exclude 'META-INF/NOTICE.txt'
        exclude 'META-INF/NOTICE'
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/DEPENDENCIES'
        exclude 'META-INF/notice.txt'
        exclude 'META-INF/license.txt'
        exclude 'META-INF/dependencies.txt'
        exclude 'META-INF/LGPL2.1'
    }
    buildToolsVersion '28.0.2'
}

configurations {
    implementation.exclude group: "org.apache.httpcomponents", module: "httpclient"
}

dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')

    implementation "com.android.support:appcompat-v7:$rootProject.appCompactLibraryVersion"
    implementation "com.android.support:support-compat:$rootProject.supportLibraryVersion"
    implementation "com.android.support:mediarouter-v7:$rootProject.supportLibraryVersion"
    implementation "com.android.support:cardview-v7:$rootProject.supportLibraryVersion"
    implementation "com.android.support:design:$rootProject.supportLibraryVersion"


    api 'com.squareup.retrofit2:retrofit:2.4.0'
    api 'com.squareup.okhttp3:okhttp:3.11.0'
    api 'com.squareup.okhttp3:logging-interceptor:3.10.0'
    implementation 'com.google.code.gson:gson:2.8.2'
    implementation 'com.squareup.retrofit2:converter-gson:2.3.0'
    implementation 'com.squareup.picasso:picasso:2.5.2'
    implementation 'com.squareup.retrofit2:adapter-rxjava:2.3.0'
    implementation 'com.android.support:multidex:1.0.3'
    implementation 'com.daimajia.easing:library:2.0@aar'
    implementation 'com.daimajia.androidanimations:library:2.3@aar'

    implementation 'com.akexorcist:googledirectionlibrary:1.0.5'
    implementation 'io.reactivex:rxandroid:1.2.1'
    implementation 'io.reactivex:rxjava:1.3.0'
    // Wifi hotspot library
    implementation 'cc.mvdan.accesspoint:library:0.2.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    implementation 'org.jsoup:jsoup:1.10.3'
    api "com.airbnb.android:lottie:$rootProject.lottieVersion"
    implementation 'com.android.support:support-v4:27.1.1'
    implementation 'com.android.support:recyclerview-v7:27.1.1'
    testImplementation 'junit:junit:4.12'
    implementation 'com.jakewharton:butterknife:8.8.1'

    debugImplementation 'com.squareup.leakcanary:leakcanary-android:1.5.4'
    releaseImplementation 'com.squareup.leakcanary:leakcanary-android-no-op:1.5.4'

    implementation 'com.googlecode.libphonenumber:libphonenumber:8.2.0'

    implementation "com.google.android.gms:play-services-base:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-cast-framework:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-auth:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-identity:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-awareness:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-cast:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-drive:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-location:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-maps:$rootProject.playServicesVersion"

    implementation "com.google.firebase:firebase-core:$rootProject.firebaseVersionCore"
    implementation "com.google.firebase:firebase-perf:$rootProject.firebaseVersionPerf"
    implementation "com.google.firebase:firebase-messaging:$rootProject.firebaseVersionMessaging"
    implementation "com.google.firebase:firebase-analytics:$rootProject.firebaseVersionCore"


    api('com.crashlytics.sdk.android:crashlytics:2.8.0@aar') {
        transitive = true
    }
    api('com.crashlytics.sdk.android:answers:1.4.1@aar') {
        transitive = true
    }
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.8.1'
    api project(path: ':libraryBTHelper')
    api project(':bkk_rush')

    debugApi 'com.amitshekhar.android:debug-db:1.0.3'
    api "org.jdeferred:jdeferred-android-aar:1.2.6"
    implementation 'com.android.support:gridlayout-v7:27.1.1'
}

apply plugin: 'com.google.gms.google-services'

Я пропустил несколько констант и другую конфиденциальную информацию в файле app/build.gradle.

2 ответа

Проблема была исправлена ​​в их последней версии 'io.fabric.tools:gradle:1.28.0'

Пожалуйста, обновите ваши оба инструмента Gradle Fabric с 1.28.0

buildscript {
  // ... repositories, etc. ...

   dependencies {
       // ...other dependencies ...
       classpath 'io.fabric.tools:gradle:1.28.0'
   }
}

Для получения дополнительной информации https://github.com/firebase/firebase-android-sdk/issues/198

Это происходит после того, как я обновил Android Studio до 3.3.0. apply plugin: 'io.fabric' это причина. Я отправил отчет об ошибке в команду Firebase об этой проблеме.

У вас есть 3 варианта:

  • Подождите, пока не выйдет следующая версия плагина Fabric. Проверьте последнюю версию здесь.

  • Переход на Android Studio 3.2.1.

  • Закомментируйте io.fabric плагин.

В build.gradle модуля вашего приложения:

apply plugin: 'com.android.application'
// apply plugin: 'io.fabric' <== this plugin causes the error

Однако вы все равно можете создавать и запускать свои проекты, даже если эта ошибка появляется. Просто игнорируй это.

В приложении build.gradle перейдите на эту стабильную версию gradle:

classpath 'com.android.tools.build:gradle:3.2.1'

Это происходит после того, как я обновил Android Studio до версии 3.3, пока решение не будет исправлено!

редактировать: вам не нужно понижать вашу андроид студию!

Если комментировать Crashlyticsплагин io.fabric на файл приложения Gradle временно работал для вас

//apply plugin: 'io.fabric'

Тогда обновление ваших зависимостей структуры матрицы в файле проекта Project навсегда решит проблему:

classpath 'io.fabric.tools:gradle:1.27.0'

NB: это не удаляет предупреждения, но позволяет вам использовать Crashlytics с AS3.3+

Не уверен, что является фактической проблемой, но комментируя зависимости, связанные с сбоем, от решенной проблемы проекта.

Это подтверждено как ошибка для Crashlytics, и они работают над этим.

https://issuetracker.google.com/issues/116408637

Цитируется от правопреемника Google:

je... @ google.com # 23 23 января 2019 01:40
Всем привет,

Спасибо за терпеливость.

Похоже, что ошибка во всех случаях происходит от сбоев, и я подал ошибку с ними.

Я буду держать вас в курсе статуса.

Для меня мое приложение отладки работает нормально на моем устройстве, просто запустив и игнорируя предупреждение, не комментируя Crashlytics или Fabric. Я не пытался для производства.

Обновить:

Google Issue Tracker пометил эти проблемы как Не Исправить (Невозможно), потому что все проблемы были из Crashlytics, и разрешил исправления, сделанные командой Crashlytics (несмотря на то, что они все те же Googler...).

Они предлагают перейти по этой ссылке для обновления Crashlytics:

https://github.com/firebase/firebase-android-sdk/issues/198

Примечание: я все еще использую Android Studio 3.3 с io.fabric.tools:gradle:1.26.0, не комментируя Craslytics, и он отлично работает в моем приложении отладки.

Последние новости от 24.01.2009

Информация здесь https://issuetracker.google.com/issues/116408637

Нам нужно будет подождать, пока Crashlytics не найдет решение, вот проблема GitHub открыта

https://github.com/firebase/firebase-android-sdk/issues/198

Единственный способ, которым я сейчас пользуюсь, чтобы не комментировать плагин io.fabric, - понижение версии моего gradle и обновление моего пути к классу ткани (это работает над моим рабочим приложением)

 dependencies {
        classpath 'com.android.tools.build:gradle:3.2.1'
        classpath 'com.google.gms:google-services:4.2.0'
        classpath 'io.fabric.tools:gradle:1.27.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }

Как уже было сказано, проблема с Fabric/Crashlytics.

apply plugin: 'io.fabric'

Это ошибка со стороны Crashlytics/Firebase, проверьте следующую ссылку и посмотрите статус ошибки: https://github.com/firebase/firebase-android-sdk/issues/198

Средство отслеживания проблем может относиться к "отложенной конфигурации задачи" -

это, по крайней мере, то, что предлагает избегание конфигурации задачи.

но, возможно, можно предотвратить доступ к этому устаревшему методу BaseVariantImpl, когда variant.outputs.all не получит доступ к этому методу (внутренне) - или когда проверки могут предотвратить доступ; или при доступе к варианту по его имени; или как-то отключить внешние родные задачи сборки для варианта. также см. вариант синхронизации проекта с одним вариантом, который скорее кажется связанным.

или жди инструментов сборки 3.3.0-alpha12 или же 3.3.0-beta1... это даже не release candidate поэтому тратить много времени бессмысленно - разве что использовать его для составления другого отчета об ошибке.

новый быстрый отзыв быстрая обратная связь Кнопка по-прежнему выглядит наиболее перспективной.

Для меня я выполнил следующие шаги: 1. обновить зависимость Gradle на уровне проекта build.gradle.

        classpath 'io.fabric.tools:gradle:1.28.0'
  1. Добавьте эту зависимость от плагина ниже. Примените плагин: 'com.android.application' на уровне приложения build.gradle.

        apply plugin: 'io.fabric'
    
  2. Синхронизируйте проект с файлами Gradle.

Это происходит из-за обновления вашей Android Studio с Android Studio 3.2.0 до Android Studio 3.3.0. Обновите ваши зависимости Gradle (Проект) IO.Fabric. Подобно:

classpath 'io.fabric.tools:gradle:1.27.1'

а также обновите версию Kotlin до

classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.3.20"

Это решит эту проблему. Спасибо

В журнале сборки выводится, как это отладить, особенно вам нужно запустить сборку с -Pandroid.debug.obsoleteApi=true, это напечатает трассировку стека вызова к устаревшему API, и вы сможете выяснить, какой плагин / код вызывает его.

Если это в конечном итоге ваш код - используйте новый API провайдера (см. Документ Lazy Task Configuration)

Если это исходит от других плагинов - сообщите им с трассировкой стека и предупреждающим сообщением и, возможно, отправьте патч. Как в этом случае его связано с io.fabric вопрос.

Я также не смог запустить проект после обновления Android Studio. Но после удаления.gradle, .idea, создания папок и повторного импорта проекта все заработало, но предупреждение все равно осталось.

Изменение совместимости источника в модуле build.gradle файл в Java 8 решает проблему

compileOptions {
    sourceCompatibility 1.8
    targetCompatibility 1.8
}

Обязательно пересоберите проект после добавления этих строк

Когда я открыл проект, я нажал Run migrations Кнопка появилась в правом нижнем углу от Android Studio, Была выполнена миграция, и проблема была решена без комментирования Crashlytics зависимость.

Исправление заключается в обновлении корневых файлов gradle до последней версии. И этот ответ верен сейчас. в будущем новые изменения будут реализованы с помощью Gradle и Android SDK. Иногда ответ будет меняться со временем.

repositories {
    maven { url "https://jitpack.io" }
    maven {
        url 'https://maven.fabric.io/public'
    }
    google()
    jcenter()

}
dependencies {

    classpath 'com.android.tools.build:gradle:3.5.0'
    classpath 'com.google.gms:google-services:4.3.0'
    classpath 'io.fabric.tools:gradle:1.30.0'
}

Для тех, кому необходимо применить плагин Fabric, временное решение - вернуться к предыдущей версии Gradle на уровне проекта.

Измените версию пути к классам на com.android.tools.build:gradle:3.2.1,

В моем случае мне нужно было использовать io.fabric Плагин, и решение было, чтобы обновить до последней версии Gradle инструментов для тканей:

classpath 'com.android.tools.build:gradle:3.3.0'
classpath 'io.fabric.tools:gradle:1.27.0'

Это исправит ошибку: На панели задач выберите Сервис->Kotlin-> Настроить Kotlin в Project.

Это была проблема с последним gradle (в моем случае 3.3.2) версия и Fabric.io плагин. Теперь это решается с помощью новой версии. Пользователи должны иметь это на своем верхнем уровне. build.gradle:

buildscript {
   // ... repositories, etc. ...

    dependencies {
        // ...other dependencies ...
        classpath 'io.fabric.tools:gradle:1.28.0'
    }
}

В первую очередь это не ошибка

это предупреждение

и он появляется при обновлении до версии 3.3.0. Часто это происходит из-за того, что io.fabric ждет, пока текущая версия обновленной структуры, где все еще отображается предупреждение, будет io.fabric.tools:gradle:1.27.1.