Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
1.1k views
in Technique[技术] by (71.8m points)

android - java.lang.reflect.InvocationTargetException (no error message) for task ':app:kaptDebugKotlin'

i ran into following error an cannot find an solution.

Execution failed for task ':app:kaptDebugKotlin'.
> A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptExecution
   > java.lang.reflect.InvocationTargetException (no error message)

I cannot say, what I have done last time, probably there is some library causing this error which i had updated. Build Gradle

plugins {
    id 'com.android.application'
    id 'kotlin-android'
    id 'kotlin-parcelize'
    id 'kotlin-kapt'
    id 'dagger.hilt.android.plugin'
    id 'androidx.navigation.safeargs.kotlin'
}

android {
    compileSdkVersion rootProject.compileSdkVersion
    buildToolsVersion "30.0.3"

    defaultConfig {
        applicationId "com.padder.application"
        minSdkVersion rootProject.minSdkVersion
        targetSdkVersion rootProject.targetSdkVersion
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

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

    buildFeatures {
        viewBinding true
    }

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

    kotlinOptions {
        jvmTarget = '1.8'
        freeCompilerArgs += "-Xopt-in=kotlinx.coroutines.ExperimentalCoroutinesApi"
    }
}

dependencies {
    implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlinVersion"
    implementation "androidx.core:core-ktx:$ktxVersion"
    implementation "androidx.appcompat:appcompat:$appCompatVersion"
    implementation "com.google.android.material:material:$materialVersion"
    implementation "androidx.constraintlayout:constraintlayout:$constraintLayoutVersion"
    testImplementation "junit:junit:$junitVersion"
    androidTestImplementation "androidx.test.ext:junit:$testExtJunitVersion"
    androidTestImplementation "androidx.test.espresso:espresso-core:$espressoVersion"

    // Fragment
    implementation "androidx.fragment:fragment-ktx:$fragmentVersion"

    // Navigation Component
    implementation "androidx.navigation:navigation-fragment-ktx:$navigationVersion"
    implementation "androidx.navigation:navigation-ui-ktx:$navigationVersion"

    // Lifecycle + ViewModel & LiveData
    implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycleVersion"
    implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycleVersion"
    implementation "android.arch.lifecycle:common-java8:$lifecycleVersion"

    // Coroutines
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:$coroutinesVersion"
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-android:$coroutinesVersion"

    // DataStore
    implementation "androidx.datastore:datastore-preferences:$dataStoreVersion"

    // Room
    implementation "androidx.room:room-runtime:$roomVersion"
    kapt "androidx.room:room-compiler:$roomVersion"
    implementation "androidx.room:room-ktx:$roomVersion"

    // Dagger Hilt
    implementation "com.google.dagger:hilt-android:$hiltVersion"
    kapt "com.google.dagger:hilt-android-compiler:$hiltVersion"
    implementation "androidx.hilt:hilt-lifecycle-viewmodel:$hiltAndroidXVersion"
    kapt "androidx.hilt:hilt-compiler:$hiltAndroidXVersion"
}

kapt {
    correctErrorTypes true
}

These are my librarys + versions. Hopefully this helps. I give you the full error log as well, so you have, what I have.

Executing tasks: [:app:assembleDebug] in project C:UsersNutzerDesktopIntelliJ_ProjectsApplication

> Task :app:preBuild UP-TO-DATE
> Task :app:preDebugBuild UP-TO-DATE
> Task :app:compileDebugAidl NO-SOURCE
[TASKS]
> Task :app:stripDebugDebugSymbols NO-SOURCE
> Task :app:validateSigningDebug UP-TO-DATE           ^
> Task :app:kaptDebugKotlin FAILED

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:kaptDebugKotlin'.
> A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptExecution
   > java.lang.reflect.InvocationTargetException (no error message)

* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Get more help at https://help.gradle.org

BUILD FAILED in 28s
21 actionable tasks: 2 executed, 19 up-to-date

Because inside the error is the Database mentioned, I give it as well.

package com.padder.application.data

import androidx.room.Database
import androidx.room.RoomDatabase
import javax.inject.Inject

@Database(entities = [Table1::class , Table2::class], version = 1) //exportSchema = false  is not working
abstract class Database : RoomDatabase() {

    abstract fun dao(): Dao
}

Just say if you need more snippeds, but hopefully these arent to much snippets that you not run away.

As wished here is the Dao I use:

package com.padder.application.data

import androidx.room.*
import kotlinx.coroutines.flow.Flow

@Dao
interface Dao {
    /**
     * SQL-Sort
     */
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    suspend fun insert(item: Item)

    @Update
    suspend fun update(item: item)

    @Delete
    suspend fun delete(item: Item)

    // Searchqueries LIST-Fragment
    fun getItemList(sortState: SortSpinnerState, item: String, search: String) : Flow<List<Item>> =
        when (sortState) {
            SortSpinnerState.BY_NAME -> getItemListSortName(item, search)
            SortSpinnerState.BY_TASTE -> getItemListSortTaste(item, search)
            SortSpinnerState.BY_FAV -> getItemListSortFav(item, search)
            SortSpinnerState.BY_LIKE -> getItemListSortLike(item, search)
        }

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE marke = :marke AND name LIKE '%' || :search || '%' ORDER BY name ASC")
    fun getItemListSortName(marke: String, search: String): Flow<List<Item>>

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE marke = :marke AND name LIKE '%' || :search || '%' ORDER BY taste ASC")
    fun getItemListSortTaste(marke: String, search: String): Flow<List<Item>>

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE marke = :marke AND name LIKE '%' || :search || '%' ORDER BY fav = 1 DESC, name ASC")
    fun getItemListSortFav(marke: String, search: String): Flow<List<Item>>

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE marke = :marke AND name LIKE '%' || :search || '%' ORDER BY like = 1 DESC, like = 2 DESC, like = 3 ASC, name ASC")
    fun getItemListSortLike(marke: String, search: String): Flow<List<Item>>

    // Searchqueries HOME-Fragment
    fun getItemListHome(state: SearchByState, search: String) : Flow<List<Item>> =
        when (state) {
            SearchByState.BY_NAME -> getItemListHomeName(search)
            SearchByState.BY_TASTE -> getItemListHomeTaste(search)
            SearchByState.NO_SEARCH -> getItemListHomeNone()
        }

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE name LIKE '%' || :search || '%' ORDER BY name ASC")
    fun getItemListHomeName(search: String): Flow<List<Item>>

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE geschmack LIKE '%' || :search || '%' ORDER BY taste ASC")
    fun getItemListHomeTaste(search: String): Flow<List<Item>>

    @Query("SELECT nr, name, taste, marke, mag, fav FROM tabak WHERE nr = 0 ORDER BY taste ASC")
    fun getItemListHomeNone(): Flow<List<Item>>

    /**
     * SQL-Marke
     */
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    suspend fun insert(marke: Marke)

    @Update
    suspend fun update(marke: Marke)

    @Delete
    suspend fun delete(marke: Marke)

    @Query("SELECT marke FROM marke ORDER BY nr")
    suspend fun getMarkeListe(): List<String>

    @Query("SELECT nr FROM marke WHERE marke = :marke")
    suspend fun getMarkeNr(marke: String): Int
}

So my question. Can you help me to get rid of this error? What did I just do wrong, or what can I do to handle it.
Thank you!

question from:https://stackoverflow.com/questions/65901834/java-lang-reflect-invocationtargetexception-no-error-message-for-task-appka

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

and user with same problem,

the gotten error is because updated the libraries and is causing by an annotation inside the viewholder.

@ViewModelInject is depricated and needs do replaced by @Inject and the class needs to be annotated with @HiltViewModel.

for example:
old: DEPRICATED

class MainViewModel @ViewModelInject constructor() : ViewModel() { ... }

new:

@HiltViewModel
class MainViewModel @Inject constructor() : ViewModel() { ... }

now everything work fine again :))

Have a nice day


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...