fe008ae27a
Reviewed-by: darcy, weijun
341 lines
11 KiB
Java
341 lines
11 KiB
Java
/*
|
|
* Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved.
|
|
* 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.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/*
|
|
* @test
|
|
* @bug 4891872
|
|
* @summary Some tests for the generic core reflection api.
|
|
* @author Gilad Bracha
|
|
* @compile TestC1.java
|
|
* @run main/othervm -ea TestC1
|
|
*/
|
|
|
|
|
|
import java.lang.reflect.*;
|
|
|
|
|
|
abstract class C1<T> {
|
|
|
|
public T ft;
|
|
public C1<T> fc1t;
|
|
public C1 fc1;
|
|
|
|
public C1(T t) {}
|
|
|
|
public abstract C1<T> mc1t(T t, C1<T> c1t, C1 c1);
|
|
|
|
public abstract C1 mc1();
|
|
|
|
public abstract T mt(T t);
|
|
|
|
}
|
|
|
|
public class TestC1 {
|
|
|
|
static Class<C1> cls = C1.class;
|
|
static {
|
|
TestC1.class.getClassLoader().setDefaultAssertionStatus(true);
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Throwable {
|
|
testSuperclass();
|
|
testSuperInterfaces();
|
|
testTypeParameters();
|
|
testMethods();
|
|
testConstructor();
|
|
testFields();
|
|
}
|
|
|
|
static void testSuperclass() {
|
|
System.out.println("testing superclass");
|
|
Type sc = cls.getGenericSuperclass();
|
|
assert
|
|
(sc == Object.class) :
|
|
"The generic superclass of C1 should be Object";
|
|
}
|
|
|
|
static void testSuperInterfaces() {
|
|
System.out.println("testing superinterfaces");
|
|
Type[] sis = cls.getGenericInterfaces();
|
|
assert
|
|
(sis.length == 0) :
|
|
"C1 should have no generic superinterfaces";
|
|
}
|
|
|
|
static void testTypeParameters() {
|
|
System.out.println("testing type parameters");
|
|
TypeVariable[] tvs = cls.getTypeParameters();
|
|
assert
|
|
tvs.length == 1 :
|
|
"C1 should have one type parameter";
|
|
TypeVariable tv = tvs[0];
|
|
Type[] bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"T should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The default bound of a type variable should be Object";
|
|
}
|
|
|
|
static void testMethods() throws NoSuchMethodException {
|
|
System.out.println("testing methods");
|
|
Class[] params1 = new Class[3];
|
|
params1[0] = Object.class;
|
|
params1[1] = cls;
|
|
params1[2] = cls;
|
|
|
|
Class[] params3 = new Class[1];
|
|
params3[0] = Object.class;
|
|
|
|
Method mc1t = cls.getMethod("mc1t", params1);
|
|
Method mc1 = cls.getMethod("mc1", new Class[0]);
|
|
Method mt = cls.getMethod("mt", params3);
|
|
|
|
Type rt_mc1t = mc1t.getGenericReturnType();
|
|
Type rt_mc1 = mc1.getGenericReturnType();
|
|
Type rt_mt = mt.getGenericReturnType();
|
|
|
|
Type[] pt_mc1t = mc1t.getGenericParameterTypes();
|
|
|
|
assert
|
|
pt_mc1t.length == 3 :
|
|
"C1.mc1t has three parameters";
|
|
Type p1_mc1t = pt_mc1t[0];
|
|
assert p1_mc1t != null;
|
|
assert
|
|
p1_mc1t instanceof TypeVariable :
|
|
"Generic type of the 1st parameter of mc1t(T) is a type variable";
|
|
TypeVariable tv = (TypeVariable) p1_mc1t;
|
|
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"Name of 1st type parameter of mc1t is T, not " + tv.getName();
|
|
Type[] bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"T should have one bound (mc1t)";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The bound of T should be Object (mc1t)";
|
|
|
|
Type p2_mc1t = pt_mc1t[1];
|
|
|
|
assert
|
|
p2_mc1t instanceof ParameterizedType :
|
|
"The type of parameter 2 of mc1t is a parameterized type";
|
|
ParameterizedType pt = (ParameterizedType) p2_mc1t;
|
|
assert
|
|
pt.getRawType() == cls :
|
|
"Type of parameter 2 of mc1t is instantiation of C1";
|
|
assert
|
|
pt.getOwnerType() == null :
|
|
"Type of parameter 2 of mc1t is has null owner";
|
|
|
|
Type[] tas = pt.getActualTypeArguments();
|
|
assert
|
|
tas.length == 1 :
|
|
"The type of parameter 2 of mc1t has one type argument";
|
|
Type ta = tas[0];
|
|
|
|
assert
|
|
ta instanceof TypeVariable :
|
|
"The actual type arg of C1<T> is a type variable (mc1t)";
|
|
tv = (TypeVariable) ta;
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"mc1t: Name of the type arg of C1<T> is T, not " + tv.getName();
|
|
bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"mc1t: The type argument of C1<T> should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"mc1t: The bound of the type arg of C1<T> should be Object";
|
|
|
|
Type p3_mc1t = pt_mc1t[2];
|
|
|
|
assert
|
|
p3_mc1t == cls :
|
|
"Type of parameter 3 of mc1t is C1";
|
|
|
|
Type[] pt_mc1 = mc1.getGenericParameterTypes();
|
|
assert
|
|
pt_mc1.length == 0 :
|
|
"C1.mc1 has zero parameters";
|
|
|
|
Type[] pt_mt = mt.getGenericParameterTypes();
|
|
assert
|
|
pt_mt.length == 1 :
|
|
"C1.mt has one parameter";
|
|
Type p_mt = pt_mt[0];
|
|
assert
|
|
p_mt instanceof TypeVariable :
|
|
"The generic type of the parameter of mt(T) is a type variable";
|
|
tv = (TypeVariable) p_mt;
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"The name of the type parameter of mt is T, not " + tv.getName();
|
|
bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"T should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The bound of T should be Object";
|
|
|
|
Type[] et_mc1t = mc1t.getGenericExceptionTypes();
|
|
assert
|
|
et_mc1t.length == 0 :
|
|
"Method C1.mc1t should have no generic exception types";
|
|
|
|
Type[] et_mc1 = mc1.getGenericExceptionTypes();
|
|
assert
|
|
et_mc1.length == 0 :
|
|
"Method C1.mc1 should have no generic exception types";
|
|
|
|
Type[] et_mt = mt.getGenericExceptionTypes();
|
|
|
|
assert
|
|
et_mt.length == 0 :
|
|
"Method C1.mt should have no generic exception types";
|
|
|
|
|
|
TypeVariable[] tv_mc1t = mc1t.getTypeParameters();
|
|
assert
|
|
tv_mc1t.length == 0 :
|
|
"Method C1.mc1t should have no type parameters";
|
|
|
|
TypeVariable[] tv_mc1 = mc1.getTypeParameters();
|
|
assert
|
|
tv_mc1.length == 0 :
|
|
"Method C1.mc1 should have no type parameters";
|
|
|
|
TypeVariable[] tv_mt = mt.getTypeParameters();
|
|
assert
|
|
tv_mt.length == 0 :
|
|
"Method C1.mt should have no type parameters";
|
|
}
|
|
|
|
|
|
static void testFields() throws NoSuchFieldException{
|
|
System.out.println("testing fields");
|
|
Field ft = cls. getField("ft");
|
|
Field fc1t = cls. getField("fc1t");
|
|
Field fc1 = cls. getField("fc1");
|
|
|
|
Type gt_ft = ft.getGenericType();
|
|
assert
|
|
gt_ft instanceof TypeVariable :
|
|
"The generic type of C1.ft is a type variable";
|
|
TypeVariable tv = (TypeVariable) gt_ft;
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"The name of the type of ft is T, not " + tv.getName();
|
|
Type[] bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"The type of ft should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The bound of the type of ft should be Object";
|
|
|
|
Type gt_fc1t = fc1t.getGenericType();
|
|
assert
|
|
gt_fc1t instanceof ParameterizedType :
|
|
"The generic type of C1.fc1t is a parameterized type";
|
|
ParameterizedType pt = (ParameterizedType) gt_fc1t;
|
|
assert
|
|
pt.getRawType() == cls :
|
|
"Type of C1.fc1t is instantiation of C1";
|
|
assert
|
|
pt.getOwnerType() == null :
|
|
"Type of C1.fc1t is has null owner";
|
|
Type[] tas = pt.getActualTypeArguments();
|
|
assert
|
|
tas.length == 1 :
|
|
"The type of fc1t has one type argument";
|
|
Type ta = tas[0];
|
|
|
|
assert
|
|
ta instanceof TypeVariable :
|
|
"The actual type arg of C1<T> is a type variable";
|
|
tv = (TypeVariable) ta;
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"The name of the type arg of C1<T> is T, not " + tv.getName();
|
|
bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"The type argument of C1<T> should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The bound of the type arg of C1<T> should be Object";
|
|
|
|
Type gt_fc1 = fc1.getGenericType();
|
|
assert
|
|
gt_fc1 == cls :
|
|
" Type of C1.fc1 should be C1";
|
|
}
|
|
|
|
static void testConstructor() throws NoSuchMethodException {
|
|
System.out.println("testing constructors");
|
|
Class[] params = new Class[1];
|
|
params[0] = Object.class;
|
|
Constructor<C1> con = cls.getDeclaredConstructor(params);
|
|
|
|
Type[] pt_con = con.getGenericParameterTypes();
|
|
assert
|
|
pt_con.length == 1 :
|
|
"Constructor C1(T) should have one generic parameter type";
|
|
Type pt = pt_con[0];
|
|
assert
|
|
pt instanceof TypeVariable :
|
|
"The generic type of the parameter of C1(T) is a type variable";
|
|
TypeVariable tv = (TypeVariable) pt;
|
|
assert
|
|
tv.getName().equals("T") :
|
|
"The name of the type parameter of C is T, not " + tv.getName();
|
|
Type[] bs = tv.getBounds();
|
|
assert
|
|
bs.length == 1 :
|
|
"T should have one bound";
|
|
assert
|
|
bs[0] == Object.class :
|
|
"The bound of T should be Object";
|
|
|
|
Type[] et_con = con.getGenericExceptionTypes();
|
|
assert
|
|
et_con.length == 0 :
|
|
"Constructor C1(T) should have no generic exception types";
|
|
|
|
TypeVariable[] tv_con = con.getTypeParameters();
|
|
assert
|
|
tv_con.length == 0 :
|
|
"Constructor C1(T) should have no type parameters";
|
|
|
|
}
|
|
}
|