Skip to content

Commit

Permalink
Update compose compiler version to 1.5.10.2 (JetBrains#4652)
Browse files Browse the repository at this point in the history
version bump & test added for reified generic in composable functions

Fixes JetBrains#3147
  • Loading branch information
shishkin-pavel authored Apr 19, 2024
1 parent 2447b07 commit 41a6d3d
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 8 deletions.
6 changes: 3 additions & 3 deletions compose/integrations/composable-test-cases/gradle.properties
Original file line number Diff line number Diff line change
@@ -1,19 +1,19 @@
org.gradle.jvmargs=-Xmx4096M -XX:MaxMetaspaceSize=512m
kotlin.code.style=official
android.useAndroidX=true
kotlin.version=1.9.22
kotlin.version=1.9.23
agp.version=7.3.0

# a version of compose libraries. In this project the only dependency is compose-runtime.
compose.version=1.6.0-rc03
compose.version=1.6.1
# a group id for compose-runtime. Keep it as a parameter to easily change it on CI.
compose.runtime.groupId=org.jetbrains.compose.runtime

kotlinx.coroutines.version=1.8.0

#empty by default - a default version will be used
#compose.kotlinCompilerPluginVersion=23.12.18
compose.kotlinCompilerPluginVersion=1.5.10.1
compose.kotlinCompilerPluginVersion=1.5.10.2

# default|failingJs - see enum class CasesToRun
tests.casesToRun=default
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import com.example.common.TextLeafNode
import com.example.common.composeText
import kotlinx.coroutines.ExperimentalCoroutinesApi
import kotlinx.coroutines.test.runTest
import kotlin.reflect.KClass
import kotlin.test.Test
import kotlin.test.assertEquals

Expand Down Expand Up @@ -45,7 +46,7 @@ class CollectionOfComposablesTests {
@Test
fun testDefaultArgsForOverridden() = runTest {
class Impl : DefaultComposableContent

val root = composeText {
Impl().ComposableContent()
}
Expand Down Expand Up @@ -101,7 +102,8 @@ class CollectionOfComposablesTests {
val f: List<@Composable () -> Unit>,
)

val composables: List<@Composable () -> Unit> = listOf(@Composable { TextLeafNode("a") }, @Composable { TextLeafNode("b") })
val composables: List<@Composable () -> Unit> =
listOf(@Composable { TextLeafNode("a") }, @Composable { TextLeafNode("b") })
val single = SingleNested(composables)

val singleRoot = composeText {
Expand All @@ -124,6 +126,45 @@ class CollectionOfComposablesTests {
)
assertEquals(singleRoot.dump(), doubleRoot.dump())
}
}

interface ViewModel {
@Composable
fun content()
}

class ViewModelA : ViewModel {
@Composable
override fun content() {
TextLeafNode("a")
}
}

fun <T : ViewModel> get(klass: KClass<T>, viewModelBlock: () -> T): T {
if (klass.toString().contains("asdf")) {
throw Exception("AsdfASDFASDF")
}
return viewModelBlock()
}

@Composable
inline fun <reified T : ViewModel> getReified(
noinline viewModelBlock: () -> T
): T = get(T::class, viewModelBlock)

/** Composable functions with `reified` generic types without proper symbol remapping for
* `IrTypeParameterSymbol` (inside 'T::class' / `IrClassReference`)
* https://github.com/JetBrains/compose-multiplatform/issues/3147
*/
@Test
fun testReifiedGenericComposable() = runTest {
val root = composeText {
val vm = getReified { ViewModelA() }
vm.content()
}

assertEquals(
expected = "root:{a}",
actual = root.dump()
)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ internal object ComposeCompilerCompatibility {
"1.9.20" to "1.5.3",
"1.9.21" to "1.5.4",
"1.9.22" to "1.5.8.1",
"1.9.23" to "1.5.10.1",
"1.9.23" to "1.5.10.2",
"2.0.0-Beta1" to "1.5.4-dev1-kt2.0.0-Beta1",
"2.0.0-Beta4" to "1.5.9-kt-2.0.0-Beta4",
"2.0.0-Beta5" to "1.5.11-kt-2.0.0-Beta5",
Expand Down
2 changes: 1 addition & 1 deletion gradle-plugins/gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ dev.junit.parallel=false
# Default version of Compose Libraries used by Gradle plugin
compose.version=1.6.10-dev1590
# The latest version of Compose Compiler used by Gradle plugin. Used only in tests/CI.
compose.tests.compiler.version=1.5.10.1
compose.tests.compiler.version=1.5.10.2
# The latest version of Kotlin compatible with compose.tests.compiler.version. Used only in tests/CI.
compose.tests.compiler.compatible.kotlin.version=1.9.23
# The latest version of Kotlin compatible with compose.tests.compiler.version for JS target. Used only on CI.
Expand Down

0 comments on commit 41a6d3d

Please sign in to comment.