Merge branch 'release-0.9.6'
[Sone.git] / src / test / java / net / pterodactylus / sone / TestUtil.java
index d1a4d04..fa7879d 100644 (file)
@@ -1,6 +1,8 @@
 package net.pterodactylus.sone;
 
 import java.lang.reflect.Field;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
 import java.lang.reflect.Modifier;
 
 /**
@@ -37,4 +39,18 @@ public class TestUtil {
                }
        }
 
+       public static <T> T callPrivateMethod(Object object, String methodName) {
+               try {
+                       Method method = object.getClass().getDeclaredMethod(methodName, new Class[0]);
+                       method.setAccessible(true);
+                       return (T) method.invoke(object);
+               } catch (NoSuchMethodException e) {
+                       throw new RuntimeException(e);
+               } catch (InvocationTargetException e) {
+                       throw new RuntimeException(e);
+               } catch (IllegalAccessException e) {
+                       throw new RuntimeException(e);
+               }
+       }
+
 }