blob: be465b610702ece12fb58444ea2bc293178e8d30 [file] [log] [blame]
/*
* 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.
*/
package nsk.jdi.ObjectReference.invokeMethod;
import nsk.share.*;
import nsk.share.jpda.*;
import nsk.share.jdi.*;
// THIS TEST IS LINE NUMBER SENSITIVE
/**
* This is a debuggee class.
*/
public class invokemethod003t {
public static void main(String args[]) {
System.exit(run(args) + Consts.JCK_STATUS_BASE);
}
public static int run(String args[]) {
return new invokemethod003t().runIt(args);
}
private int runIt(String args[]) {
ArgumentHandler argHandler = new ArgumentHandler(args);
IOPipe pipe = argHandler.createDebugeeIOPipe();
invokemethod003tDummyClass invokemethod003tdummyCls = new invokemethod003tDummyClass();
Thread.currentThread().setName(invokemethod003.DEBUGGEE_THRNAME);
pipe.println(invokemethod003.COMMAND_READY);
String cmd = pipe.readln();
if (cmd.equals(invokemethod003.COMMAND_QUIT)) {
System.err.println("Debuggee: exiting due to the command "
+ cmd);
return Consts.TEST_PASSED;
}
int stopMeHere = 0; // invokemethod003.DEBUGGEE_STOPATLINE
cmd = pipe.readln();
if (!cmd.equals(invokemethod003.COMMAND_QUIT)) {
System.err.println("TEST BUG: unknown debugger command: "
+ cmd);
System.exit(Consts.JCK_STATUS_BASE +
Consts.TEST_FAILED);
}
return Consts.TEST_PASSED;
}
}
// Dummy interface & abstract class used to provoke
// IllegalArgumentException in the debugger
interface invokemethod003tDummyInterface {
byte byteMeth();
short shortMeth();
int intMeth();
long longMeth();
float floatMeth();
double doubleMeth();
char charMeth();
boolean booleanMeth();
String strMeth();
void voidMeth();
}
abstract class invokemethod003tDummyAbstractCls {
abstract byte absByteMeth();
abstract short absShortMeth();
abstract int absIntMeth();
abstract long absLongMeth();
abstract float absFloatMeth();
abstract double absDoubleMeth();
abstract char absCharMeth();
abstract boolean absBooleanMeth();
abstract String absStrMeth();
abstract void absVoidMeth();
}
class invokemethod003tDummyClass extends invokemethod003tDummyAbstractCls implements invokemethod003tDummyInterface {
public byte byteMeth() {
return 127;
}
public short shortMeth() {
return -32768;
}
public int intMeth() {
return 2147483647;
}
public long longMeth() {
return 9223372036854775807L;
}
public float floatMeth() {
return 5.1F;
}
public double doubleMeth() {
return 6.2D;
}
public char charMeth() {
return 'a';
}
public boolean booleanMeth() {
return false;
}
public String strMeth() {
return "string method";
}
public void voidMeth() {}
byte absByteMeth() {
return 127;
}
public short absShortMeth() {
return 32767;
}
public int absIntMeth() {
return 2147483647;
}
public long absLongMeth() {
return 9223372036854775807L;
}
public float absFloatMeth() {
return 5.1F;
}
public double absDoubleMeth() {
return 6.2D;
}
public char absCharMeth() {
return 'a';
}
public boolean absBooleanMeth() {
return true;
}
public String absStrMeth() {
return "string method";
}
public void absVoidMeth() {}
}