jdk-24/test/jdk/com/sun/jdi/EvalArgs.java

291 lines
10 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2002, 2018, 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 4663146
* @summary Arguments match no method error
* @comment converted from test/jdk/com/sun/jdi/EvalArgs.sh
*
* @library /test/lib
* @build EvalArgs
* @run main/othervm EvalArgs
*/
import lib.jdb.JdbCommand;
import lib.jdb.JdbTest;
/*
* The bug is that, for example, if a String is passed
* as an arg to a func where an Object is expected,
* "Arguments match no method" error occurs. jdb doesn't notice that this is
* legal because String is an instance of Object.
*/
class EvalArgsTarg {
static jj1 myjj1;
static jj2 myjj2;
static oranges myoranges;
static boolean jjboolean = true;
static byte jjbyte = 1;
static char jjchar = 'a';
static double jjdouble = 2.2;
static float jjfloat = 3.1f;
static int jjint = 4;
static long jjlong = 5;
static short jjshort = 6;
static int[] jjintArray = {7, 8};
static float[] jjfloatArray = {9.1f, 10.2f};
public static void main(String args[]) {
myjj1 = new jj1();
myjj2 = new jj2();
myoranges = new oranges();
// prove that these work
System.out.println( ffjj1(myjj1));
System.out.println( ffjj1(myjj2));
System.out.println("EvalArgsTarg.ffoverload(EvalArgsTarg.jjboolean) = " +
EvalArgsTarg.ffoverload(EvalArgsTarg.jjboolean));
System.out.println("EvalArgsTarg.ffoverload(EvalArgsTarg.jjbyte) = " +
EvalArgsTarg.ffoverload(EvalArgsTarg.jjbyte));
System.out.println("EvalArgsTarg.ffoverload(EvalArgsTarg.jjchar) = " +
EvalArgsTarg.ffoverload(EvalArgsTarg.jjchar));
System.out.println("EvalArgsTarg.ffoverload(EvalArgsTarg.jjdouble) = " +
EvalArgsTarg.ffoverload(EvalArgsTarg.jjdouble));
//This doesn't even compile
//System.out.println( "ffintArray(jjfloatArray) = " + ffintArray(jjfloatArray));
gus();
}
static void gus() {
int x = 0; // @1 breakpoint
}
public static String ffjj1(jj1 arg) {
return arg.me;
}
public static String ffjj2(jj2 arg) {
return arg.me;
}
static String ffboolean(boolean p1) {
return "ffbool: p1 = " + p1;
}
static String ffbyte(byte p1) {
return "ffbyte: p1 = " + p1;
}
static String ffchar(char p1) {
return "ffchar: p1 = " + p1;
}
static String ffdouble(double p1) {
return "ffdouble: p1 = " + p1;
}
static String fffloat(float p1) {
return "fffloat: p1 = " + p1;
}
static String ffint(int p1) {
return "ffint: p1 = " + p1;
}
static String fflong(long p1) {
return "fflong: p1 = " + p1;
}
static String ffshort(short p1) {
return "ffshort: p1 = " + p1;
}
static String ffintArray(int[] p1) {
return "ffintArray: p1 = " + p1;
}
// Overloaded funcs
public static String ffoverload(jj1 arg) {
return arg.me;
}
static String ffoverload(boolean p1) {
return "ffoverload: boolean p1 = " + p1;
}
/***
static String ffoverload(byte p1) {
return "ffoverload: byte p1 = " + p1;
}
***/
static String ffoverload(char p1) {
return "ffoverload: char p1 = " + p1;
}
static String ffoverload(double p1) {
return "ffoverload: double p1 = " + p1;
}
static String ffoverload(float p1) {
return "ffoverload: float p1 = " + p1;
}
/***
static String ffoverload(int p1) {
return "ffoverload: int p1 = " + p1;
}
***/
static String ffoverload(long p1) {
return "ffoverload: long p1 = " + p1;
}
static String ffoverload(short p1) {
return "ffoverload: short p1 = " + p1;
}
static String ffoverload(int[] p1) {
return "ffoverload: int array p1 = " + p1;
}
static class jj1 {
String me;
jj1() {
me = "jj1name";
}
public String toString() {
return me;
}
}
static class jj2 extends jj1 {
jj2() {
super();
me = "jj2name";
}
}
static class oranges {
oranges() {
}
}
}
public class EvalArgs extends JdbTest {
public static void main(String argv[]) {
new EvalArgs().run();
}
private EvalArgs() {
super(DEBUGGEE_CLASS);
}
private static final String DEBUGGEE_CLASS = EvalArgsTarg.class.getName();
@Override
protected void runCases() {
setBreakpointsFromTestSource("EvalArgs.java", 1);
// Run to breakpoint #1
jdb.command(JdbCommand.run());
final String argsMatchNoMethod = "Arguments match no method";
// verify that it works ok when arg types are the same as
// the param types
evalShouldNotContain("EvalArgsTarg.ffboolean(EvalArgsTarg.jjboolean)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffbyte(EvalArgsTarg.jjbyte)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffchar(EvalArgsTarg.jjchar)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffdouble(EvalArgsTarg.jjdouble)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.fffloat(EvalArgsTarg.jjfloat)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffint(EvalArgsTarg.jjint)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.fflong(EvalArgsTarg.jjlong)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffshort(EvalArgsTarg.jjshort)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffintArray(EvalArgsTarg.jjintArray)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffjj1(EvalArgsTarg.myjj1)", argsMatchNoMethod);
// Provide a visual break in the output
jdb.command(JdbCommand.print("1"));
// Verify mixing primitive types works ok
// These should work even though the arg types are
// not the same because there is only one
// method with each name.
evalShouldNotContain("EvalArgsTarg.ffbyte(EvalArgsTarg.jjint)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffchar(EvalArgsTarg.jjdouble)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffdouble(EvalArgsTarg.jjfloat)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.fffloat(EvalArgsTarg.jjshort)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffint(EvalArgsTarg.jjlong)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.fflong(EvalArgsTarg.jjchar)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffshort(EvalArgsTarg.jjbyte)", argsMatchNoMethod);
jdb.command(JdbCommand.print("1"));
// Verify that passing a subclass object works
evalShouldNotContain("EvalArgsTarg.ffjj1(EvalArgsTarg.myjj2)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.myjj1.toString().equals(\"jj1name\")", argsMatchNoMethod);
jdb.command(JdbCommand.print("1"));
// Overloaded methods. These should pass
// because there is an exact match.
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjboolean)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjchar)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjdouble)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjfloat)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjlong)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjshort)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjintArray)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.myjj1)", argsMatchNoMethod);
evalShouldNotContain("EvalArgsTarg.ffoverload(EvalArgsTarg.myjj2)", argsMatchNoMethod);
jdb.command(JdbCommand.print("1"));
jdb.command(JdbCommand.print("\"These should fail with msg Arguments match multiple methods\""));
// These overload calls should fail because there
// isn't an exact match and jdb isn't smart enough
// to figure out which of several possibilities
// should be called
final String argsMatchMultipleMethods = "Arguments match multiple methods";
evalShouldContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjbyte)", argsMatchMultipleMethods);
evalShouldContain("EvalArgsTarg.ffoverload(EvalArgsTarg.jjint)", argsMatchMultipleMethods);
jdb.command(JdbCommand.print("1"));
jdb.command(JdbCommand.print("\"These should fail with InvalidTypeExceptions\""));
final String invalidTypeException = "InvalidTypeException";
evalShouldContain("EvalArgsTarg.ffboolean(EvalArgsTarg.jjbyte)", invalidTypeException);
evalShouldContain("EvalArgsTarg.ffintArray(EvalArgsTarg.jjint)", invalidTypeException);
evalShouldContain("EvalArgsTarg.ffintArray(EvalArgsTarg.jjfloatArray)", invalidTypeException);
evalShouldContain("EvalArgsTarg.ffjj2(EvalArgsTarg.myjj1)", invalidTypeException);
evalShouldContain("EvalArgsTarg.ffjj2(EvalArgsTarg.myoranges)", invalidTypeException);
jdb.contToExit(1);
}
}