8152343: JVMCI test tasks: Unit tests for MetaAccessProvider
authordpochepk
Mon, 16 May 2016 17:01:53 +0300
changeset 38691 a2c52cff500d
parent 38690 5c01a80db90c
child 38692 54a84b7f3721
child 38693 9b68b18ad248
8152343: JVMCI test tasks: Unit tests for MetaAccessProvider Reviewed-by: twisti
hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java
--- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java	Mon May 16 17:00:08 2016 +0300
+++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java	Mon May 16 17:01:53 2016 +0300
@@ -37,10 +37,13 @@
 import static jdk.vm.ci.meta.MetaUtil.toInternalName;
 import static org.junit.Assert.assertEquals;
 import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertNull;
 import static org.junit.Assert.assertTrue;
 
 import java.lang.reflect.Field;
 import java.lang.reflect.Method;
+import jdk.vm.ci.meta.DeoptimizationAction;
+import jdk.vm.ci.meta.DeoptimizationReason;
 
 import jdk.vm.ci.meta.JavaConstant;
 import jdk.vm.ci.meta.JavaKind;
@@ -48,6 +51,7 @@
 import jdk.vm.ci.meta.ResolvedJavaField;
 import jdk.vm.ci.meta.ResolvedJavaMethod;
 import jdk.vm.ci.meta.ResolvedJavaType;
+import jdk.vm.ci.meta.Signature;
 
 import org.junit.Test;
 
@@ -55,6 +59,16 @@
  * Tests for {@link MetaAccessProvider}.
  */
 public class TestMetaAccessProvider extends TypeUniverse {
+    private static final DeoptimizationAction DEOPT_ACTION = DeoptimizationAction.InvalidateRecompile;
+    private static final DeoptimizationReason DEOPT_REASON = DeoptimizationReason.Aliasing;
+    private static final int INT_23BITS_SET = 0x7FFFFF;
+    private static final int[] DEBUG_IDS = new int[]{0, 1, 42, INT_23BITS_SET};
+    private static final int[] VALID_ENCODED_VALUES = new int[]{
+                    metaAccess.encodeDeoptActionAndReason(DEOPT_ACTION, DEOPT_REASON, DEBUG_IDS[0]).asInt(),
+                    metaAccess.encodeDeoptActionAndReason(DEOPT_ACTION, DEOPT_REASON, DEBUG_IDS[1]).asInt(),
+                    metaAccess.encodeDeoptActionAndReason(DEOPT_ACTION, DEOPT_REASON, DEBUG_IDS[2]).asInt(),
+                    metaAccess.encodeDeoptActionAndReason(DEOPT_ACTION, DEOPT_REASON, DEBUG_IDS[3]).asInt()
+    };
 
     @Test
     public void lookupJavaTypeTest() {
@@ -70,6 +84,37 @@
         }
     }
 
+    @Test(expected = IllegalArgumentException.class)
+    public void lookupJavaTypeNegativeTest() {
+        metaAccess.lookupJavaType((Class<?>) null);
+    }
+
+    @Test
+    public void lookupJavaTypesTest() {
+        ResolvedJavaType[] result = metaAccess.lookupJavaTypes(classes.toArray(new Class<?>[classes.size()]));
+        int counter = 0;
+        for (Class<?> aClass : classes) {
+            assertEquals("Unexpected javaType: " + result[counter] + " while expecting of class: " + aClass, result[counter].toClassName(), aClass.getName());
+            counter++;
+        }
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void lookupJavaTypesNegative1Test() {
+        assertNull("Expected null", metaAccess.lookupJavaTypes(null));
+    }
+
+    @Test(expected = IllegalArgumentException.class)
+    public void lookupJavaTypesNegative2Test() {
+        ResolvedJavaType[] result = metaAccess.lookupJavaTypes(new Class<?>[]{null, null, null});
+        for (ResolvedJavaType aType : result) {
+            assertNull("Expected null javaType", aType);
+        }
+        result = metaAccess.lookupJavaTypes(new Class<?>[]{String.class, String.class});
+        assertEquals("Results not equals", result[0].getClass(), result[1].getClass());
+        assertEquals("Result is not String.class", result[0].getClass(), String.class);
+    }
+
     @Test
     public void lookupJavaMethodTest() {
         for (Class<?> c : classes) {
@@ -81,6 +126,11 @@
         }
     }
 
+    @Test(expected = NullPointerException.class)
+    public void lookupJavaMethodNegativeTest() {
+        metaAccess.lookupJavaMethod(null);
+    }
+
     @Test
     public void lookupJavaFieldTest() {
         for (Class<?> c : classes) {
@@ -106,4 +156,107 @@
             }
         }
     }
+
+    @Test(expected = NullPointerException.class)
+    public void lookupJavaTypeConstantNegativeTest() {
+        metaAccess.lookupJavaType((JavaConstant) null);
+    }
+
+    @Test
+    public void getMemorySizeTest() {
+        for (ConstantValue cv : constants()) {
+            JavaConstant c = cv.value;
+            long memSize = metaAccess.getMemorySize(c);
+            if (c.isNull()) {
+                assertEquals("Expected size = 0 for null", memSize, 0L);
+            } else {
+                assertTrue("Expected size != 0 for " + cv, memSize != 0L);
+            }
+        }
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void getMemorySizeNegativeTest() {
+        metaAccess.getMemorySize(null);
+    }
+
+    @Test
+    public void parseMethodDescriptorTest() {
+        for (String retType : new String[]{"V", "Z", "Ljava/lang/String;"}) {
+            for (String paramTypes : new String[]{"", "B",
+                            "Ljava/lang/String;", "JLjava/lang/String;",
+                            "Ljava/lang/String;F",
+                            "[Ljava/lang/String;ZBCDFIJLS[ILjava/lang/Object;"}) {
+                String signature = "(" + paramTypes + ")" + retType;
+                Signature result = metaAccess.parseMethodDescriptor(signature);
+                assertEquals("Expected signatures to be equal", result.toMethodDescriptor(), signature);
+            }
+        }
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void parseMethodDescriptorNegativeNullTest() {
+        metaAccess.parseMethodDescriptor(null);
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void encodeDeoptActionAndReasonNegative1Test() {
+        metaAccess.encodeDeoptActionAndReason(null, DeoptimizationReason.Aliasing, 0);
+
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void encodeDeoptActionAndReasonNegative2Test() {
+        metaAccess.encodeDeoptActionAndReason(DeoptimizationAction.InvalidateRecompile, null, 0);
+    }
+
+    @Test
+    public void decodeDeoptReasonTest() {
+        for (int encoded : VALID_ENCODED_VALUES) {
+            JavaConstant value = JavaConstant.forInt(encoded);
+            DeoptimizationReason reason = metaAccess.decodeDeoptReason(value);
+            assertEquals("Expected equal reasons", reason, DEOPT_REASON);
+        }
+    }
+
+    @Test
+    public void decodeDeoptReasonNegative1Test() {
+        int encoded = 42;
+        JavaConstant value = JavaConstant.forInt(encoded);
+        metaAccess.decodeDeoptReason(value);
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void decodeDeoptReasonNegative2Test() {
+        metaAccess.decodeDeoptReason(null);
+    }
+
+    @Test
+    public void decodeDeoptActionTest() {
+        for (int encoded : VALID_ENCODED_VALUES) {
+            JavaConstant value = JavaConstant.forInt(encoded);
+            DeoptimizationAction action = metaAccess.decodeDeoptAction(value);
+            assertEquals("Expected equal actions", action, DEOPT_ACTION);
+        }
+    }
+
+    @Test
+    public void decodeDeoptActionNegative1Test() {
+        int encoded = 123456789;
+        JavaConstant value = JavaConstant.forInt(encoded);
+        metaAccess.decodeDeoptAction(value);
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void decodeDeoptActionNegative2Test() {
+        metaAccess.decodeDeoptAction(null);
+    }
+
+    @Test
+    public void decodeDebugIdTest() {
+        for (int i = 0; i < VALID_ENCODED_VALUES.length; i++) {
+            JavaConstant value = JavaConstant.forInt(VALID_ENCODED_VALUES[i]);
+            assertEquals("Unexpected debugId", metaAccess.decodeDebugId(value), DEBUG_IDS[i]);
+        }
+    }
 }