У меня есть пользовательская реализация ViewModel.Factory
, которая обеспечивается лямбда-выражением, введенным Dagger2
interface ViewModelFactoryComponent {
val factoryProvider: (Bundle?) -> ViewModelProvider.Factory
}
Реализация Dagger выглядит следующим образом:
@Module
class ViewModelModule {
@Provides
@Singleton
fun bindViewModelFactory(creators: Map<Class<out ViewModel>, @JvmSuppressWildcards Provider<(Bundle?) -> ViewModel>>): (Bundle?) -> ViewModelProvider.Factory {
return { ViewModelFactory(creators, it) }
}
}
@Singleton
@Component(modules = [ ApplicationModule::class, ViewModelModule::class])
interface ApplicationComponent : ViewModelFactoryComponent
В приложении все работает какпри попытке настроить тест Espresso
возникла проблема, но возникла проблема.Вот конфигурация тестового компонента кинжала:
@Singleton
@Component(modules = [ApplicationModule::class, ViewModelModule::class])
interface TestComponent : ApplicationComponent
Теперь в чем проблема - реализация тестового компонента, генерируемая функцией генерации кинжала, подобной этой
@Override
public Function1<Bundle, ViewModelProvider$Factory> getFactoryProvider() {
return bindViewModelFactoryProvider.get();
}
, которая генерирует ошибку компиляции, а не как в реальном приложении:
@Override
public Function1<Bundle, ViewModelProvider.Factory> getFactoryProvider() {
return bindViewModelFactoryProvider.get();
}
Сначала я подумал, что это случай ViewModelProvider.Factory
видимости, но все модификации build.gradle
не помогли.Я столкнулся с полным отсутствием идеи, поэтому я буду рад по крайней мере некоторым предложениям.
ОБНОВЛЕНИЕ Я создал пустой проект, чтобы воспроизвести эту ошибку, и она должна быть полностью повторяемой.
Файл в каталоге main
:
@Singleton
@Component(modules = [ViewModelModule::class])
interface ApplicationComponent : ViewModelFactoryComponent
@Module
class ViewModelModule {
@Provides
@Singleton
fun bindViewModelFactory(): () -> ViewModelProvider.Factory {
return { ViewModelFactory() }
}
}
interface ViewModelFactoryComponent {
val factoryProvider: () -> ViewModelProvider.Factory
}
class ViewModelFactory @Inject constructor() : ViewModelProvider.Factory {
override fun <T : ViewModel> create(modelClass: Class<T>): T {
return modelClass.newInstance()
}
}
class MainActivity : AppCompatActivity()
Файл в каталоге androidTest
:
@Singleton
@Component(modules = [ViewModelModule::class])
interface TestComponent : ApplicationComponent
@RunWith(AndroidJUnit4::class)
class TestCase {
@get:Rule
val activityTestRule = ActivityTestRule(MainActivity::class.java, false, false)
@Test
fun appLaunchesSuccessfully() {
ActivityScenario.launch(MainActivity::class.java)
}
}
И это все зависимости:
implementation"org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'com.google.dagger:dagger:2.21'
kapt 'com.google.dagger:dagger-compiler:2.21'
kaptAndroidTest 'com.google.dagger:dagger-compiler:2.21'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
androidTestImplementation 'androidx.test.ext:junit:1.1.0'
androidTestImplementation 'androidx.test:rules:1.1.1'
Приложение создается без проблем, но когда я пытаюсь запустить appLaunchesSuccessfully()
test, появляется ошибка компиляции по вышеуказанной причине.
Edit Итак, я понял, что без kaptAndroidTest 'com.google.dagger:dagger-compiler:2.21'
Тестовый проект может быть успешно собран.
Плохо то, что без него класс компонента кинжала не будет генерироваться.