Partial fix of -applymapping for array types.

Bug: 124177369
Change-Id: I57d6d25976da01de91b5dd88361e90a65735f335
diff --git a/src/main/java/com/android/tools/r8/naming/ProguardMapApplier.java b/src/main/java/com/android/tools/r8/naming/ProguardMapApplier.java
index b0e2f4c..d95f299 100644
--- a/src/main/java/com/android/tools/r8/naming/ProguardMapApplier.java
+++ b/src/main/java/com/android/tools/r8/naming/ProguardMapApplier.java
@@ -230,6 +230,11 @@
     }
 
     private DexType applyClassMappingOnTheFly(DexType from) {
+      if (from.isArrayType()) {
+        DexType baseType = from.toBaseType(appInfo.dexItemFactory);
+        DexType appliedBaseType = applyClassMappingOnTheFly(baseType);
+        return from.replaceBaseType(appliedBaseType, appInfo.dexItemFactory);
+      }
       if (seedMapper.hasMapping(from)) {
         DexType appliedType = lenseBuilder.lookup(from);
         if (appliedType != from) {
diff --git a/src/test/java/com/android/tools/r8/naming/applymapping/InnerEnumValuesTest.java b/src/test/java/com/android/tools/r8/naming/applymapping/InnerEnumValuesTest.java
index 6c8a9be..2500be1 100644
--- a/src/test/java/com/android/tools/r8/naming/applymapping/InnerEnumValuesTest.java
+++ b/src/test/java/com/android/tools/r8/naming/applymapping/InnerEnumValuesTest.java
@@ -3,20 +3,43 @@
 // BSD-style license that can be found in the LICENSE file.
 package com.android.tools.r8.naming.applymapping;
 
+import static com.android.tools.r8.utils.codeinspector.Matchers.isPresent;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertThat;
+
 import com.android.tools.r8.TestBase;
 import com.android.tools.r8.naming.applymapping.Outer.InnerEnum;
+import com.android.tools.r8.utils.BooleanUtils;
 import com.android.tools.r8.utils.FileUtils;
 import com.android.tools.r8.utils.StringUtils;
+import com.android.tools.r8.utils.codeinspector.ClassSubject;
+import com.android.tools.r8.utils.codeinspector.FieldSubject;
 import java.nio.file.Path;
+import java.util.Collection;
 import org.junit.Before;
-import org.junit.Ignore;
 import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.junit.runners.Parameterized;
 
+@RunWith(Parameterized.class)
 public class InnerEnumValuesTest extends TestBase {
-  private static Class<?> MAIN = TestApp.class;
-  private static String EXPECTED_OUTPUT = StringUtils.lines("state_X", "state_Y");
+  private static final Class<?> MAIN = TestApp.class;
+  private static final String RENAMED_NAME = "x.y.z$ie";
+  private static final String EXPECTED_OUTPUT = StringUtils.lines("STATE_A", "STATE_B");
 
   private static Path mappingFile;
+  private final Backend backend;
+  private final boolean minification;
+
+  @Parameterized.Parameters(name = "Backend: {0} minification: {1}")
+  public static Collection<Object[]> data() {
+    return buildParameters(Backend.values(), BooleanUtils.values());
+  }
+
+  public InnerEnumValuesTest(Backend backend, boolean minification) {
+    this.backend = backend;
+    this.minification = minification;
+  }
 
   @Before
   public void setup() throws Exception {
@@ -27,7 +50,7 @@
         StringUtils.lines(
             Outer.class.getTypeName() + " -> " + "x.y.z:",
             "    void <init>() -> <init>",
-            InnerEnum.class.getTypeName() + " -> " + "x.y.z$ie:",
+            InnerEnum.class.getTypeName() + " -> " + RENAMED_NAME + ":",
             "    " + InnerEnum.class.getTypeName() + " STATE_A -> state_X",
             "    " + InnerEnum.class.getTypeName() + " STATE_B -> state_Y",
             "    " + InnerEnum.class.getTypeName() + "[] $VALUES -> XY",
@@ -37,18 +60,29 @@
             "    " + InnerEnum.class.getTypeName() + "[] values() -> values"));
   }
 
-  @Ignore("b/124177369")
   @Test
   public void b124177369() throws Exception {
-    testForR8(Backend.DEX)
+    testForR8(backend)
         .addProgramClassesAndInnerClasses(Outer.class)
         .addProgramClasses(MAIN)
         .addKeepMainRule(MAIN)
-        .addKeepRules("-dontoptimize")
         .addKeepRules("-applymapping " + mappingFile.toAbsolutePath())
+        .minification(minification)
         .compile()
-        .run(MAIN)
-        .assertSuccessWithOutput(EXPECTED_OUTPUT);
+        .inspect(inspector -> {
+          ClassSubject enumSubject = inspector.clazz(RENAMED_NAME);
+          assertThat(enumSubject, isPresent());
+          assertEquals(minification, enumSubject.isRenamed());
+          String fieldName =
+              minification
+                  ? "a"        // minified name
+                  : "state_X"; // mapped name without minification
+          FieldSubject stateA = enumSubject.uniqueFieldWithName(fieldName);
+          assertThat(stateA, isPresent());
+        });
+    // TODO(b/124177369): method signature Object Outer$InnerEnum[]#clone() left in values().
+    //  .run(MAIN)
+    //  .assertSuccessWithOutput(EXPECTED_OUTPUT);
   }
 }