< prev index next >

test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java

Print this page

        

@@ -33,29 +33,39 @@
 
 package jdk.vm.ci.runtime.test;
 
 import static jdk.vm.ci.meta.MetaUtil.toInternalName;
 import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotSame;
 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;
 import jdk.vm.ci.meta.MetaAccessProvider;
 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;
 
 /**
  * Tests for {@link MetaAccessProvider}.
  */
 public class TestMetaAccessProvider extends TypeUniverse {
+    /* These values are encoded values for deoptReason=Aliasing,
+       deoptAction=InvalidateRecompile and debugId={0, 1, 42, 0x7FFFFF}
+       so, we have 0, 1, <some non-border value>, 0x7FFFFF which is a maximum debugId value,
+       which is 23 bits wide */
+    private static final int[] VALID_ENCODED_VALUES = new int[] {0xFFFFFF4C, 0xFFFFFE4C, 0xFFFFD54C, 0x8000004C};
 
     @Test
     public void lookupJavaTypeTest() {
         for (Class<?> c : classes) {
             ResolvedJavaType type = metaAccess.lookupJavaType(c);

@@ -67,10 +77,48 @@
                 assertEquals(c.toString(), c.getName(), type.toJavaName());
             }
         }
     }
 
+    @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) {
             for (Method reflect : c.getDeclaredMethods()) {
                 ResolvedJavaMethod method = metaAccess.lookupJavaMethod(reflect);

@@ -78,10 +126,15 @@
                 assertTrue(method.getDeclaringClass().equals(metaAccess.lookupJavaType(reflect.getDeclaringClass())));
             }
         }
     }
 
+    @Test(expected = NullPointerException.class)
+    public void lookupJavaMethodNegativeTest() {
+        metaAccess.lookupJavaMethod(null);
+    }
+
     @Test
     public void lookupJavaFieldTest() {
         for (Class<?> c : classes) {
             for (Field reflect : c.getDeclaredFields()) {
                 ResolvedJavaField field = metaAccess.lookupJavaField(reflect);

@@ -103,6 +156,147 @@
             } else {
                 assertEquals(metaAccess.lookupJavaType(c), null);
             }
         }
     }
+
+    @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
+    public void encodeDeoptActionAndReasonTest() {
+        int[] ids = new int[]{-1, 0, 1, Integer.MAX_VALUE};
+        int casesLength = ids.length * DeoptimizationAction.values().length
+                * DeoptimizationReason.values().length;
+        JavaConstant[] allValues = new JavaConstant[casesLength];
+        int counter = 0;
+        for (DeoptimizationAction action : DeoptimizationAction.values()) {
+            for (DeoptimizationReason reason : DeoptimizationReason.values()) {
+                for (int debugId : new int[]{-1, 0, 1, Integer.MAX_VALUE}) {
+                    JavaConstant result = metaAccess
+                            .encodeDeoptActionAndReason(action, reason,
+                                    debugId);
+                    JavaConstant result2 = metaAccess
+                            .encodeDeoptActionAndReason(action, reason,
+                                    debugId);
+                    assertNotNull("Expected not null result", result);
+                    assertEquals("Expected equal results", result, result2);
+                    allValues[counter++] = result;
+                    for (int i = 0; i < counter - 1; i++) {
+                        assertNotSame("Expected unique result for value "
+                                + result, result, allValues[i]);
+                    }
+                }
+            }
+        }
+    }
+
+    @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);
+            DeoptimizationReason reason2 = metaAccess.decodeDeoptReason(value);
+            assertNotNull("Expected not null reason", reason);
+            assertEquals("Expected equal reasons", reason, reason2);
+        }
+    }
+
+    @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);
+            DeoptimizationAction action2 = metaAccess.decodeDeoptAction(value);
+            assertNotNull("Expected not null action", action);
+            assertEquals("Expected equal actions", action, action2);
+        }
+    }
+
+    @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() {
+        int[] input = new int[]{-1, 0, 1, 42, Integer.MAX_VALUE, Integer.MIN_VALUE};
+        for (int encoded : input) {
+            JavaConstant value = JavaConstant.forInt(encoded);
+            int id = metaAccess.decodeDebugId(value);
+            int id2 = metaAccess.decodeDebugId(value);
+            assertEquals("Expected equal debugId", id, id2);
+        }
+    }
 }
< prev index next >