234 lines
9.2 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2000, 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.Field.equals;
import nsk.share.*;
import nsk.share.jpda.*;
import nsk.share.jdi.*;
import com.sun.jdi.*;
import java.util.*;
import java.io.*;
public class equals001 {
private static Log log;
private final static String prefix = "nsk.jdi.Field.equals.";
private final static String className = "equals001";
private final static String debugerName = prefix + className;
private final static String debugeeName = debugerName + "a";
private final static String classToCheckName = prefix + "ClassToCheck";
public static void main(String argv[]) {
System.exit(95 + run(argv, System.out));
}
public static int run(String argv[], PrintStream out) {
ArgumentHandler argHandler = new ArgumentHandler(argv);
log = new Log(out, argHandler);
Binder binder = new Binder(argHandler, log);
Debugee debugee = binder.bindToDebugee(debugeeName
+ (argHandler.verbose() ? " -verbose" : ""));
IOPipe pipe = new IOPipe(debugee);
boolean testFailed = false;
List fieldsDebugee;
List methods;
Iterator methodsIterator;
java.lang.reflect.Field[] fieldsDebuger;
ClassOfFields classOfFields = new ClassOfFields();
// Connect with debugee and resume it
debugee.redirectStderr(out);
debugee.resume();
String line = pipe.readln();
if (line == null) {
log.complain("debuger FAILURE> UNEXPECTED debugee's signal - null");
return 2;
}
if (!line.equals("ready")) {
log.complain("debuger FAILURE> UNEXPECTED debugee's signal - "
+ line);
return 2;
}
else {
log.display("debuger> debugee's \"ready\" signal recieved.");
}
// Get all fields from debugee
ReferenceType refType = debugee.classByName(classToCheckName);
if (refType == null) {
log.complain("debuger FAILURE> Class " + classToCheckName
+ " not found.");
return 2;
}
try {
fieldsDebugee = refType.allFields();
} catch (Exception e) {
log.complain("debuger FAILURE> Can't get fields from class");
log.complain("debuger FAILURE> Exception: " + e);
return 2;
}
int totalFields = fieldsDebugee.size();
if (totalFields < 1) {
log.complain("debuger FAILURE> Total number of fields read "
+ totalFields);
return 2;
}
log.display("debuger> Total fields found: " + totalFields);
// Compare each Field and Method from debugee
try {
methods = refType.allMethods();
} catch (Exception e) {
log.complain("debuger FAILURE 1> Can't get methods from class");
log.complain("debuger FAILURE 1> Exception: " + e);
return 2;
}
log.display("debuger> Total methods found: " + methods.size());
Iterator fieldsIterator = fieldsDebugee.iterator();
for (int i = 0; fieldsIterator.hasNext(); i++) {
Field fieldDebugee = (Field)fieldsIterator.next();
String name = fieldDebugee.name();
methodsIterator = methods.iterator();
for (int j = 0; methodsIterator.hasNext(); j++) {
Method method = (Method)methodsIterator.next();
String methodName = method.name();
log.display("debuger> Field " + name + " and method "
+ methodName + " read from debugee.");
if (fieldDebugee.equals(method)) {
// Field is not equal to any Object which type is not Field
log.complain("debuger FAILURE 2> Field " + name
+ " and method " + methodName + " are equal. "
+ "Expected result: not equal.");
testFailed = true;
continue;
}
}
}
// Compare Field (com.sun.jdi.Field) from debugee and Field
// from debuger (java.lang.reflect.Field)
Class classDebuger = classOfFields.getClass();
try {
fieldsDebuger = classDebuger.getDeclaredFields();
} catch (SecurityException e) {
log.complain("debuger FAILURE 3> Can't get fields from debuger's"
+ " class");
log.complain("debuger FAILURE 3> Exception: " + e);
return 2;
}
int totalDebugerFields = fieldsDebuger.length;
log.display("debuger> Total fields in debuger found: "
+ totalDebugerFields);
fieldsIterator = fieldsDebugee.iterator();
for (int i = 0; fieldsIterator.hasNext(); i++) {
Field fieldDebugee = (Field)fieldsIterator.next();
String name = fieldDebugee.name();
for (int j = 1; j < totalDebugerFields; j++) {
java.lang.reflect.Field fieldDebuger = fieldsDebuger[j];
String nameDebuger = fieldDebuger.getName();
log.display("debuger> Field from debugee " + name + " and "
+ "field from debuger " + nameDebuger + " read.");
if (fieldDebugee.equals(fieldDebuger)) {
// Field is not equal to any Object which type
// is not not com.sun.jdi.Field
log.complain("debuger FAILURE 4> Field from debugee "
+ name + " and field from debuger "
+ nameDebuger + " are equal. Expected "
+ "result: not equal.");
testFailed = true;
continue;
}
}
}
pipe.println("quit");
debugee.waitFor();
int status = debugee.getStatus();
if (testFailed) {
log.complain("debuger FAILURE> TEST FAILED");
return 2;
} else {
if (status == 95) {
log.display("debuger> expected Debugee's exit "
+ "status - " + status);
return 0;
} else {
log.complain("debuger FAILURE> UNEXPECTED Debugee's exit "
+ "status (not 95) - " + status);
return 2;
}
}
}
}
class ClassOfFields {
boolean z0, z1[]={z0}, z2[][]={z1};
byte b0, b1[]={b0}, b2[][]={b1};
char c0, c1[]={c0}, c2[][]={c1};
double d0, d1[]={d0}, d2[][]={d1};
float f0, f1[]={f0}, f2[][]={f1};
int i0, i1[]={i0}, i2[][]={i1};
long l0, l1[]={l0}, l2[][]={l1};
static long lS0, lS1[]={lS0}, lS2[][]={lS1};
private long lP0, lP1[]={lP0}, lP2[][]={lP1};
public long lU0, lU1[]={lU0}, lU2[][]={lU1};
protected long lR0, lR1[]={lR0}, lR2[][]={lR1};
transient long lT0, lT1[]={lT0}, lT2[][]={lT1};
volatile long lV0, lV1[]={lV0}, lV2[][]={lV1};
final long lF0 = 999, lF1[]={lF0}, lF2[][]={lF1};
Boolean Z0, Z1[]={Z0}, Z2[][]={Z1};
Byte B0, B1[]={B0}, B2[][]={B1};
Character C0, C1[]={C0}, C2[][]={C1};
Double D0, D1[]={D0}, D2[][]={D1};
Float F0, F1[]={F0}, F2[][]={F1};
Integer I0, I1[]={I0}, I2[][]={I1};
Long L0, L1[]={L0}, L2[][]={L1};
String S0, S1[]={S0}, S2[][]={S1};
Object O0, O1[]={O0}, O2[][]={O1};
static Long LS0, LS1[]={LS0}, LS2[][]={LS1};
private Long LP0, LP1[]={LP0}, LP2[][]={LP1};
public Long LU0, LU1[]={LU0}, LU2[][]={LU1};
protected Long LR0, LR1[]={LR0}, LR2[][]={LR1};
transient Long LT0, LT1[]={LT0}, LT2[][]={LT1};
volatile Long LV0, LV1[]={LV0}, LV2[][]={LV1};
final Long LF0 = new Long(999), LF1[]={LF0}, LF2[][]={LF1};
interface Inter {}
Inter E0, E1[]={E0}, E2[][]={E1};
static Inter ES0, ES1[]={ES0}, ES2[][]={ES1};
private Inter EP0, EP1[]={EP0}, EP2[][]={EP1};
public Inter EU0, EU1[]={EU0}, EU2[][]={EU1};
protected Inter ER0, ER1[]={ER0}, ER2[][]={ER1};
transient Inter ET0, ET1[]={ET0}, ET2[][]={ET1};
volatile Inter EV0, EV1[]={EV0}, EV2[][]={EV1};
final Inter EF0 = null, EF1[]={EF0}, EF2[][]={EF1};
}