Browse Source

Refactor composable-test-cases to get rid of dependency on compose-multiplatform-gradle-plugin (#4421)

This is a preparation to move these tests to kotlin project.

Some neccessary parts were copy-pasted from our Compose Multiplatform
gradle plugin.

So `id("org.jetbrains.compose")` is not used anymore
pull/4426/head
Oleksandr Karpovich 9 months ago committed by GitHub
parent
commit
9709609fad
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 22
      compose/integrations/composable-test-cases/build.gradle.kts
  2. 70
      compose/integrations/composable-test-cases/buildSrc/src/main/kotlin/internal/ComposeCompilerArtifactProvider.kt
  3. 50
      compose/integrations/composable-test-cases/buildSrc/src/main/kotlin/internal/InternalComposeSupportPlugin.kt
  4. 6
      compose/integrations/composable-test-cases/common/build.gradle.kts
  5. 4
      compose/integrations/composable-test-cases/gradle.properties
  6. 4
      compose/integrations/composable-test-cases/settings.gradle.kts
  7. 2
      compose/integrations/composable-test-cases/testcases/anonymousObjects/lib/build.gradle.kts
  8. 2
      compose/integrations/composable-test-cases/testcases/anonymousObjects/main/build.gradle.kts
  9. 2
      compose/integrations/composable-test-cases/testcases/constructors/lib/build.gradle.kts
  10. 2
      compose/integrations/composable-test-cases/testcases/constructors/main/build.gradle.kts
  11. 2
      compose/integrations/composable-test-cases/testcases/expectActual/lib/build.gradle.kts
  12. 2
      compose/integrations/composable-test-cases/testcases/expectActual/main/build.gradle.kts
  13. 2
      compose/integrations/composable-test-cases/testcases/inheritance/composableInterface/lib/build.gradle.kts
  14. 2
      compose/integrations/composable-test-cases/testcases/inheritance/composableInterface/main/build.gradle.kts
  15. 2
      compose/integrations/composable-test-cases/testcases/inheritance/funInterface/lib/build.gradle.kts
  16. 2
      compose/integrations/composable-test-cases/testcases/inheritance/funInterface/main/build.gradle.kts
  17. 2
      compose/integrations/composable-test-cases/testcases/lambdas/lib/build.gradle.kts
  18. 2
      compose/integrations/composable-test-cases/testcases/lambdas/main/build.gradle.kts
  19. 2
      compose/integrations/composable-test-cases/testcases/rememberAnonymousObj/lib/build.gradle.kts
  20. 2
      compose/integrations/composable-test-cases/testcases/rememberAnonymousObj/main/build.gradle.kts
  21. 2
      compose/integrations/composable-test-cases/testcases/stability/lib/build.gradle.kts
  22. 2
      compose/integrations/composable-test-cases/testcases/stability/main/build.gradle.kts
  23. 2
      compose/integrations/composable-test-cases/testcases/template/lib/build.gradle.kts
  24. 2
      compose/integrations/composable-test-cases/testcases/template/main/build.gradle.kts
  25. 2
      compose/integrations/composable-test-cases/testcases/valueClass/lib/build.gradle.kts
  26. 2
      compose/integrations/composable-test-cases/testcases/valueClass/main/build.gradle.kts

22
compose/integrations/composable-test-cases/build.gradle.kts

@ -1,3 +1,4 @@
import internal.InternalComposeSupportPlugin
import org.jetbrains.kotlin.gradle.dsl.KotlinCompile import org.jetbrains.kotlin.gradle.dsl.KotlinCompile
import org.jetbrains.kotlin.gradle.dsl.KotlinJsCompile import org.jetbrains.kotlin.gradle.dsl.KotlinJsCompile
@ -13,15 +14,23 @@ allprojects {
// mavenLocal() // mavenLocal()
} }
// Apply here for all subprojects instead of applying in each build.gradle.kts separately.
// It applies the compiler plugin
this.apply<InternalComposeSupportPlugin>()
afterEvaluate { afterEvaluate {
val pluginOptionPrefix = "plugin:androidx.compose.compiler.plugins.kotlin:"
val project = this val project = this
val compilerPluginVersion = project.properties["compose.kotlinCompilerPluginVersion"] as? String
val kotlinVersion = project.properties["kotlin.version"] as? String val kotlinVersion = project.properties["kotlin.version"] as? String
project.extensions.findByType<org.jetbrains.compose.ComposeExtension>()?.also {
if (!compilerPluginVersion.isNullOrEmpty()) { project.tasks.withType(KotlinCompile::class.java).configureEach {
println("${project.name} is using compilerPluginVersion = $compilerPluginVersion") kotlinOptions.apply {
it.kotlinCompilerPlugin.set(compilerPluginVersion) freeCompilerArgs +=
it.kotlinCompilerPluginArgs.add("suppressKotlinVersionCompatibilityCheck=$kotlinVersion") listOf(
"-P",
"${pluginOptionPrefix}suppressKotlinVersionCompatibilityCheck=$kotlinVersion"
)
} }
} }
@ -40,7 +49,6 @@ allprojects {
plugins { plugins {
kotlin("multiplatform") apply false kotlin("multiplatform") apply false
id("org.jetbrains.compose") apply false
} }
fun Project.disableYarnLockMismatchReport() { fun Project.disableYarnLockMismatchReport() {

70
compose/integrations/composable-test-cases/buildSrc/src/main/kotlin/internal/ComposeCompilerArtifactProvider.kt

@ -0,0 +1,70 @@
/*
* Copyright 2020-2022 JetBrains s.r.o. and respective authors and developers.
* Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE.txt file.
*/
package internal
import internal.ComposeCompilerArtifactProvider.DefaultCompiler.pluginArtifact
import org.jetbrains.kotlin.gradle.plugin.SubpluginArtifact
// Partially copy-pasted from https://github.com/JetBrains/compose-multiplatform/tree/master/gradle-plugins/compose/src/main/kotlin/org/jetbrains/compose
internal class ComposeCompilerArtifactProvider(
private val customPluginString: () -> String
) {
val compilerArtifact: SubpluginArtifact by lazy {
val customPlugin = customPluginString()
val customCoordinates = customPlugin.split(":")
when (customCoordinates.size) {
1 -> {
val customVersion = customCoordinates[0]
check(customVersion.isNotBlank()) { "'compose.kotlinCompilerPlugin' cannot be blank!" }
pluginArtifact(version = customVersion)
}
3 -> pluginArtifact(
version = customCoordinates[2],
groupId = customCoordinates[0],
artifactId = customCoordinates[1],
)
else -> error("""
Illegal format of 'compose.kotlinCompilerPlugin' property.
Expected format: either '<VERSION>' or '<GROUP_ID>:<ARTIFACT_ID>:<VERSION>'
Actual value: '$customPlugin'
""".trimIndent())
}
}
val compilerHostedArtifact: SubpluginArtifact
get() = compilerArtifact.run {
val newArtifactId =
if (groupId == DefaultCompiler.GROUP_ID && artifactId == DefaultCompiler.ARTIFACT_ID) {
DefaultCompiler.HOSTED_ARTIFACT_ID
} else artifactId
copy(artifactId = newArtifactId)
}
internal object DefaultCompiler {
const val GROUP_ID = "org.jetbrains.compose.compiler"
const val ARTIFACT_ID = "compiler"
const val HOSTED_ARTIFACT_ID = "compiler-hosted"
fun pluginArtifact(
version: String,
groupId: String = GROUP_ID,
artifactId: String = ARTIFACT_ID,
): SubpluginArtifact =
SubpluginArtifact(groupId = groupId, artifactId = artifactId, version = version)
}
}
internal fun SubpluginArtifact.copy(
groupId: String? = null,
artifactId: String? = null,
version: String? = null
): SubpluginArtifact =
SubpluginArtifact(
groupId = groupId ?: this.groupId,
artifactId = artifactId ?: this.artifactId,
version = version ?: this.version
)

50
compose/integrations/composable-test-cases/buildSrc/src/main/kotlin/internal/InternalComposeSupportPlugin.kt

@ -0,0 +1,50 @@
/*
* Copyright 2020-2021 JetBrains s.r.o. and respective authors and developers.
* Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE.txt file.
*/
package internal
import org.gradle.api.Project
import org.gradle.api.provider.Provider
import org.jetbrains.kotlin.gradle.plugin.*
// Partially copy-pasted from https://github.com/JetBrains/compose-multiplatform/tree/master/gradle-plugins/compose/src/main/kotlin/org/jetbrains/compose
class InternalComposeSupportPlugin : KotlinCompilerPluginSupportPlugin {
private lateinit var composeCompilerArtifactProvider: ComposeCompilerArtifactProvider
override fun apply(target: Project) {
super.apply(target)
val composeCompilerVersion = target.properties["compose.kotlinCompilerPluginVersion"] as? String
?: error("'compose.kotlinCompilerPluginVersion' is not defined")
composeCompilerArtifactProvider = ComposeCompilerArtifactProvider { composeCompilerVersion }
}
override fun getCompilerPluginId(): String = "androidx.compose.compiler.plugins.kotlin"
override fun getPluginArtifact(): SubpluginArtifact =
composeCompilerArtifactProvider.compilerArtifact
override fun getPluginArtifactForNative(): SubpluginArtifact =
composeCompilerArtifactProvider.compilerHostedArtifact
override fun isApplicable(kotlinCompilation: KotlinCompilation<*>): Boolean = true
override fun applyToCompilation(kotlinCompilation: KotlinCompilation<*>): Provider<List<SubpluginOption>> {
val target = kotlinCompilation.target
return target.project.provider { emptyList() }
}
private fun options(vararg options: Pair<String, String>): List<SubpluginOption> =
options.map { SubpluginOption(it.first, it.second) }
}
val Project.composeVersion: String
get() = properties["compose.version"] as? String
?: error("'compose.version' is not defined")
val Project.composeRuntimeDependency: String
get() = properties["compose.runtime.artifactId"] as? String
?: properties["compose.runtime.groupId"]?.let { it.toString() + ":runtime:$composeVersion" }
?: "org.jetbrains.compose.runtime:runtime:${composeVersion}"

6
compose/integrations/composable-test-cases/common/build.gradle.kts

@ -1,6 +1,7 @@
import internal.composeRuntimeDependency
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
group = "com.example" group = "com.example"
@ -12,7 +13,8 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime) // Expose it as api here, so other modules don't need to care about it
api(project.composeRuntimeDependency)
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:$coroutinesVersion") implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:$coroutinesVersion")
} }
} }

4
compose/integrations/composable-test-cases/gradle.properties

@ -3,7 +3,11 @@ kotlin.code.style=official
android.useAndroidX=true android.useAndroidX=true
kotlin.version=1.9.22 kotlin.version=1.9.22
agp.version=7.3.0 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.0-rc03
# 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 kotlinx.coroutines.version=1.8.0

4
compose/integrations/composable-test-cases/settings.gradle.kts

@ -7,10 +7,6 @@ pluginManagement {
maven("https://maven.pkg.jetbrains.space/kotlin/p/kotlin/dev/") maven("https://maven.pkg.jetbrains.space/kotlin/p/kotlin/dev/")
mavenLocal() mavenLocal()
} }
plugins {
id("org.jetbrains.compose").version(extra["compose.version"] as String)
}
} }
rootProject.name = "composable-test-cases" rootProject.name = "composable-test-cases"

2
compose/integrations/composable-test-cases/testcases/anonymousObjects/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/anonymousObjects/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/constructors/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/constructors/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/expectActual/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/expectActual/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/inheritance/composableInterface/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/inheritance/composableInterface/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/inheritance/funInterface/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/inheritance/funInterface/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/lambdas/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/lambdas/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/rememberAnonymousObj/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/rememberAnonymousObj/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/stability/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/stability/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/template/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/template/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

2
compose/integrations/composable-test-cases/testcases/valueClass/lib/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
} }
} }

2
compose/integrations/composable-test-cases/testcases/valueClass/main/build.gradle.kts

@ -1,6 +1,5 @@
plugins { plugins {
kotlin("multiplatform") kotlin("multiplatform")
id("org.jetbrains.compose")
} }
kotlin { kotlin {
@ -9,7 +8,6 @@ kotlin {
sourceSets { sourceSets {
val commonMain by getting { val commonMain by getting {
dependencies { dependencies {
implementation(compose.runtime)
implementation(getCommonLib()) implementation(getCommonLib())
implementation(getLibDependencyForMain()) implementation(getLibDependencyForMain())
} }

Loading…
Cancel
Save