2007-12-01 00:00:00 +00:00
|
|
|
/*
|
2010-05-25 15:58:33 -07:00
|
|
|
* Copyright (c) 2003, 2008, Oracle and/or its affiliates. All rights reserved.
|
2007-12-01 00:00:00 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
2010-05-25 15:58:33 -07:00
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
2007-12-01 00:00:00 +00:00
|
|
|
*/
|
|
|
|
|
2008-05-07 23:20:32 +04:00
|
|
|
import java.beans.BeanDescriptor;
|
2007-12-01 00:00:00 +00:00
|
|
|
import java.beans.EventSetDescriptor;
|
|
|
|
import java.beans.IndexedPropertyDescriptor;
|
|
|
|
import java.beans.IntrospectionException;
|
|
|
|
import java.beans.Introspector;
|
|
|
|
import java.beans.MethodDescriptor;
|
|
|
|
import java.beans.PropertyDescriptor;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class contains utilities useful for JavaBeans regression testing.
|
|
|
|
*/
|
|
|
|
public final class BeanUtils {
|
|
|
|
/**
|
|
|
|
* Disables instantiation.
|
|
|
|
*/
|
|
|
|
private BeanUtils() {
|
|
|
|
}
|
|
|
|
|
2008-05-07 23:20:32 +04:00
|
|
|
/**
|
|
|
|
* Returns a bean descriptor for specified class.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @return a bean descriptor
|
|
|
|
*/
|
|
|
|
public static BeanDescriptor getBeanDescriptor(Class type) {
|
|
|
|
try {
|
|
|
|
return Introspector.getBeanInfo(type).getBeanDescriptor();
|
|
|
|
} catch (IntrospectionException exception) {
|
|
|
|
throw new Error("unexpected exception", exception);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
/**
|
|
|
|
* Returns an array of property descriptors for specified class.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @return an array of property descriptors
|
|
|
|
*/
|
|
|
|
public static PropertyDescriptor[] getPropertyDescriptors(Class type) {
|
|
|
|
try {
|
|
|
|
return Introspector.getBeanInfo(type).getPropertyDescriptors();
|
|
|
|
} catch (IntrospectionException exception) {
|
|
|
|
throw new Error("unexpected exception", exception);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-05-07 23:20:32 +04:00
|
|
|
/**
|
|
|
|
* Returns an array of event set descriptors for specified class.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @return an array of event set descriptors
|
|
|
|
*/
|
|
|
|
public static EventSetDescriptor[] getEventSetDescriptors(Class type) {
|
|
|
|
try {
|
|
|
|
return Introspector.getBeanInfo(type).getEventSetDescriptors();
|
|
|
|
} catch (IntrospectionException exception) {
|
|
|
|
throw new Error("unexpected exception", exception);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds an event set descriptor for the class
|
|
|
|
* that matches the event set name.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @param name the name of the event set to search
|
|
|
|
* @return the {@code EventSetDescriptor} or {@code null}
|
|
|
|
*/
|
|
|
|
public static EventSetDescriptor findEventSetDescriptor(Class type, String name) {
|
|
|
|
EventSetDescriptor[] esds = getEventSetDescriptors(type);
|
|
|
|
for (EventSetDescriptor esd : esds) {
|
|
|
|
if (esd.getName().equals(name)) {
|
|
|
|
return esd;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
/**
|
|
|
|
* Finds a property descriptor for the class
|
|
|
|
* that matches the property name.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @param name the name of the property to search
|
|
|
|
* @return the {@code PropertyDescriptor}, {@code IndexedPropertyDescriptor} or {@code null}
|
|
|
|
*/
|
|
|
|
public static PropertyDescriptor findPropertyDescriptor(Class type, String name) {
|
|
|
|
PropertyDescriptor[] pds = getPropertyDescriptors(type);
|
|
|
|
for (PropertyDescriptor pd : pds) {
|
|
|
|
if (pd.getName().equals(name)) {
|
|
|
|
return pd;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2008-05-07 23:20:32 +04:00
|
|
|
/**
|
|
|
|
* Returns a event set descriptor for the class
|
|
|
|
* that matches the property name.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @param name the name of the event set to search
|
|
|
|
* @return the {@code EventSetDescriptor}
|
|
|
|
*/
|
|
|
|
public static EventSetDescriptor getEventSetDescriptor(Class type, String name) {
|
|
|
|
EventSetDescriptor esd = findEventSetDescriptor(type, name);
|
|
|
|
if (esd != null) {
|
|
|
|
return esd;
|
|
|
|
}
|
|
|
|
throw new Error("could not find event set '" + name + "' in " + type);
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
/**
|
|
|
|
* Returns a property descriptor for the class
|
|
|
|
* that matches the property name.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @param name the name of the property to search
|
|
|
|
* @return the {@code PropertyDescriptor}
|
|
|
|
*/
|
|
|
|
public static PropertyDescriptor getPropertyDescriptor(Class type, String name) {
|
|
|
|
PropertyDescriptor pd = findPropertyDescriptor(type, name);
|
|
|
|
if (pd != null) {
|
|
|
|
return pd;
|
|
|
|
}
|
|
|
|
throw new Error("could not find property '" + name + "' in " + type);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an indexed property descriptor for the class
|
|
|
|
* that matches the property name.
|
|
|
|
*
|
|
|
|
* @param type the class to introspect
|
|
|
|
* @param name the name of the property to search
|
|
|
|
* @return the {@code IndexedPropertyDescriptor}
|
|
|
|
*/
|
|
|
|
public static IndexedPropertyDescriptor getIndexedPropertyDescriptor(Class type, String name) {
|
|
|
|
PropertyDescriptor pd = findPropertyDescriptor(type, name);
|
|
|
|
if (pd instanceof IndexedPropertyDescriptor) {
|
|
|
|
return (IndexedPropertyDescriptor) pd;
|
|
|
|
}
|
|
|
|
reportPropertyDescriptor(pd);
|
|
|
|
throw new Error("could not find indexed property '" + name + "' in " + type);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reports all the interesting information in an Indexed/PropertyDescrptor.
|
|
|
|
*/
|
|
|
|
public static void reportPropertyDescriptor(PropertyDescriptor pd) {
|
|
|
|
System.out.println("property name: " + pd.getName());
|
|
|
|
System.out.println(" type: " + pd.getPropertyType());
|
|
|
|
System.out.println(" read: " + pd.getReadMethod());
|
|
|
|
System.out.println(" write: " + pd.getWriteMethod());
|
|
|
|
if (pd instanceof IndexedPropertyDescriptor) {
|
|
|
|
IndexedPropertyDescriptor ipd = (IndexedPropertyDescriptor) pd;
|
|
|
|
System.out.println(" indexed type: " + ipd.getIndexedPropertyType());
|
|
|
|
System.out.println(" indexed read: " + ipd.getIndexedReadMethod());
|
|
|
|
System.out.println(" indexed write: " + ipd.getIndexedWriteMethod());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reports all the interesting information in an EventSetDescriptor
|
|
|
|
*/
|
|
|
|
public static void reportEventSetDescriptor(EventSetDescriptor esd) {
|
|
|
|
System.out.println("event set name: " + esd.getName());
|
|
|
|
System.out.println(" listener type: " + esd.getListenerType());
|
|
|
|
System.out.println(" method get: " + esd.getGetListenerMethod());
|
|
|
|
System.out.println(" method add: " + esd.getAddListenerMethod());
|
|
|
|
System.out.println(" method remove: " + esd.getRemoveListenerMethod());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reports all the interesting information in a MethodDescriptor
|
|
|
|
*/
|
|
|
|
public static void reportMethodDescriptor(MethodDescriptor md) {
|
|
|
|
System.out.println("method name: " + md.getName());
|
|
|
|
System.out.println(" method: " + md.getMethod());
|
|
|
|
}
|
|
|
|
}
|