org.springframework.test.util
Class ReflectionTestUtils

java.lang.Object
  extended by org.springframework.test.util.ReflectionTestUtils

public class ReflectionTestUtils
extends java.lang.Object

ReflectionTestUtils is a collection of reflection-based utility methods for use in unit and integration testing scenarios.

There are often situations in which it would be beneficial to be able to set a non-public field or invoke a non-public setter method when testing code involving, for example:

Since:
2.5
Author:
Sam Brannen, Juergen Hoeller
See Also:
ReflectionUtils

Field Summary
private static java.lang.String GETTER_PREFIX
           
private static Log logger
           
private static java.lang.String SETTER_PREFIX
           
 
Constructor Summary
ReflectionTestUtils()
           
 
Method Summary
static java.lang.Object getField(java.lang.Object target, java.lang.String name)
          Get the field with the given name from the provided target object.
static java.lang.Object invokeGetterMethod(java.lang.Object target, java.lang.String name)
          Invoke the getter method with the given name on the supplied target object with the supplied value.
static void invokeSetterMethod(java.lang.Object target, java.lang.String name, java.lang.Object value)
          Invoke the setter method with the given name on the supplied target object with the supplied value.
static void invokeSetterMethod(java.lang.Object target, java.lang.String name, java.lang.Object value, java.lang.Class<?> type)
          Invoke the setter method with the given name on the supplied target object with the supplied value.
static void setField(java.lang.Object target, java.lang.String name, java.lang.Object value)
          Set the field with the given name on the provided target object to the supplied value.
static void setField(java.lang.Object target, java.lang.String name, java.lang.Object value, java.lang.Class<?> type)
          Set the field with the given name on the provided target object to the supplied value.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

SETTER_PREFIX

private static final java.lang.String SETTER_PREFIX
See Also:
Constant Field Values

GETTER_PREFIX

private static final java.lang.String GETTER_PREFIX
See Also:
Constant Field Values

logger

private static final Log logger
Constructor Detail

ReflectionTestUtils

public ReflectionTestUtils()
Method Detail

setField

public static void setField(java.lang.Object target,
                            java.lang.String name,
                            java.lang.Object value)
Set the field with the given name on the provided target object to the supplied value.

This method traverses the class hierarchy in search of the desired field. In addition, an attempt will be made to make non-public fields accessible, thus allowing one to set protected, private, and package-private fields.

Parameters:
target - the target object on which to set the field
name - the name of the field to set
value - the value to set
See Also:
ReflectionUtils.findField(Class, String, Class), ReflectionUtils.makeAccessible(Field), ReflectionUtils.setField(Field, Object, Object)

setField

public static void setField(java.lang.Object target,
                            java.lang.String name,
                            java.lang.Object value,
                            java.lang.Class<?> type)
Set the field with the given name on the provided target object to the supplied value.

This method traverses the class hierarchy in search of the desired field. In addition, an attempt will be made to make non-public fields accessible, thus allowing one to set protected, private, and package-private fields.

Parameters:
target - the target object on which to set the field
name - the name of the field to set
value - the value to set
type - the type of the field (may be null)
See Also:
ReflectionUtils.findField(Class, String, Class), ReflectionUtils.makeAccessible(Field), ReflectionUtils.setField(Field, Object, Object)

getField

public static java.lang.Object getField(java.lang.Object target,
                                        java.lang.String name)
Get the field with the given name from the provided target object.

This method traverses the class hierarchy in search of the desired field. In addition, an attempt will be made to make non-public fields accessible, thus allowing one to get protected, private, and package-private fields.

Parameters:
target - the target object on which to set the field
name - the name of the field to get
Returns:
the field's current value
See Also:
ReflectionUtils.findField(Class, String, Class), ReflectionUtils.makeAccessible(Field), ReflectionUtils.setField(Field, Object, Object)

invokeSetterMethod

public static void invokeSetterMethod(java.lang.Object target,
                                      java.lang.String name,
                                      java.lang.Object value)
Invoke the setter method with the given name on the supplied target object with the supplied value.

This method traverses the class hierarchy in search of the desired method. In addition, an attempt will be made to make non- public methods accessible, thus allowing one to invoke protected, private, and package-private setter methods.

In addition, this method supports JavaBean-style property names. For example, if you wish to set the name property on the target object, you may pass either "name" or "setName" as the method name.

Parameters:
target - the target object on which to invoke the specified setter method
name - the name of the setter method to invoke or the corresponding property name
value - the value to provide to the setter method
See Also:
ReflectionUtils.findMethod(Class, String, Class[]), ReflectionUtils.makeAccessible(Method), ReflectionUtils.invokeMethod(Method, Object, Object[])

invokeSetterMethod

public static void invokeSetterMethod(java.lang.Object target,
                                      java.lang.String name,
                                      java.lang.Object value,
                                      java.lang.Class<?> type)
Invoke the setter method with the given name on the supplied target object with the supplied value.

This method traverses the class hierarchy in search of the desired method. In addition, an attempt will be made to make non- public methods accessible, thus allowing one to invoke protected, private, and package-private setter methods.

In addition, this method supports JavaBean-style property names. For example, if you wish to set the name property on the target object, you may pass either "name" or "setName" as the method name.

Parameters:
target - the target object on which to invoke the specified setter method
name - the name of the setter method to invoke or the corresponding property name
value - the value to provide to the setter method
type - the formal parameter type declared by the setter method
See Also:
ReflectionUtils.findMethod(Class, String, Class[]), ReflectionUtils.makeAccessible(Method), ReflectionUtils.invokeMethod(Method, Object, Object[])

invokeGetterMethod

public static java.lang.Object invokeGetterMethod(java.lang.Object target,
                                                  java.lang.String name)
Invoke the getter method with the given name on the supplied target object with the supplied value.

This method traverses the class hierarchy in search of the desired method. In addition, an attempt will be made to make non- public methods accessible, thus allowing one to invoke protected, private, and package-private getter methods.

In addition, this method supports JavaBean-style property names. For example, if you wish to get the name property on the target object, you may pass either "name" or "getName" as the method name.

Parameters:
target - the target object on which to invoke the specified getter method
name - the name of the getter method to invoke or the corresponding property name
Returns:
the value returned from the invocation
See Also:
ReflectionUtils.findMethod(Class, String, Class[]), ReflectionUtils.makeAccessible(Method), ReflectionUtils.invokeMethod(Method, Object, Object[])