From d44f1acc366b6ffa5e3b23df10f76cf831d44b7c Mon Sep 17 00:00:00 2001 From: Alex Vanyo Date: Wed, 17 Apr 2024 20:09:21 -0700 Subject: [PATCH] Workaround disallow changes by splitting configuration file setup (#138) --- .../java/com/slack/keeper/KeeperPlugin.kt | 52 ++++++++++--------- 1 file changed, 28 insertions(+), 24 deletions(-) diff --git a/keeper-gradle-plugin/src/main/java/com/slack/keeper/KeeperPlugin.kt b/keeper-gradle-plugin/src/main/java/com/slack/keeper/KeeperPlugin.kt index 01d81982..4927c87a 100644 --- a/keeper-gradle-plugin/src/main/java/com/slack/keeper/KeeperPlugin.kt +++ b/keeper-gradle-plugin/src/main/java/com/slack/keeper/KeeperPlugin.kt @@ -291,14 +291,31 @@ public class KeeperPlugin : Plugin { ) ) - afterEvaluate { - val prop = - layout.dir(inferAndroidTestUsageProvider.flatMap { it.outputProguardRules.asFile }) - val testProguardFiles = - project.provider { testVariant.runtimeConfiguration.proguardFiles() } - val testProguardFile = - (testVariant.artifacts.unwrap()).get(InternalArtifactType.GENERATED_PROGUARD_FILE) - applyGeneratedRules(appVariant.name, prop, testProguardFiles, testProguardFile) + val prop = + layout.dir(inferAndroidTestUsageProvider.flatMap { it.outputProguardRules.asFile }) + + configureR8Task(appVariant.name) { + logger.debug("$TAG: Patching task '$name' with inferred androidTest proguard rules") + configurationFiles.from(prop) + } + + val disableTestProguardFiles = project.hasProperty("keeper.disableTestProguardFiles") + + if (!disableTestProguardFiles) { + // We offer an option to disable this because the FILTERED_PROGUARD_RULES doesn't + // propagate + // task dependencies and breaks in Gradle 8. + afterEvaluate { + val testProguardFiles = + project.provider { testVariant.runtimeConfiguration.proguardFiles() } + val testProguardFile = + (testVariant.artifacts.unwrap()).get(InternalArtifactType.GENERATED_PROGUARD_FILE) + configureR8Task(appVariant.name) { + logger.debug("$TAG: Patching task '$name' with test-specific proguard rules") + configurationFiles.from(testProguardFiles) + configurationFiles.from(testProguardFile) + } + } } } } @@ -355,29 +372,16 @@ public class KeeperPlugin : Plugin { } } - private fun Project.applyGeneratedRules( + private fun Project.configureR8Task( appVariant: String, - prop: Provider, - testProguardFiles: Provider, - testProguardFile: Provider + action: R8Task.() -> Unit, ) { val targetName = interpolateR8TaskName(appVariant) - val disableTestProguardFiles = project.hasProperty("keeper.disableTestProguardFiles") tasks .withType(R8Task::class.java) .matching { it.name == targetName } - .configureEach { - logger.debug("$TAG: Patching task '$name' with inferred androidTest proguard rules") - configurationFiles.from(prop) - // We offer an option to disable this because the FILTERED_PROGUARD_RULES doesn't - // propagate - // task dependencies and breaks in Gradle 8. - if (!disableTestProguardFiles) { - configurationFiles.from(testProguardFiles) - configurationFiles.from(testProguardFile) - } - } + .configureEach(action) } /**