Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/vmTestbase/nsk/jdwp/ObjectReference/EnableCollection/enablecol001a.java
41161 views
1
/*
2
* Copyright (c) 2001, 2018, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
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
package nsk.jdwp.ObjectReference.EnableCollection;
25
26
import nsk.share.*;
27
import nsk.share.jpda.*;
28
import nsk.share.jdwp.*;
29
30
import java.io.*;
31
32
/**
33
* This class represents debuggee part in the test.
34
*/
35
public class enablecol001a {
36
37
// name for the tested thread
38
public static final String OBJECT_FIELD_NAME = "object";
39
40
public static void main(String args[]) {
41
enablecol001a _enablecol001a = new enablecol001a();
42
System.exit(enablecol001.JCK_STATUS_BASE + _enablecol001a.runIt(args, System.err));
43
}
44
45
public int runIt(String args[], PrintStream out) {
46
//make log for debugee messages
47
ArgumentHandler argumentHandler = new ArgumentHandler(args);
48
Log log = new Log(out, argumentHandler);
49
50
// make communication pipe to debugger
51
log.display("Creating pipe");
52
IOPipe pipe = argumentHandler.createDebugeeIOPipe(log);
53
54
// load tested class and create tested thread
55
log.display("Creating object of tested class");
56
TestedClass.object = new TestedClass();
57
58
// send debugger signal READY
59
log.display("Sending signal to debugger: " + enablecol001.READY);
60
pipe.println(enablecol001.READY);
61
62
// wait for signal QUIT from debugeer
63
log.display("Waiting for signal from debugger: " + enablecol001.QUIT);
64
String signal = pipe.readln();
65
log.display("Received signal from debugger: " + signal);
66
67
// check received signal
68
if (signal == null || !signal.equals(enablecol001.QUIT)) {
69
log.complain("Unexpected communication signal from debugee: " + signal
70
+ " (expected: " + enablecol001.QUIT + ")");
71
log.display("Debugee FAILED");
72
return enablecol001.FAILED;
73
}
74
75
// exit debugee
76
log.display("Debugee PASSED");
77
return enablecol001.PASSED;
78
}
79
80
// tested class
81
public static class TestedClass {
82
83
// static field with the tested object value
84
public static volatile TestedClass object = null;
85
86
private int foo = 0;
87
88
public TestedClass() {
89
foo = 100;
90
}
91
}
92
93
}
94
95