From eb4ac88bb298c128c60661320f6e657fade16ad3 Mon Sep 17 00:00:00 2001 From: Jesse Wilson Date: Wed, 16 Oct 2024 15:14:22 -0400 Subject: [PATCH] Adopt Burst in Redwood --- build.gradle | 1 + gradle/libs.versions.toml | 4 +- redwood-compose/build.gradle | 1 + .../redwood/compose/ChangeListenerTest.kt | 85 ++++++++++++------- redwood-gradle-plugin/build.gradle | 1 - redwood-layout-composeui/build.gradle | 2 +- .../layout/composeui/ComposeUiBoxTest.kt | 8 +- .../composeui/ComposeUiFlexContainerTest.kt | 8 +- redwood-layout-view/build.gradle | 3 +- .../cash/redwood/layout/view/ViewBoxTest.kt | 8 +- .../layout/view/ViewFlexContainerTest.kt | 8 +- redwood-lazylayout-composeui/build.gradle | 2 +- .../layout/composeui/ComposeUiLazyListTest.kt | 8 +- redwood-lazylayout-view/build.gradle | 3 +- .../view/ViewLazyListAsFlexContainerTest.kt | 8 +- .../lazylayout/view/ViewLazyListTest.kt | 3 - redwood-tooling-codegen/build.gradle | 3 +- .../codegen/DeprecatedGenerationTest.kt | 14 +-- redwood-tooling-schema/build.gradle | 1 - redwood-widget-view-test/build.gradle | 3 +- .../widget/view/ViewRedwoodViewTest.kt | 8 +- 21 files changed, 93 insertions(+), 89 deletions(-) diff --git a/build.gradle b/build.gradle index fda79d3bf4..2c915cadc4 100644 --- a/build.gradle +++ b/build.gradle @@ -4,6 +4,7 @@ buildscript { classpath libs.kotlin.serializationPlugin classpath libs.atomicFuPlugin classpath libs.buildConfigPlugin + classpath libs.burst.gradle.plugin classpath libs.zipline.gradlePlugin classpath libs.paparazzi.gradlePlugin classpath libs.poko.gradlePlugin diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 014a1c64b6..197abfe2c5 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -11,6 +11,7 @@ paparazzi = "1.3.2" zipline = "1.17.0" coil = "3.0.0-rc01" okio = "3.9.1" +burst = "0.4.0" [libraries] kotlin-compiler = { module = "org.jetbrains.kotlin:kotlin-compiler", version.ref = "kotlin" } @@ -69,10 +70,11 @@ jetbrains-compose-ui-tooling = { module = "org.jetbrains.compose.ui:ui-tooling", jetbrains-compose-ui-tooling-preview = { module = "org.jetbrains.compose.ui:ui-tooling-preview", version.ref = "jbCompose" } androidGradlePlugin = { module = "com.android.tools.build:gradle", version = "8.7.1" } +burst = { module = "app.cash.burst:burst", version.ref = "burst" } +burst-gradle-plugin = { module = "app.cash.burst:burst-gradle-plugin", version.ref = "burst" } kotlinPoet = { module = "com.squareup:kotlinpoet", version = "1.18.1" } clikt = "com.github.ajalt.clikt:clikt:5.0.1" junit = { module = "junit:junit", version = "4.13.2" } -testParameterInjector = { module = "com.google.testparameterinjector:test-parameter-injector", version = "1.18" } assertk = "com.willowtreeapps.assertk:assertk:0.28.1" robolectric = { module = "org.robolectric:robolectric", version = "4.13" } okio = { module = "com.squareup.okio:okio", version.ref = "okio" } diff --git a/redwood-compose/build.gradle b/redwood-compose/build.gradle index ddcd1641e4..b2ec6ef92c 100644 --- a/redwood-compose/build.gradle +++ b/redwood-compose/build.gradle @@ -8,6 +8,7 @@ redwoodBuild { } apply plugin: 'org.jetbrains.kotlin.plugin.compose' +apply plugin: 'app.cash.burst' kotlin { applyDefaultHierarchyTemplate { diff --git a/redwood-compose/src/commonTest/kotlin/app/cash/redwood/compose/ChangeListenerTest.kt b/redwood-compose/src/commonTest/kotlin/app/cash/redwood/compose/ChangeListenerTest.kt index 50319c1429..c20beea909 100644 --- a/redwood-compose/src/commonTest/kotlin/app/cash/redwood/compose/ChangeListenerTest.kt +++ b/redwood-compose/src/commonTest/kotlin/app/cash/redwood/compose/ChangeListenerTest.kt @@ -18,8 +18,8 @@ package app.cash.redwood.compose import androidx.compose.runtime.getValue import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.setValue +import app.cash.burst.Burst import app.cash.redwood.Modifier -import app.cash.redwood.RedwoodCodegenApi import app.cash.redwood.layout.testing.RedwoodLayoutTestingWidgetFactory import app.cash.redwood.lazylayout.testing.RedwoodLazyLayoutTestingWidgetFactory import app.cash.redwood.leaks.LeakDetector @@ -47,44 +47,65 @@ import kotlin.test.Test import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.test.runTest -class DirectChangeListenerTest : AbstractChangeListenerTest() { - override fun CoroutineScope.launchComposition( - widgetSystem: TestSchemaWidgetSystem, - snapshot: () -> T, - ) = TestRedwoodComposition(this, widgetSystem, MutableListChildren(), createSnapshot = snapshot) -} - -class ProtocolChangeListenerTest : AbstractChangeListenerTest() { - override fun CoroutineScope.launchComposition( - widgetSystem: TestSchemaWidgetSystem, - snapshot: () -> T, - ): TestRedwoodComposition { - val guestAdapter = DefaultGuestProtocolAdapter( - hostVersion = hostRedwoodVersion, - widgetSystemFactory = TestSchemaProtocolWidgetSystemFactory, - ) - val hostAdapter = HostProtocolAdapter( - guestVersion = guestRedwoodVersion, +enum class ComposeLauncher { + Direct { + override fun launchComposition( + scope: CoroutineScope, + widgetSystem: TestSchemaWidgetSystem, + snapshot: () -> T, + ) = TestRedwoodComposition( + scope = scope, + widgetSystem = widgetSystem, container = MutableListChildren(), - factory = TestSchemaProtocolFactory(widgetSystem), - eventSink = { throw AssertionError() }, - leakDetector = LeakDetector.none(), + createSnapshot = snapshot, ) - guestAdapter.initChangesSink(hostAdapter) - return TestRedwoodComposition(this, guestAdapter.widgetSystem, guestAdapter.root) { - guestAdapter.emitChanges() - snapshot() + }, + + Protocol { + override fun launchComposition( + scope: CoroutineScope, + widgetSystem: TestSchemaWidgetSystem, + snapshot: () -> T, + ): TestRedwoodComposition { + val guestAdapter = DefaultGuestProtocolAdapter( + hostVersion = hostRedwoodVersion, + widgetSystemFactory = TestSchemaProtocolWidgetSystemFactory, + ) + val hostAdapter = HostProtocolAdapter( + guestVersion = guestRedwoodVersion, + container = MutableListChildren(), + factory = TestSchemaProtocolFactory(widgetSystem), + eventSink = { throw AssertionError() }, + leakDetector = LeakDetector.none(), + ) + guestAdapter.initChangesSink(hostAdapter) + return TestRedwoodComposition( + scope = scope, + widgetSystem = guestAdapter.widgetSystem, + container = guestAdapter.root, + ) { + guestAdapter.emitChanges() + snapshot() + } } - } -} + }, + ; -@OptIn(RedwoodCodegenApi::class) -abstract class AbstractChangeListenerTest { - // There is no test parameter injector in multiplatform, so we fake it with subtypes. - abstract fun CoroutineScope.launchComposition( + abstract fun launchComposition( + scope: CoroutineScope, widgetSystem: TestSchemaWidgetSystem, snapshot: () -> T, ): TestRedwoodComposition +} + +@Burst +class ChangeListenerTest( + private val launcher: ComposeLauncher, +) { + private fun CoroutineScope.launchComposition( + widgetSystem: TestSchemaWidgetSystem, + snapshot: () -> T, + ): TestRedwoodComposition = launcher.launchComposition(this, widgetSystem, snapshot) @Test fun propertyChangeNotifiesWidget() = runTest { diff --git a/redwood-gradle-plugin/build.gradle b/redwood-gradle-plugin/build.gradle index d85c9e2b6c..e1dc88a21a 100644 --- a/redwood-gradle-plugin/build.gradle +++ b/redwood-gradle-plugin/build.gradle @@ -38,7 +38,6 @@ dependencies { compileOnly libs.androidGradlePlugin testImplementation libs.junit - testImplementation libs.testParameterInjector testImplementation libs.assertk testImplementation gradleTestKit() diff --git a/redwood-layout-composeui/build.gradle b/redwood-layout-composeui/build.gradle index 5fca28ad25..99a5b47675 100644 --- a/redwood-layout-composeui/build.gradle +++ b/redwood-layout-composeui/build.gradle @@ -7,6 +7,7 @@ redwoodBuild { apply plugin: 'org.jetbrains.kotlin.plugin.compose' apply plugin: 'org.jetbrains.kotlin.plugin.serialization' +apply plugin: 'app.cash.burst' apply plugin: 'app.cash.paparazzi' kotlin { @@ -25,7 +26,6 @@ kotlin { dependencies { implementation projects.redwoodLayoutSharedTest implementation projects.redwoodSnapshotTesting - implementation libs.testParameterInjector } } } diff --git a/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiBoxTest.kt b/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiBoxTest.kt index fdb04fbca6..0fd71d60bd 100644 --- a/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiBoxTest.kt +++ b/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiBoxTest.kt @@ -16,6 +16,7 @@ package app.cash.redwood.layout.composeui import androidx.compose.runtime.Composable +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractBoxTest @@ -23,14 +24,11 @@ import app.cash.redwood.layout.widget.Box import app.cash.redwood.snapshot.testing.ComposeSnapshotter import app.cash.redwood.snapshot.testing.ComposeUiTestWidgetFactory import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ComposeUiBoxTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractBoxTest<@Composable () -> Unit>() { @get:Rule diff --git a/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiFlexContainerTest.kt b/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiFlexContainerTest.kt index 6d6bb2a2d2..181f1f1718 100644 --- a/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiFlexContainerTest.kt +++ b/redwood-layout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiFlexContainerTest.kt @@ -19,6 +19,7 @@ import androidx.compose.foundation.background import androidx.compose.runtime.Composable import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractFlexContainerTest @@ -32,15 +33,12 @@ import app.cash.redwood.widget.Widget import app.cash.redwood.widget.compose.ComposeWidgetChildren import app.cash.redwood.yoga.FlexDirection import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import kotlinx.coroutines.runBlocking import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ComposeUiFlexContainerTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractFlexContainerTest<@Composable () -> Unit>() { override val widgetFactory = ComposeUiTestWidgetFactory diff --git a/redwood-layout-view/build.gradle b/redwood-layout-view/build.gradle index d938b2afcc..5c7840511f 100644 --- a/redwood-layout-view/build.gradle +++ b/redwood-layout-view/build.gradle @@ -6,15 +6,16 @@ redwoodBuild { } apply plugin: 'org.jetbrains.kotlin.plugin.serialization' +apply plugin: 'app.cash.burst' apply plugin: 'app.cash.paparazzi' dependencies { api projects.redwoodLayoutWidget implementation projects.redwoodYoga implementation libs.androidx.core + testImplementation libs.burst testImplementation projects.redwoodLayoutSharedTest testImplementation projects.redwoodSnapshotTesting - testImplementation libs.testParameterInjector } android { diff --git a/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewBoxTest.kt b/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewBoxTest.kt index f8da027ba6..dcb7ba0361 100644 --- a/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewBoxTest.kt +++ b/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewBoxTest.kt @@ -18,6 +18,7 @@ package app.cash.redwood.layout.view import android.graphics.drawable.ColorDrawable import android.view.View import android.widget.FrameLayout +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractBoxTest @@ -26,14 +27,11 @@ import app.cash.redwood.snapshot.testing.Snapshotter import app.cash.redwood.snapshot.testing.ViewSnapshotter import app.cash.redwood.snapshot.testing.ViewTestWidgetFactory import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ViewBoxTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractBoxTest() { @get:Rule diff --git a/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewFlexContainerTest.kt b/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewFlexContainerTest.kt index cf867476b1..42ebae5b4e 100644 --- a/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewFlexContainerTest.kt +++ b/redwood-layout-view/src/test/kotlin/app/cash/redwood/layout/view/ViewFlexContainerTest.kt @@ -16,6 +16,7 @@ package app.cash.redwood.layout.view import android.view.View +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractFlexContainerTest @@ -30,14 +31,11 @@ import app.cash.redwood.widget.ViewGroupChildren import app.cash.redwood.widget.Widget import app.cash.redwood.yoga.FlexDirection import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ViewFlexContainerTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractFlexContainerTest() { @get:Rule diff --git a/redwood-lazylayout-composeui/build.gradle b/redwood-lazylayout-composeui/build.gradle index ae24fb029e..16e008c535 100644 --- a/redwood-lazylayout-composeui/build.gradle +++ b/redwood-lazylayout-composeui/build.gradle @@ -6,6 +6,7 @@ redwoodBuild { } apply plugin: 'org.jetbrains.kotlin.plugin.compose' +apply plugin: 'app.cash.burst' apply plugin: 'app.cash.paparazzi' kotlin { @@ -24,7 +25,6 @@ kotlin { implementation projects.redwoodLayoutComposeui implementation projects.redwoodLayoutSharedTest implementation projects.redwoodSnapshotTesting - implementation libs.testParameterInjector } } } diff --git a/redwood-lazylayout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiLazyListTest.kt b/redwood-lazylayout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiLazyListTest.kt index ebda3edd33..5e48364128 100644 --- a/redwood-lazylayout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiLazyListTest.kt +++ b/redwood-lazylayout-composeui/src/androidUnitTest/kotlin/app/cash/redwood/layout/composeui/ComposeUiLazyListTest.kt @@ -19,6 +19,7 @@ import androidx.compose.foundation.background import androidx.compose.runtime.Composable import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractFlexContainerTest @@ -37,14 +38,11 @@ import app.cash.redwood.widget.Widget import app.cash.redwood.widget.compose.ComposeWidgetChildren import app.cash.redwood.yoga.FlexDirection import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ComposeUiLazyListTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractFlexContainerTest<@Composable () -> Unit>() { @get:Rule diff --git a/redwood-lazylayout-view/build.gradle b/redwood-lazylayout-view/build.gradle index 7bc9b03fa4..8f67dd5d3b 100644 --- a/redwood-lazylayout-view/build.gradle +++ b/redwood-lazylayout-view/build.gradle @@ -6,6 +6,7 @@ redwoodBuild { } apply plugin: 'org.jetbrains.kotlin.plugin.serialization' +apply plugin: 'app.cash.burst' apply plugin: 'app.cash.paparazzi' dependencies { @@ -14,11 +15,11 @@ dependencies { implementation libs.androidx.recyclerview implementation libs.androidx.swipeRefreshLayout implementation libs.kotlinx.coroutines.android + testImplementation libs.burst testImplementation projects.redwoodLayoutSharedTest testImplementation projects.redwoodLazylayoutSharedTest testImplementation projects.redwoodLayoutView testImplementation projects.redwoodSnapshotTesting - testImplementation libs.testParameterInjector } android { diff --git a/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListAsFlexContainerTest.kt b/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListAsFlexContainerTest.kt index 7bccefcfee..1e93112d55 100644 --- a/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListAsFlexContainerTest.kt +++ b/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListAsFlexContainerTest.kt @@ -17,6 +17,7 @@ package app.cash.redwood.lazylayout.view import android.content.Context import android.view.View +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.layout.AbstractFlexContainerTest @@ -35,14 +36,11 @@ import app.cash.redwood.widget.ChangeListener import app.cash.redwood.widget.Widget import app.cash.redwood.yoga.FlexDirection import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ViewLazyListAsFlexContainerTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractFlexContainerTest() { @get:Rule diff --git a/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListTest.kt b/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListTest.kt index 921738dac5..6a3c67bce6 100644 --- a/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListTest.kt +++ b/redwood-lazylayout-view/src/test/kotlin/app/cash/redwood/lazylayout/view/ViewLazyListTest.kt @@ -24,11 +24,8 @@ import app.cash.redwood.snapshot.testing.Snapshotter import app.cash.redwood.snapshot.testing.TestWidgetFactory import app.cash.redwood.snapshot.testing.ViewSnapshotter import app.cash.redwood.snapshot.testing.ViewTestWidgetFactory -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) class ViewLazyListTest : AbstractLazyListTest() { @get:Rule diff --git a/redwood-tooling-codegen/build.gradle b/redwood-tooling-codegen/build.gradle index 66a760277c..2584d4af2f 100644 --- a/redwood-tooling-codegen/build.gradle +++ b/redwood-tooling-codegen/build.gradle @@ -6,6 +6,8 @@ redwoodBuild { cliApplication('redwood-codegen', 'app.cash.redwood.tooling.codegen.Main') } +apply plugin: 'app.cash.burst' + dependencies { api projects.redwoodToolingSchema implementation libs.kotlinPoet @@ -16,5 +18,4 @@ dependencies { testImplementation projects.testApp.schema.compose testImplementation libs.junit testImplementation libs.assertk - testImplementation libs.testParameterInjector } diff --git a/redwood-tooling-codegen/src/test/kotlin/app/cash/redwood/tooling/codegen/DeprecatedGenerationTest.kt b/redwood-tooling-codegen/src/test/kotlin/app/cash/redwood/tooling/codegen/DeprecatedGenerationTest.kt index e63de6590a..010aab7b3b 100644 --- a/redwood-tooling-codegen/src/test/kotlin/app/cash/redwood/tooling/codegen/DeprecatedGenerationTest.kt +++ b/redwood-tooling-codegen/src/test/kotlin/app/cash/redwood/tooling/codegen/DeprecatedGenerationTest.kt @@ -15,6 +15,7 @@ */ package app.cash.redwood.tooling.codegen +import app.cash.burst.Burst import app.cash.redwood.schema.Children import app.cash.redwood.schema.Modifier import app.cash.redwood.schema.Property @@ -25,13 +26,10 @@ import assertk.all import assertk.assertAll import assertk.assertThat import assertk.assertions.contains -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import kotlin.DeprecationLevel.ERROR import org.junit.Test -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class DeprecatedGenerationTest { @Suppress("DEPRECATION") @Schema( @@ -140,9 +138,7 @@ class DeprecatedGenerationTest { } @Test - fun protocolCodegen( - @TestParameter type: ProtocolCodegenType, - ) { + fun protocolCodegen(type: ProtocolCodegenType) { val schema = parseTestSchema(DeprecatedSchema::class) assertAll { for (fileSpec in schema.generateFileSpecs(type)) { @@ -152,9 +148,7 @@ class DeprecatedGenerationTest { } } - @Test fun codegen( - @TestParameter type: CodegenType, - ) { + @Test fun codegen(type: CodegenType) { val schema = parseTestSchema(DeprecatedSchema::class) assertAll { for (fileSpec in schema.generateFileSpecs(type)) { diff --git a/redwood-tooling-schema/build.gradle b/redwood-tooling-schema/build.gradle index 92176b2ebb..92c8dbadd6 100644 --- a/redwood-tooling-schema/build.gradle +++ b/redwood-tooling-schema/build.gradle @@ -20,6 +20,5 @@ dependencies { testImplementation projects.testApp.schema testImplementation libs.junit testImplementation libs.assertk - testImplementation libs.testParameterInjector testImplementation libs.jimfs } diff --git a/redwood-widget-view-test/build.gradle b/redwood-widget-view-test/build.gradle index 365453a4ea..63aa7ccc64 100644 --- a/redwood-widget-view-test/build.gradle +++ b/redwood-widget-view-test/build.gradle @@ -4,13 +4,14 @@ redwoodBuild { targets(ToolkitAndroid) } +apply plugin: 'app.cash.burst' apply plugin: 'app.cash.paparazzi' dependencies { testImplementation projects.redwoodSnapshotTesting testImplementation projects.redwoodWidgetSharedTest testImplementation libs.androidx.activity - testImplementation libs.testParameterInjector + testImplementation libs.burst } android { diff --git a/redwood-widget-view-test/src/test/kotlin/app/cash/redwood/widget/view/ViewRedwoodViewTest.kt b/redwood-widget-view-test/src/test/kotlin/app/cash/redwood/widget/view/ViewRedwoodViewTest.kt index 42a5c60ac3..0bef9b4748 100644 --- a/redwood-widget-view-test/src/test/kotlin/app/cash/redwood/widget/view/ViewRedwoodViewTest.kt +++ b/redwood-widget-view-test/src/test/kotlin/app/cash/redwood/widget/view/ViewRedwoodViewTest.kt @@ -17,6 +17,7 @@ package app.cash.redwood.widget.view import android.view.View import androidx.activity.OnBackPressedDispatcher +import app.cash.burst.Burst import app.cash.paparazzi.DeviceConfig import app.cash.paparazzi.Paparazzi import app.cash.redwood.snapshot.testing.TestWidgetFactory @@ -25,14 +26,11 @@ import app.cash.redwood.snapshot.testing.ViewTestWidgetFactory import app.cash.redwood.widget.AbstractRedwoodViewTest import app.cash.redwood.widget.RedwoodLayout import com.android.resources.LayoutDirection -import com.google.testing.junit.testparameterinjector.TestParameter -import com.google.testing.junit.testparameterinjector.TestParameterInjector import org.junit.Rule -import org.junit.runner.RunWith -@RunWith(TestParameterInjector::class) +@Burst class ViewRedwoodViewTest( - @TestParameter layoutDirection: LayoutDirection, + layoutDirection: LayoutDirection, ) : AbstractRedwoodViewTest() { @get:Rule val paparazzi = Paparazzi(