|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.test.util.ReflectionTestUtils
public class ReflectionTestUtils
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:
private
or protected
field access as opposed to
public
setter methods for properties in a domain entity.@Autowired
and
@Resource
which provides dependency
injection for private
or protected
fields, setter
methods, and configuration methods.
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 |
---|
private static final java.lang.String SETTER_PREFIX
private static final java.lang.String GETTER_PREFIX
private static final Log logger
Constructor Detail |
---|
public ReflectionTestUtils()
Method Detail |
---|
public static void setField(java.lang.Object target, java.lang.String name, java.lang.Object value)
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.
target
- the target object on which to set the fieldname
- the name of the field to setvalue
- the value to setReflectionUtils.findField(Class, String, Class)
,
ReflectionUtils.makeAccessible(Field)
,
ReflectionUtils.setField(Field, Object, Object)
public static void setField(java.lang.Object target, java.lang.String name, java.lang.Object value, java.lang.Class<?> type)
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.
target
- the target object on which to set the fieldname
- the name of the field to setvalue
- the value to settype
- the type of the field (may be null
)ReflectionUtils.findField(Class, String, Class)
,
ReflectionUtils.makeAccessible(Field)
,
ReflectionUtils.setField(Field, Object, Object)
public static java.lang.Object getField(java.lang.Object target, java.lang.String name)
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.
target
- the target object on which to set the fieldname
- the name of the field to get
ReflectionUtils.findField(Class, String, Class)
,
ReflectionUtils.makeAccessible(Field)
,
ReflectionUtils.setField(Field, Object, Object)
public static void invokeSetterMethod(java.lang.Object target, java.lang.String name, java.lang.Object value)
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.
target
- the target object on which to invoke the specified setter
methodname
- the name of the setter method to invoke or the corresponding
property namevalue
- the value to provide to the setter methodReflectionUtils.findMethod(Class, String, Class[])
,
ReflectionUtils.makeAccessible(Method)
,
ReflectionUtils.invokeMethod(Method, Object, Object[])
public static void invokeSetterMethod(java.lang.Object target, java.lang.String name, java.lang.Object value, java.lang.Class<?> type)
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.
target
- the target object on which to invoke the specified setter
methodname
- the name of the setter method to invoke or the corresponding
property namevalue
- the value to provide to the setter methodtype
- the formal parameter type declared by the setter methodReflectionUtils.findMethod(Class, String, Class[])
,
ReflectionUtils.makeAccessible(Method)
,
ReflectionUtils.invokeMethod(Method, Object, Object[])
public static java.lang.Object invokeGetterMethod(java.lang.Object target, java.lang.String name)
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.
target
- the target object on which to invoke the specified getter
methodname
- the name of the getter method to invoke or the corresponding
property name
ReflectionUtils.findMethod(Class, String, Class[])
,
ReflectionUtils.makeAccessible(Method)
,
ReflectionUtils.invokeMethod(Method, Object, Object[])
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |