From 949553246785e0ec4497498a71ba1fdb41c2e516 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9sar?= <56847527+LikeTheSalad@users.noreply.github.com> Date: Fri, 6 Oct 2023 08:27:38 +0200 Subject: [PATCH] Enhanced android testing (#1538) * Upgrading AGP to 7.4.0 * Making android test a standalone project * Adapting ByteBuddyLocalClassesEnhancerTask to the new 7.4.0 apis * Using ByteBuddyLocalClassesEnhancerTask with the new artifacts api * Avoiding compilation oom * Fixing "toTransform" method reflection * Splitting resources from classes for local projects * Using custom dependency rule to merge class dirs and resources from local and remote deps * Using custom dependency rule to merge class dirs and resources from local and remote deps * Using the last api's ALL scope * Adding SPI stability tests * Clean up tests * Updating tests * Fixing android descriptor * Removed project references in ByteBuddyLocalClassesEnhancerTask due to https://docs.gradle.org/8.3/userguide/configuration_cache.html#config_cache:requirements:use_project_during_execution * Update working regarding ByteBuddyLocalClassesEnhancerTask's scope * Update working regarding ByteBuddyLocalClassesEnhancerTask's scope * Update wordings and renaming methods in ByteBuddyAndroidPlugin * Renaming bytebuddy 7.4 transform tasks * Removed project references in ByteBuddyLocalClassesEnhancerTask due to https://docs.gradle.org/8.3/userguide/configuration_cache.html#config_cache:requirements:use_project_during_execution * Update working regarding ByteBuddyLocalClassesEnhancerTask's scope * Update working regarding ByteBuddyLocalClassesEnhancerTask's scope * Update wordings and renaming methods in ByteBuddyAndroidPlugin * Renaming bytebuddy 7.4 transform tasks * Clean up * Moving back ByteBuddyAndroidPlugin * Clean up test's properties * Removing "getProject()" calls in ByteBuddyLocalClassesEnhancerTask due to https://docs.gradle.org/8.3/userguide/configuration_cache.html#config_cache:requirements:use_project_during_execution * Renaming vars * Updating tests * Reverting indentation and gradle versions * Fixing indentation * Cleaning up the readme for tests * Using Task.getLogger in ByteBuddyLocalClassesEnhancerTask --- .../android-plugin-test/.gitignore | 5 + .../android-plugin-test/README.md | 19 +- .../plugin/gradle/test/aar/AarAdvice.java | 2 +- .../aar-bytebuddy-target/build.gradle | 1 + .../service/TargetServiceImplementation.java | 26 ++ .../com.service.definition.ServiceDefinition | 1 + .../android-plugin-test/app/build.gradle | 17 +- .../test/ByteBuddyInstrumentedTest.java | 43 ++- .../app/src/main/AndroidManifest.xml | 21 +- .../bytebuddy/android/test/MainActivity.java | 53 --- .../app/src/main/res/layout/activity_main.xml | 26 -- .../src/main/res/mipmap-mdpi/ic_launcher.webp | Bin 982 -> 0 bytes .../res/mipmap-mdpi/ic_launcher_round.webp | Bin 1772 -> 0 bytes .../app/src/main/res/values/colors.xml | 10 - .../app/src/main/res/values/strings.xml | 3 - .../app/src/main/res/values/themes.xml | 4 - .../android-plugin-test/build.gradle | 14 +- .../android-plugin-test/bytebuddy.gradle | 4 + .../android-plugin-test/gradle.properties | 1 + .../android-plugin-test/gradlew | 359 ++++++++++++++++++ .../android-plugin-test/gradlew.bat | 181 +++++++++ .../gradle/test/jar/AdviceForLibClass.java | 34 ++ ...arAdvice.java => AdviceForLocalClass.java} | 4 +- ...{JarPlugin.java => PluginForLibClass.java} | 14 +- .../gradle/test/jar/PluginForLocalClass.java | 56 +++ .../META-INF/net.bytebuddy/build.plugins | 3 +- .../service-definition-lib/build.gradle | 8 + .../service/definition/ServiceDefinition.java | 21 + .../service-implementation-lib/build.gradle | 12 + .../service/usage/ServiceImplementation.java | 25 ++ .../com.service.definition.ServiceDefinition | 1 + .../service-implementation2-lib/build.gradle | 12 + .../service/usage2/ServiceImplementation.java | 25 ++ .../com.service.definition.ServiceDefinition | 1 + .../android-plugin-test/settings.gradle | 7 + .../android}/ByteBuddyAndroidPlugin.java | 0 .../ByteBuddyLocalClassesEnhancerTask.java | 11 +- byte-buddy-gradle-plugin/gradle.properties | 1 - byte-buddy-gradle-plugin/settings.gradle | 7 - 39 files changed, 851 insertions(+), 181 deletions(-) create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/.gitignore create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/java/net/bytebuddy/android/test/aar/lib/service/TargetServiceImplementation.java create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/java/net/bytebuddy/android/test/MainActivity.java delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/layout/activity_main.xml delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/mipmap-mdpi/ic_launcher.webp delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/colors.xml delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/strings.xml delete mode 100644 byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/themes.xml create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/bytebuddy.gradle create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/gradle.properties create mode 100755 byte-buddy-gradle-plugin/android-plugin-test/gradlew create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/gradlew.bat create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/jar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/jar/AdviceForLibClass.java rename byte-buddy-gradle-plugin/android-plugin-test/jar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/jar/{JarAdvice.java => AdviceForLocalClass.java} (90%) rename byte-buddy-gradle-plugin/android-plugin-test/jar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/jar/{JarPlugin.java => PluginForLibClass.java} (71%) create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/jar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/jar/PluginForLocalClass.java create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-definition-lib/build.gradle create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-definition-lib/src/main/java/com/service/definition/ServiceDefinition.java create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation-lib/build.gradle create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation-lib/src/main/java/com/service/usage/ServiceImplementation.java create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation-lib/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation2-lib/build.gradle create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation2-lib/src/main/java/com/service/usage2/ServiceImplementation.java create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/service-implementation2-lib/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition create mode 100644 byte-buddy-gradle-plugin/android-plugin-test/settings.gradle rename {byte-buddy/src/main/resources => byte-buddy-gradle-plugin/android-plugin/src/main/java/net/bytebuddy/build/gradle/android}/ByteBuddyAndroidPlugin.java (100%) diff --git a/byte-buddy-gradle-plugin/android-plugin-test/.gitignore b/byte-buddy-gradle-plugin/android-plugin-test/.gitignore new file mode 100644 index 0000000000..55b147bea5 --- /dev/null +++ b/byte-buddy-gradle-plugin/android-plugin-test/.gitignore @@ -0,0 +1,5 @@ +build/ +.gradle/ +.idea/ +local.properties +captures/ \ No newline at end of file diff --git a/byte-buddy-gradle-plugin/android-plugin-test/README.md b/byte-buddy-gradle-plugin/android-plugin-test/README.md index 08ad87e916..6e73f42d2a 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/README.md +++ b/byte-buddy-gradle-plugin/android-plugin-test/README.md @@ -4,22 +4,17 @@ How to run the tests ### Environment setup * The environment var `ANDROID_HOME` must be set and pointing to the Android SDK dir. -* Java 11 is required, more info [here](https://developer.android.com/studio/releases/gradle-plugin#jdk-11). -* A Gradle wrapper version of 7.2+ is required in order to be compatible with the Android - Gradle plugin used in this project, more info on it - [here](https://developer.android.com/studio/releases/gradle-plugin#updating-gradle). -* There must be an Android device connected through [ADB](https://developer.android.com/studio/command-line/adb), either +* Java 11 is required, more + info [here](https://developer.android.com/studio/releases/gradle-plugin#jdk-11). +* There must be an Android device connected + through [ADB](https://developer.android.com/studio/command-line/adb), either a running Emulator or a real device plugged in with [USB debugging](https://developer.android.com/studio/command-line/adb#Enabling) enabled. -* Set environment var `ANDROID_TEST` to `"true"`. - -This module is disabled by default to avoid issues with the Android Gradle Plugin and Intellij IDEA -version incompatibility, which causes the project analysis to fail when opened with said IDE, though it doesn't -cause any issues when running it from the command line. That's why the environment var `ANDROID_TEST` is needed -in order to switch this module on by setting it to `"true"`. ### Steps * Build Byte Buddy alongside the Byte Buddy Gradle plugin. -* Run the following command from the Byte Buddy Gradle plugin +* Located in the root dir of this test project, run the following command: dir: `./gradlew connectedAndroidTest -Pandroid.testInstrumentationRunnerArguments.class=net.bytebuddy.android.test.ByteBuddyInstrumentedTest` +* Optionally, you can also open up this test project with Android Studio, open up the test class and + run it through the IDE. \ No newline at end of file diff --git a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/aar/AarAdvice.java b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/aar/AarAdvice.java index dfd86bebf7..5bcad3b1d6 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/aar/AarAdvice.java +++ b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-plugin/src/main/java/net/bytebuddy/plugin/gradle/test/aar/AarAdvice.java @@ -29,6 +29,6 @@ public class AarAdvice { */ @Advice.OnMethodExit public static void onExit(@Advice.Return(readOnly = false) String returned) { - returned = "bar"; + returned = "instrumented local class from aar plugin"; } } diff --git a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/build.gradle b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/build.gradle index dcb7351eb6..d0ed79b9b1 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/build.gradle +++ b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/build.gradle @@ -25,4 +25,5 @@ android { dependencies { implementation group: 'com.google.android.material', name: 'material', version: '1.6.1' + implementation project(":service-definition-lib") } diff --git a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/java/net/bytebuddy/android/test/aar/lib/service/TargetServiceImplementation.java b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/java/net/bytebuddy/android/test/aar/lib/service/TargetServiceImplementation.java new file mode 100644 index 0000000000..9fe659434d --- /dev/null +++ b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/java/net/bytebuddy/android/test/aar/lib/service/TargetServiceImplementation.java @@ -0,0 +1,26 @@ +/* + * Copyright 2014 - Present Rafael Winterhalter + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package net.bytebuddy.android.test.aar.lib.service; + +import com.service.definition.ServiceDefinition; + +public class TargetServiceImplementation implements ServiceDefinition { + + @Override + public String getValue() { + return "Target service impl"; + } +} diff --git a/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition new file mode 100644 index 0000000000..5a52a2cb84 --- /dev/null +++ b/byte-buddy-gradle-plugin/android-plugin-test/aar-bytebuddy-target/src/main/resources/META-INF/services/com.service.definition.ServiceDefinition @@ -0,0 +1 @@ +net.bytebuddy.android.test.aar.lib.service.TargetServiceImplementation \ No newline at end of file diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/build.gradle b/byte-buddy-gradle-plugin/android-plugin-test/app/build.gradle index ac04d874b1..386b93e310 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/build.gradle +++ b/byte-buddy-gradle-plugin/android-plugin-test/app/build.gradle @@ -26,14 +26,15 @@ android { } } -def outerPom = new groovy.xml.XmlSlurper().parse(rootProject.file("$rootDir/pom.xml")) - dependencies { - implementation group: 'androidx.appcompat', name: 'appcompat', version: '1.5.0' - implementation project(':android-plugin-test:aar-bytebuddy-target') - byteBuddy project(":android-plugin-test:jar-bytebuddy-plugin") - byteBuddy project(":android-plugin-test:aar-bytebuddy-plugin") + implementation project(":service-definition-lib") + implementation project(':aar-bytebuddy-target') + implementation project(":service-implementation-lib") + implementation project(":service-implementation2-lib") + byteBuddy project(":jar-bytebuddy-plugin") + byteBuddy project(":aar-bytebuddy-plugin") testImplementation group: 'junit', name: 'junit', version: outerPom.properties.'version.junit' - androidTestImplementation group: 'androidx.test.ext', name: 'junit', version: '1.1.3' - androidTestImplementation group: 'androidx.test.espresso', name: 'espresso-core', version: '3.4.0' + androidTestImplementation group: 'androidx.test', name: 'rules', version: '1.5.0' + androidTestImplementation group: 'androidx.test', name: 'runner', version: '1.5.2' + androidTestImplementation group: 'androidx.test.ext', name: 'junit', version: '1.1.5' } diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/androidTest/java/net/bytebuddy/android/test/ByteBuddyInstrumentedTest.java b/byte-buddy-gradle-plugin/android-plugin-test/app/src/androidTest/java/net/bytebuddy/android/test/ByteBuddyInstrumentedTest.java index 0ead9aa097..472475656d 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/androidTest/java/net/bytebuddy/android/test/ByteBuddyInstrumentedTest.java +++ b/byte-buddy-gradle-plugin/android-plugin-test/app/src/androidTest/java/net/bytebuddy/android/test/ByteBuddyInstrumentedTest.java @@ -1,30 +1,37 @@ package net.bytebuddy.android.test; -import static androidx.test.espresso.Espresso.onView; -import static androidx.test.espresso.assertion.ViewAssertions.matches; -import static androidx.test.espresso.matcher.ViewMatchers.withId; -import static androidx.test.espresso.matcher.ViewMatchers.withText; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; -import androidx.test.ext.junit.rules.ActivityScenarioRule; -import androidx.test.ext.junit.runners.AndroidJUnit4; +import com.service.definition.ServiceDefinition; + +import net.bytebuddy.android.test.aar.lib.SomeAarClass; -import org.junit.Rule; import org.junit.Test; -import org.junit.runner.RunWith; -@RunWith(AndroidJUnit4.class) -class ByteBuddyInstrumentedTest { +import java.util.ArrayList; +import java.util.List; +import java.util.ServiceLoader; - @Rule - public ActivityScenarioRule activityRule = new ActivityScenarioRule<>(MainActivity.class); +public class ByteBuddyInstrumentedTest { @Test public void bytecodeInstrumentation() { - // On local java - onView(withId(R.id.text_from_local_java_class)).check(matches(withText("bar"))); - // On dependency class - onView(withId(R.id.text_from_aar_dependency)).check(matches(withText("bar"))); - // From aar - onView(withId(R.id.text_instrumented_from_aar)).check(matches(withText("bar"))); + assertEquals("instrumented local class from jar plugin", new SomeClass().method()); + assertEquals("instrumented local class from aar plugin", new AnotherClass().method()); + assertEquals("instrumented aar lib's class from jar plugin", new SomeAarClass().method()); + } + + @Test + public void verifySPIsAreNotMissing() { + List values = new ArrayList<>(); + for (ServiceDefinition serviceDefinition : ServiceLoader.load(ServiceDefinition.class)) { + values.add(serviceDefinition.getValue()); + } + + assertEquals(3, values.size()); + assertTrue(values.contains("Target service impl")); + assertTrue(values.contains("Service implementation")); + assertTrue(values.contains("Service implementation2")); } } \ No newline at end of file diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/AndroidManifest.xml b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/AndroidManifest.xml index bdf383e9b4..4d2e630d7d 100644 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/AndroidManifest.xml +++ b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/AndroidManifest.xml @@ -1,21 +1,2 @@ - - - - - - - - - - - + diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/java/net/bytebuddy/android/test/MainActivity.java b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/java/net/bytebuddy/android/test/MainActivity.java deleted file mode 100644 index 48dd531540..0000000000 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/java/net/bytebuddy/android/test/MainActivity.java +++ /dev/null @@ -1,53 +0,0 @@ -/* - * Copyright 2014 - Present Rafael Winterhalter - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package net.bytebuddy.android.test; - -import android.os.Bundle; -import android.widget.TextView; - -import androidx.annotation.IdRes; -import androidx.appcompat.app.AppCompatActivity; - -import net.bytebuddy.android.test.aar.lib.SomeAarClass; - -/** - * The main activity to use under test. - */ -public class MainActivity extends AppCompatActivity { - - /** - * {@inheritDoc} - */ - public void onCreate(Bundle savedInstanceState) { - super.onCreate(savedInstanceState); - setContentView(R.layout.activity_main); - - setTextTo(R.id.text_from_local_java_class, new SomeClass().someMethod()); - setTextTo(R.id.text_from_aar_dependency, new SomeAarClass().someMethod()); - setTextTo(R.id.text_instrumented_from_aar, new AnotherClass().someMethod()); - } - - /** - * Sets a resource text to a given value. - * - * @param id The text id. - * @param text The text to set. - */ - private void setTextTo(@IdRes int id, String text) { - TextView textView = findViewById(id); - textView.setText(text); - } -} diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/layout/activity_main.xml b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/layout/activity_main.xml deleted file mode 100644 index bcd2967ea7..0000000000 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/layout/activity_main.xml +++ /dev/null @@ -1,26 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/mipmap-mdpi/ic_launcher.webp b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/mipmap-mdpi/ic_launcher.webp deleted file mode 100644 index 4f0f1d64e58ba64d180ce43ee13bf9a17835fbca..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 982 zcmV;{11bDcNk&G_0{{S5MM6+kP&il$0000G0000l001ul06|PpNU8t;00Dqo+t#w^ z^1csucXz7-Qrhzl9HuHB%l>&>1tG2^vb*E&k^T3$FG1eQZ51g$uv4V+kI`0<^1Z@N zk?Jjh$olyC%l>)Xq;7!>{iBj&BjJ`P&$fsCfpve_epJOBkTF?nu-B7D!hO=2ZR}

C%4 zc_9eOXvPbC4kzU8YowIA8cW~Uv|eB&yYwAObSwL2vY~UYI7NXPvf3b+c^?wcs~_t{ ze_m66-0)^{JdOMKPwjpQ@Sna!*?$wTZ~su*tNv7o!gXT!GRgivP}ec?5>l1!7<(rT zds|8x(qGc673zrvYIz;J23FG{9nHMnAuP}NpAED^laz3mAN1sy+NXK)!6v1FxQ;lh zOBLA>$~P3r4b*NcqR;y6pwyhZ3_PiDb|%n1gGjl3ZU}ujInlP{eks-#oA6>rh&g+!f`hv#_%JrgYPu z(U^&XLW^QX7F9Z*SRPpQl{B%x)_AMp^}_v~?j7 zapvHMKxSf*Mtyx8I}-<*UGn3)oHd(nn=)BZ`d$lDBwq_GL($_TPaS{UeevT(AJ`p0 z9%+hQb6z)U9qjbuXjg|dExCLjpS8$VKQ55VsIC%@{N5t{NsW)=hNGI`J=x97_kbz@ E0Of=7!TQj4N+cqN`nQhxvX7dAV-`K|Ub$-q+H-5I?Tx0g9jWxd@A|?POE8`3b8fO$T))xP* z(X?&brZw({`)WU&rdAs1iTa0x6F@PIxJ&&L|dpySV!ID|iUhjCcKz(@mE z!x@~W#3H<)4Ae(4eQJRk`Iz3<1)6^m)0b_4_TRZ+cz#eD3f8V;2r-1fE!F}W zEi0MEkTTx}8i1{`l_6vo0(Vuh0HD$I4SjZ=?^?k82R51bC)2D_{y8mi_?X^=U?2|F{Vr7s!k(AZC$O#ZMyavHhlQ7 zUR~QXuH~#o#>(b$u4?s~HLF*3IcF7023AlwAYudn0FV~|odGH^05AYPEfR)8p`i{n zwg3zPVp{+wOsxKc>)(pMupKF!Y2HoUqQ3|Yu|8lwR=?5zZuhG6J?H`bSNk_wPoM{u zSL{c@pY7+c2kck>`^q1^^gR0QB7Y?KUD{vz-uVX~;V-rW)PDcI)$_UjgVV?S?=oLR zf4}zz{#*R_{LkiJ#0RdQLNC^2Vp%JPEUvG9ra2BVZ92(p9h7Ka@!yf9(lj#}>+|u* z;^_?KWdzkM`6gqPo9;;r6&JEa)}R3X{(CWv?NvgLeOTq$cZXqf7|sPImi-7cS8DCN zGf;DVt3Am`>hH3{4-WzH43Ftx)SofNe^-#|0HdCo<+8Qs!}TZP{HH8~z5n`ExcHuT zDL1m&|DVpIy=xsLO>8k92HcmfSKhflQ0H~9=^-{#!I1g(;+44xw~=* zxvNz35vfsQE)@)Zsp*6_GjYD};Squ83<_?^SbALb{a`j<0Gn%6JY!zhp=Fg}Ga2|8 z52e1WU%^L1}15Ex0fF$e@eCT(()_P zvV?CA%#Sy08_U6VPt4EtmVQraWJX` zh=N|WQ>LgrvF~R&qOfB$!%D3cGv?;Xh_z$z7k&s4N)$WYf*k=|*jCEkO19{h_(%W4 zPuOqbCw`SeAX*R}UUsbVsgtuG?xs(#Ikx9`JZoQFz0n*7ZG@Fv@kZk`gzO$HoA9kN z8U5{-yY zvV{`&WKU2$mZeoBmiJrEdzUZAv1sRxpePdg1)F*X^Y)zp^Y*R;;z~vOv-z&)&G)JQ{m!C9cmziu1^nHA z`#`0c>@PnQ9CJKgC5NjJD8HM3|KC(g5nnCq$n0Gsu_DXk36@ql%npEye|?%RmG)

FJ$wK}0tWNB{uH;AM~i diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/colors.xml b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/colors.xml deleted file mode 100644 index ca1931bca9..0000000000 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/colors.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - #FFBB86FC - #FF6200EE - #FF3700B3 - #FF03DAC5 - #FF018786 - #FF000000 - #FFFFFFFF - diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/strings.xml b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/strings.xml deleted file mode 100644 index b02be6da86..0000000000 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/strings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - app - diff --git a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/themes.xml b/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/themes.xml deleted file mode 100644 index 227462dcdf..0000000000 --- a/byte-buddy-gradle-plugin/android-plugin-test/app/src/main/res/values/themes.xml +++ /dev/null @@ -1,4 +0,0 @@ - - -