Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/vmTestbase/nsk/jdi/EventRequest/setEnabled/setenabled003a.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.jdi.EventRequest.setEnabled;
25
26
import nsk.share.*;
27
import nsk.share.jpda.*;
28
import nsk.share.jdi.*;
29
30
/**
31
* This class is used as debuggee application for the setenabled003 JDI test.
32
*/
33
34
public class setenabled003a {
35
36
//----------------------------------------------------- templete section
37
38
static final int PASSED = 0;
39
static final int FAILED = 2;
40
static final int PASS_BASE = 95;
41
42
static ArgumentHandler argHandler;
43
static Log log;
44
45
//-------------------------------------------------- log procedures
46
47
public static void log1(String message) {
48
log.display("**> debuggee: " + message);
49
}
50
51
private static void logErr(String message) {
52
log.complain("**> debuggee: " + message);
53
}
54
55
//====================================================== test program
56
57
static Thread1setenabled003a thread1 = null;
58
59
//------------------------------------------------------ common section
60
61
static int exitCode = PASSED;
62
63
static int instruction = 1;
64
static int end = 0;
65
// static int quit = 0;
66
// static int continue = 2;
67
static int maxInstr = 1; // 2;
68
69
static int lineForComm = 2;
70
71
private static void methodForCommunication() {
72
int i1 = instruction;
73
int i2 = i1;
74
int i3 = i2;
75
}
76
//---------------------------------------------------- main method
77
78
public static void main (String argv[]) {
79
80
argHandler = new ArgumentHandler(argv);
81
log = argHandler.createDebugeeLog();
82
83
log1("debuggee started!");
84
85
label0:
86
for (int i = 0; ; i++) {
87
88
if (instruction > maxInstr) {
89
logErr("ERROR: unexpected instruction: " + instruction);
90
exitCode = FAILED;
91
break ;
92
}
93
94
switch (i) {
95
96
//------------------------------------------------------ section tested
97
98
case 0:
99
thread1 = new Thread1setenabled003a("thread1");
100
Thread1setenabled003a.method();
101
break;
102
103
case 1:
104
synchronized (lockObj) {
105
threadStart(thread1);
106
log1("methodForCommunication();----");
107
methodForCommunication();
108
}
109
// case 2:
110
try {
111
thread1.join();
112
log1("methodForCommunication();----2");
113
methodForCommunication();
114
} catch ( InterruptedException e ) {
115
}
116
i++;
117
118
119
//------------------------------------------------- standard end section
120
121
default:
122
instruction = end;
123
break;
124
}
125
126
log1("methodForCommunication();");
127
methodForCommunication();
128
if (instruction == end)
129
break;
130
131
}
132
133
log1("debuggee exits");
134
System.exit(exitCode + PASS_BASE);
135
}
136
137
static Object lockObj = new Object();
138
static Object waitnotifyObj = new Object();
139
140
static int threadStart(Thread t) {
141
synchronized (waitnotifyObj) {
142
t.start();
143
try {
144
waitnotifyObj.wait();
145
} catch ( Exception e) {
146
exitCode = FAILED;
147
logErr(" Exception : " + e );
148
return FAILED;
149
}
150
}
151
return PASSED;
152
}
153
}
154
155
class Thread1setenabled003a extends Thread {
156
157
String tName = null;
158
159
public Thread1setenabled003a(String threadName) {
160
super(threadName);
161
tName = threadName;
162
}
163
164
public void run() {
165
setenabled003a.log1(" 'run': enter :: threadName == " + tName);
166
synchronized(setenabled003a.waitnotifyObj) {
167
setenabled003a.waitnotifyObj.notify();
168
}
169
170
synchronized(setenabled003a.lockObj) {
171
setenabled003a.log1(" 'run': exit :: threadName == " + tName);
172
}
173
return;
174
}
175
176
static void method() {
177
setenabled003a.log1(" enetred: method");
178
}
179
180
}
181
182