Add regression test for 181837660
Bug: 181837660
Change-Id: I62f467fae9eda3bb96b18c1092f0016527bd2d2c
diff --git a/src/test/java/com/android/tools/r8/dexsplitter/SplitterTestBase.java b/src/test/java/com/android/tools/r8/dexsplitter/SplitterTestBase.java
index 77ddefd..05d6d3d 100644
--- a/src/test/java/com/android/tools/r8/dexsplitter/SplitterTestBase.java
+++ b/src/test/java/com/android/tools/r8/dexsplitter/SplitterTestBase.java
@@ -120,7 +120,7 @@
return builder.build();
}
- ProcessResult testR8Splitter(
+ public ProcessResult testR8Splitter(
TestParameters parameters,
Set<Class<?>> baseClasses,
Set<Class<?>> featureClasses,
diff --git a/src/test/java/com/android/tools/r8/regress/Regress181837660.java b/src/test/java/com/android/tools/r8/regress/Regress181837660.java
new file mode 100644
index 0000000..d03c1e1
--- /dev/null
+++ b/src/test/java/com/android/tools/r8/regress/Regress181837660.java
@@ -0,0 +1,83 @@
+// Copyright (c) 2021, the R8 project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+package com.android.tools.r8.regress;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
+
+import com.android.tools.r8.NeverInline;
+import com.android.tools.r8.R8FullTestBuilder;
+import com.android.tools.r8.TestParameters;
+import com.android.tools.r8.TestParametersCollection;
+import com.android.tools.r8.ToolHelper.ProcessResult;
+import com.android.tools.r8.dexsplitter.SplitterTestBase;
+import com.android.tools.r8.utils.StringUtils;
+import com.google.common.collect.ImmutableSet;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.junit.runners.Parameterized;
+import org.junit.runners.Parameterized.Parameters;
+
+/**
+ * We need to ensure that we distribute the synthetic items in the features where they where
+ * generated.
+ */
+@RunWith(Parameterized.class)
+public class Regress181837660 extends SplitterTestBase {
+
+ public static final String EXPECTED = StringUtils.lines("42");
+
+ @Parameters(name = "{0}")
+ public static TestParametersCollection params() {
+ return getTestParameters().withDexRuntimes().withAllApiLevels().build();
+ }
+
+ private final TestParameters parameters;
+
+ public Regress181837660(TestParameters parameters) {
+ this.parameters = parameters;
+ }
+
+ @Test
+ public void testDistribution() throws Exception {
+ ProcessResult processResult =
+ testR8Splitter(
+ parameters,
+ ImmutableSet.of(BaseClass.class),
+ ImmutableSet.of(FeatureClass.class),
+ FeatureClass.class,
+ b -> {},
+ this::configure);
+
+ assertEquals(1, processResult.exitCode);
+ // We can't actually read the field since it is in the feature.
+ assertTrue(processResult.stderr.contains("NoClassDefFoundError"));
+ }
+
+ private void configure(R8FullTestBuilder testBuilder) throws NoSuchMethodException {
+ testBuilder.enableInliningAnnotations().noMinification().setMinApi(parameters.getApiLevel());
+ }
+
+ public static class BaseClass {
+ @NeverInline
+ public static String getFromFeature() {
+ return FeatureClass.featureString;
+ }
+ }
+
+ public static class FeatureClass implements RunInterface {
+
+ public static String featureString = "22";
+
+ public static String getAString() {
+ return BaseClass.getFromFeature();
+ }
+
+ @Override
+ public void run() {
+ System.out.println(getAString());
+ }
+ }
+}