6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 24 /* 25 * @test 26 * @summary javac should generate method parameters correctly. 27 */ 28 29 import java.lang.*; 30 import java.lang.reflect.*; 31 import java.util.List; 32 33 public class WithoutParameters { 34 35 private static final Class<?>[] qux_types = { 36 int.class, 37 Foo.class, 38 List.class, 39 List.class, 40 List.class, 41 String[].class 42 }; 43 44 public static void main(String argv[]) throws Exception { 45 int error = 0; 46 Method[] methods = Foo.class.getMethods(); 47 for(Method m : methods) { 48 System.err.println("Inspecting method " + m); 49 Parameter[] parameters = m.getParameters(); 50 if(parameters == null) 51 throw new Exception("getParameters should never be null"); 52 for(int i = 0; i < parameters.length; i++) { 53 Parameter p = parameters[i]; 54 if(!p.getDeclaringExecutable().equals(m)) { 55 System.err.println(p + ".getDeclaringExecutable != " + m); 56 error++; 57 } 58 if(null == p.getType()) { 59 System.err.println(p + ".getType() == null"); 60 error++; 61 } 62 if(null == p.getParameterizedType()) { 63 System.err.println(p + ".getParameterizedType == null"); 64 error++; 65 } 66 } 67 if(m.getName().equals("qux")) { 68 if(6 != parameters.length) { 69 System.err.println("Wrong number of parameters for qux"); 70 error++; 71 } 72 for(int i = 0; i < parameters.length; i++) { 73 Parameter p = parameters[i]; 74 // The getType family work with or without 75 // parameter attributes compiled in. 76 if(!parameters[i].getType().equals(qux_types[i])) { 77 System.err.println("Wrong parameter type for " + parameters[0] + ": expected " + qux_types[i] + ", but got " + parameters[i].getType()); 78 error++; 79 } 80 } 81 if(!parameters[0].getParameterizedType().equals(int.class)) { 82 System.err.println("getParameterizedType for quux is wrong"); 83 error++; 84 } 85 if(!parameters[1].getParameterizedType().equals(Foo.class)) { 86 System.err.println("getParameterizedType for quux is wrong"); 87 error++; 88 } 89 if(!(parameters[2].getParameterizedType() instanceof 90 ParameterizedType)) { 91 System.err.println("getParameterizedType for l is wrong"); 92 error++; 93 } else { 94 ParameterizedType pt = 95 (ParameterizedType) parameters[2].getParameterizedType(); 96 if(!pt.getRawType().equals(List.class)) { 97 System.err.println("Raw type for l is wrong"); 98 error++; 99 } 100 if(1 != pt.getActualTypeArguments().length) { 101 System.err.println("Number of type parameters for l is wrong"); 102 error++; 103 } 104 if(!(pt.getActualTypeArguments()[0] instanceof WildcardType)) { 105 System.err.println("Type parameter for l is wrong"); 106 error++; 107 } 108 } 109 if(!(parameters[3].getParameterizedType() instanceof 110 ParameterizedType)) { 111 System.err.println("getParameterizedType for l2 is wrong"); 112 error++; 113 } else { 114 ParameterizedType pt = 115 (ParameterizedType) parameters[3].getParameterizedType(); 116 if(!pt.getRawType().equals(List.class)) { 117 System.err.println("Raw type for l2 is wrong"); 118 error++; 119 } 120 if(1 != pt.getActualTypeArguments().length) { 121 System.err.println("Number of type parameters for l2 is wrong"); 122 error++; 123 } 124 if(!(pt.getActualTypeArguments()[0].equals(Foo.class))) { 125 System.err.println("Type parameter for l2 is wrong"); 126 error++; 127 } 128 } 129 if(!(parameters[4].getParameterizedType() instanceof 130 ParameterizedType)) { 131 System.err.println("getParameterizedType for l3 is wrong"); 132 error++; 133 } else { 134 ParameterizedType pt = 135 (ParameterizedType) parameters[4].getParameterizedType(); 136 if(!pt.getRawType().equals(List.class)) { 137 System.err.println("Raw type for l3 is wrong"); 138 error++; 139 } 140 if(1 != pt.getActualTypeArguments().length) { 141 System.err.println("Number of type parameters for l3 is wrong"); 142 error++; 143 } 144 if(!(pt.getActualTypeArguments()[0] instanceof WildcardType)) { 145 System.err.println("Type parameter for l3 is wrong"); 146 error++; 147 } else { 148 WildcardType wt = (WildcardType) 149 pt.getActualTypeArguments()[0]; 150 if(!wt.getUpperBounds()[0].equals(Foo.class)) { 151 System.err.println("Upper bounds on type parameter fol l3 is wrong"); 152 error++; 153 } 154 } 155 } 156 if(!parameters[5].isVarArgs()) { 157 System.err.println("isVarArg for rest is wrong"); 158 error++; 159 } 160 if(!(parameters[5].getParameterizedType().equals(String[].class))) { 161 System.err.println("getParameterizedType for rest is wrong"); 162 error++; 163 } 164 165 } 166 } 167 if(0 != error) 168 throw new Exception("Failed " + error + " tests"); 169 } 170 171 public class Foo { 172 int thing; 173 public void qux(int quux, Foo quuux, 174 List<?> l, List<Foo> l2, 175 List<? extends Foo> l3, 176 String... rest) {} 177 public class Inner { 178 int thang; 179 public Inner(int theng) { 180 thang = theng + thing; 181 } 182 } 183 } 184 185 } | 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 24 /* 25 * @test 26 * @bug 8004729 27 * @summary javac should generate method parameters correctly. 28 */ 29 30 import java.lang.*; 31 import java.lang.reflect.*; 32 import java.lang.annotation.*; 33 import java.util.List; 34 import java.util.Objects; 35 36 import static java.lang.annotation.ElementType.*; 37 38 public class WithoutParameters { 39 int errors = 0; 40 41 private WithoutParameters() {} 42 43 public static void main(String argv[]) throws Exception { 44 WithoutParameters wp = new WithoutParameters(); 45 wp.runTests(Foo.class.getMethods()); 46 wp.runTests(Foo.Inner.class.getConstructors()); 47 wp.checkForErrors(); 48 } 49 50 void runTests(Method[] methods) throws Exception { 51 for(Method m : methods) {runTest(m);} 52 } 53 54 void runTests(Constructor[] constructors) throws Exception { 55 for(Constructor c : constructors) {runTest(c);} 56 } 57 58 void runTest(Executable e) throws Exception { 59 System.err.println("Inspecting executable " + e); 60 Parameter[] parameters = e.getParameters(); 61 Objects.requireNonNull(parameters, "getParameters should never be null"); 62 63 ExpectedParameterInfo epi = e.getAnnotation(ExpectedParameterInfo.class); 64 if (epi != null) { 65 abortIfTrue(epi.parameterCount() != e.getParameterCount(), "Bad parameter count for "+ e); 66 abortIfTrue(epi.isVarArgs() != e.isVarArgs(),"Bad varargs value for "+ e); 67 } 68 abortIfTrue(e.getParameterCount() != parameters.length, "Mismatched of parameter counts."); 69 70 for(int i = 0; i < parameters.length; i++) { 71 Parameter p = parameters[i]; 72 errorIfTrue(!p.getDeclaringExecutable().equals(e), p + ".getDeclaringExecutable != " + e); 73 Objects.requireNonNull(p.getType(), "getType() should not be null"); 74 Objects.requireNonNull(p.getParameterizedType(), "getParameterizedType() should not be null"); 75 76 if (epi != null) { 77 Class<?> expectedParameterType = epi.parameterTypes()[i]; 78 errorIfTrue(!p.getType().equals(expectedParameterType), 79 "Wrong parameter type for " + p + ": expected " + expectedParameterType + 80 ", but got " + p.getType()); 81 82 ParameterizedInfo[] expectedParameterizedTypes = epi.parameterizedTypes(); 83 if (expectedParameterizedTypes.length > 0) { 84 Type parameterizedType = p.getParameterizedType(); 85 Class<? extends Type> expectedParameterziedTypeType = expectedParameterizedTypes[i].value(); 86 errorIfTrue(!expectedParameterziedTypeType.isAssignableFrom(parameterizedType.getClass()), 87 "Wrong class of parameteried type of " + p + ": expected " + expectedParameterziedTypeType + 88 ", but got " + parameterizedType.getClass()); 89 90 if (expectedParameterziedTypeType.equals(Class.class)) { 91 errorIfTrue(!parameterizedType.equals(expectedParameterType), 92 "Wrong parameteried type for " + p + ": expected " + expectedParameterType + 93 ", but got " + parameterizedType); 94 } else { 95 if (expectedParameterziedTypeType.equals(ParameterizedType.class)) { 96 ParameterizedType ptype = (ParameterizedType)parameterizedType; 97 errorIfTrue(!ptype.getRawType().equals(expectedParameterType), 98 "Wrong raw type for " + p + ": expected " + expectedParameterType + 99 ", but got " + ptype.getRawType()); 100 } 101 102 // Check string representation 103 String expectedStringOfType = epi.parameterizedTypes()[i].string(); 104 errorIfTrue(!expectedStringOfType.equals(parameterizedType.toString()), 105 "Bad type string" + p + ": expected " + expectedStringOfType + 106 ", but got " + parameterizedType.toString()); 107 } 108 } 109 } 110 } 111 } 112 113 private void checkForErrors() { 114 if (errors > 0) 115 throw new RuntimeException("Failed " + errors + " tests"); 116 } 117 118 private void errorIfTrue(boolean predicate, String errMessage) { 119 if (predicate) { 120 errors++; 121 System.err.println(errMessage); 122 } 123 } 124 125 private void abortIfTrue(boolean predicate, String errMessage) { 126 if (predicate) { 127 throw new RuntimeException(errMessage); 128 } 129 } 130 131 @Retention(RetentionPolicy.RUNTIME) 132 @Target({METHOD, CONSTRUCTOR}) 133 @interface ExpectedParameterInfo { 134 int parameterCount() default 0; 135 Class<?>[] parameterTypes() default {}; 136 ParameterizedInfo[] parameterizedTypes() default {}; 137 boolean isVarArgs() default false; 138 } 139 140 @Target({}) 141 @interface ParameterizedInfo { 142 Class<? extends Type> value() default Class.class; 143 String string() default ""; 144 } 145 146 public class Foo { 147 int thing; 148 @ExpectedParameterInfo(parameterCount = 6, 149 parameterTypes = 150 {int.class, Foo.class, 151 List.class, List.class, 152 List.class, String[].class}, 153 parameterizedTypes = 154 {@ParameterizedInfo(Class.class), 155 @ParameterizedInfo(Class.class), 156 @ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<?>"), 157 @ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<WithoutParameters$Foo>"), 158 @ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<? extends WithoutParameters$Foo>"), 159 @ParameterizedInfo(Class.class)}, 160 isVarArgs = true) 161 public void qux(int quux, Foo quuux, 162 List<?> l, List<Foo> l2, 163 List<? extends Foo> l3, 164 String... rest) {} 165 public class Inner { 166 int thang; 167 @ExpectedParameterInfo(parameterCount = 2, 168 parameterTypes = {Foo.class, int.class}) 169 public Inner(int theng) { 170 thang = theng + thing; 171 } 172 } 173 } 174 } |