Merge pull request #5636 from BrzVlad/fix-xmm-scan
[mono.git] / mono / tests / runtime-invoke.cs
index 7ffaf16ee4f01fba386ae5a13dc067466b336edc..2c34478f83d63d1931908c51f24d1384fbc2f1db 100644 (file)
@@ -17,11 +17,52 @@ public class D
        }
 }
 
-class X
+enum Enum1
 {
-       static void Main ()
+       A,
+       B
+}
+
+enum Enum2
+{
+       C,
+       D
+}
+
+struct AStruct {
+       public int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10;
+       public int a11, a12, a13, a14, a15, a16, a17, a18, a19, a20;
+}
+
+class Tests
+{
+       public static Enum1 return_enum1 () {
+               return Enum1.A;
+       }
+
+       public static Enum2 return_enum2 () {
+               return Enum2.C;
+       }
+
+       public static long return_long () {
+               return 1234;
+       }
+
+       public static ulong return_ulong () {
+               return UInt64.MaxValue - 5;
+       }
+
+       public static object return_t<T> (T t) {
+               return (object)t;
+       }
+
+       static int Main (string[] args)
        {
-               Assembly ass = Assembly.GetCallingAssembly ();
+               return TestDriver.RunTests (typeof (Tests), args);
+       }
+
+       public static int test_0_base () {
+               Assembly ass = typeof (Tests).Assembly;
                Type a_type = ass.GetType ("A");
                MethodInfo a_method = a_type.GetMethod ("ToString");
 
@@ -38,5 +79,228 @@ class X
 
                object d_ret = d_method.Invoke (d, null);
                Console.WriteLine (d_ret);
+
+               return 0;
+       }
+
+       public static int test_0_enum_sharing () {
+               /* Check sharing of wrappers returning enums */
+               if (typeof (Tests).GetMethod ("return_enum1").Invoke (null, null).GetType () != typeof (Enum1))
+                       return 1;
+               if (typeof (Tests).GetMethod ("return_enum2").Invoke (null, null).GetType () != typeof (Enum2))
+                       return 2;
+               return 0;
+       }
+
+       public static int test_0_primitive_sharing () {
+               /* Check sharing of wrappers returning primitive types */
+               if (typeof (Tests).GetMethod ("return_long").Invoke (null, null).GetType () != typeof (long))
+                       return 3;
+               if (typeof (Tests).GetMethod ("return_ulong").Invoke (null, null).GetType () != typeof (ulong))
+                       return 4;
+
+               return 0;
+       }
+
+       public struct Foo
+       {
+               public string ToString2 () {
+                       return "FOO";
+               }
+       }
+
+       public static object GetNSObject (IntPtr i) {
+               return i;
+       }
+
+       public static int test_0_vtype_method_sharing () {
+               /* Check sharing of wrappers of vtype methods with static methods having an IntPtr argument */
+               if ((string)(typeof (Foo).GetMethod ("ToString2").Invoke (new Foo (), null)) != "FOO")
+                       return 3;
+               object o = typeof (Tests).GetMethod ("GetNSObject").Invoke (null, new object [] { new IntPtr (42) });
+               if (!(o is IntPtr) || ((IntPtr)o != new IntPtr (42)))
+                       return 4;
+
+               return 0;
+       }
+
+       public static unsafe int test_0_ptr () {
+               int[] arr = new int [10];
+               fixed (void *p = &arr [5]) {
+                       object o = typeof (Tests).GetMethod ("data_types_ptr").Invoke (null, new object [1] { new IntPtr (p) });
+                       void *p2 = Pointer.Unbox (o);
+                       if (new IntPtr (p) != new IntPtr (p2))
+                               return 1;
+
+                       o = typeof (Tests).GetMethod ("data_types_ptr").Invoke (null, new object [1] { null });
+                       p2 = Pointer.Unbox (o);
+                       if (new IntPtr (p2) != IntPtr.Zero)
+                               return 1;
+               }
+
+               return 0;
+       }
+
+       public static int test_0_string_ctor () {
+               string res = (string)typeof (String).GetConstructor (new Type [] { typeof (char[]) }).Invoke (new object [] { new char [] { 'A', 'B', 'C' } });
+               if (res == "ABC")
+                       return 0;
+               else
+                       return 1;
+       }
+
+       public class Foo<T> {
+               public T t;
+       }
+
+       public static int test_0_ginst_ref () {
+               Foo<string> f = new Foo<string> { t = "A" };
+               Foo<string> f2 = (Foo<string>)typeof (Tests).GetMethod ("data_types_ginst_ref").MakeGenericMethod (new Type [] { typeof (string) }).Invoke (null, new object [] { f });
+               if (f2.t != "A")
+                       return 1;
+               else
+                       return 0;
+       }
+
+       public static int test_0_ginst_vtype () {
+               FooStruct<string> f = new FooStruct<string> { t = "A" };
+               FooStruct<string> f2 = (FooStruct<string>)typeof (Tests).GetMethod ("data_types_ginst_vtype").MakeGenericMethod (new Type [] { typeof (string) }).Invoke (null, new object [] { f });
+               if (f2.t != "A")
+                       return 1;
+               else
+                       return 0;
+       }
+
+       public static Foo<T> data_types_ginst_ref<T> (Foo<T> f) {
+               return f;
+       }
+
+       public struct FooStruct<T> {
+               public T t;
+       }
+
+       public static FooStruct<T> data_types_ginst_vtype<T> (FooStruct<T> f) {
+               return f;
+       }
+
+    public static unsafe int* data_types_ptr (int *val) {
+               //Console.WriteLine (new IntPtr (val));
+        return val;
+    }
+
+       public static bool pack_u2 (ushort us) {
+               return true;
+       }
+
+       public static bool pack_i2 (short value) {
+               int c = 0;
+               // Force 'value' to be register allocated
+               for (int i = 0; i < value; ++i)
+                       c += value;
+         return value < 0x80;
+       }
+
+       // #11750
+       public static int test_0_i2_u2 () {
+               typeof (Tests).GetMethod ("pack_u2").Invoke (null, new object [] { (ushort)0 });
+               var res = typeof (Tests).GetMethod ("pack_i2").Invoke (null, new object [] { (short)-1 });
+               return (bool)res ? 0 : 1;
+       }
+
+       public static bool pack_bool (bool b) {
+               return true;
+       }
+
+       public static bool pack_i1 (sbyte value) {
+               int c = 0;
+               // Force 'value' to be register allocated
+               for (int i = 0; i < value; ++i)
+                       c += value;
+               return value < -1;
+       }
+
+       public static int test_0_i1_bool () {
+               typeof (Tests).GetMethod ("pack_bool").Invoke (null, new object [] { true });
+               var res = typeof (Tests).GetMethod ("pack_i1").Invoke (null, new object [] { (sbyte)-0x40 });
+               return (bool)res ? 0 : 1;
+       }
+
+       struct Point {
+               public int x, y;
+       }
+
+       struct Foo2 {
+               public Point Location {
+                       get {
+                               return new Point () { x = 10, y = 20 };
+                       }
+               }
+       }
+
+       public static int test_0_vtype_method_vtype_ret () {
+               var f = new Foo2 ();
+               var p = (Point)typeof (Foo2).GetMethod ("get_Location").Invoke (f, null);
+               if (p.x != 10 || p.y != 20)
+                       return 1;
+               return 0;
+       }
+
+       public static int test_0_array_get_set () {
+               int[,,] arr = new int [10, 10, 10];
+               arr [0, 1, 2] = 42;
+               var gm = arr.GetType ().GetMethod ("Get");
+               int i = (int) gm.Invoke (arr, new object [] { 0, 1, 2 });
+               if (i != 42)
+                       return 1;
+               var sm = arr.GetType ().GetMethod ("Set");
+               sm.Invoke (arr, new object [] { 0, 1, 2, 33 });
+               if (arr [0, 1, 2] != 33)
+                       return 2;
+               return 0;
+       }
+
+       public static int test_0_multi_dim_array_ctor () {
+        var type1 = Type.GetType ("System.Char[,]").GetTypeInfo ();
+
+               ConstructorInfo ci = null;
+               foreach (var c in type1.DeclaredConstructors) {
+                       if (c.GetParameters ().Length == 4)
+                               ci = c;
+               }
+        var res = ci.Invoke (new object[] { 1, 5, -10, 7 });
+               var a = (Array)res;
+               if (a.GetLength (0) != 5 || a.GetLowerBound (0) != 1 || a.GetLength (1) != 7 || a.GetLowerBound (1) != -10)
+                       return 1;
+               return 0;
+       }
+
+       private static void method_invoke_no_modify_by_value_arg_helper (int dummy)
+    {
+    }
+
+    public static int test_0_method_invoke_no_modify_by_value_arg ()
+    {
+        var args = new object[] { null };
+        var method = typeof (Tests).GetMethod ("method_invoke_no_modify_by_value_arg_helper", BindingFlags.NonPublic | BindingFlags.Static);
+        method.Invoke (null, args);
+        if (args[0] == null)
+            return 0;
+        else
+            return 1;
+    }
+
+       public static int test_0_large_arg ()
+       {
+               var arg = new AStruct ();
+               arg.a1 = 1;
+               arg.a2 = 2;
+               arg.a3 = 3;
+               arg.a20 = 20;
+               var res = typeof (Tests).GetMethod ("return_t").MakeGenericMethod (new Type [] { typeof (AStruct) }).Invoke (null, new object [] { arg });
+               var arg2 = (AStruct)res;
+               if (arg2.a20 == 20)
+                       return 0;
+               else
+                       return 1;
        }
 }