Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openjdk-multiarch-jdk8u
Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/test/java/awt/Frame/MaximizedToIconified/MaximizedToIconified.java
38828 views
1
/*
2
* Copyright (c) 2007, 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
/*
25
@test
26
@bug 4977491
27
@summary State changes should always be reported as events
28
@author anthony.petrov@...: area=awt.toplevel
29
@library ../../regtesthelpers
30
@build Util
31
@run main MaximizedToIconified
32
*/
33
34
/**
35
* MaximizedToIconified.java
36
*
37
* summary: Invoking setExtendedState(ICONIFIED) on a maximized
38
* frame should not combine the maximized and iconified
39
* states in the newState of the state change event.
40
*/
41
42
import java.awt.*;
43
import java.awt.event.*;
44
import java.util.*;
45
import test.java.awt.regtesthelpers.Util;
46
47
48
public class MaximizedToIconified
49
{
50
static volatile int lastFrameState = Frame.NORMAL;
51
static volatile boolean failed = false;
52
static volatile Toolkit myKit;
53
54
private static void checkState(Frame f, int state) {
55
f.setExtendedState(state);
56
Util.waitForIdle(null);
57
58
System.out.println("state = " + state + "; getExtendedState() = " + f.getExtendedState());
59
60
if (failed) {
61
MaximizedToIconified.fail("getOldState() != previous getNewState() in WINDOW_STATE_CHANGED event.");
62
}
63
if (lastFrameState != f.getExtendedState()) {
64
MaximizedToIconified.fail("getExtendedState() != last getNewState() in WINDOW_STATE_CHANGED event.");
65
}
66
if (f.getExtendedState() != state) {
67
MaximizedToIconified.fail("getExtendedState() != " + state + " as expected.");
68
}
69
// Plain return means the check passed
70
}
71
72
private static void examineStates(Frame f_arg, int states[]) {
73
Frame f = f_arg;
74
75
if (f == null) {
76
f = new Frame("test");
77
f.setSize(200, 200);
78
f.setVisible(true);
79
}
80
81
Util.waitForIdle(null);
82
83
f.addWindowStateListener(new WindowStateListener() {
84
public void windowStateChanged(WindowEvent e) {
85
System.out.println("last = " + lastFrameState + "; getOldState() = " + e.getOldState() + "; getNewState() = " + e.getNewState());
86
if (e.getOldState() == lastFrameState) {
87
lastFrameState = e.getNewState();
88
} else {
89
System.out.println("Wrong getOldState(): expected = " + lastFrameState + "; received = " + e.getOldState());
90
failed = true;
91
}
92
}
93
});
94
95
for (int state: states) {
96
if (myKit.isFrameStateSupported(state)) {
97
checkState(f, state);
98
} else {
99
System.out.println("Frame state = " + state + " is NOT supported by the native system. The state is skipped.");
100
}
101
}
102
103
if (f_arg == null) {
104
f.dispose();
105
}
106
}
107
108
private static void init()
109
{
110
String[] instructions =
111
{
112
"This is an AUTOMATIC test, simply wait until it is done.",
113
"The result (passed or failed) will be shown in the",
114
"message window below."
115
};
116
Sysout.createDialog( );
117
Sysout.printInstructions( instructions );
118
119
myKit = Toolkit.getDefaultToolkit();
120
121
// NOTE! Compound states (like MAXIMIZED_BOTH | ICONIFIED) CANNOT be used,
122
// because Toolkit.isFrameStateSupported() method reports these states
123
// as not supported. And such states will simply be skipped.
124
examineStates(null, new int[] {Frame.MAXIMIZED_BOTH, Frame.ICONIFIED, Frame.NORMAL});
125
examineStates(null, new int[] {Frame.ICONIFIED, Frame.MAXIMIZED_BOTH, Frame.NORMAL});
126
127
128
MaximizedToIconified.pass();
129
130
}//End init()
131
132
133
134
/*****************************************************
135
* Standard Test Machinery Section
136
* DO NOT modify anything in this section -- it's a
137
* standard chunk of code which has all of the
138
* synchronisation necessary for the test harness.
139
* By keeping it the same in all tests, it is easier
140
* to read and understand someone else's test, as
141
* well as insuring that all tests behave correctly
142
* with the test harness.
143
* There is a section following this for test-
144
* classes
145
******************************************************/
146
private static boolean theTestPassed = false;
147
private static boolean testGeneratedInterrupt = false;
148
private static String failureMessage = "";
149
150
private static Thread mainThread = null;
151
152
private static int sleepTime = 300000;
153
154
// Not sure about what happens if multiple of this test are
155
// instantiated in the same VM. Being static (and using
156
// static vars), it aint gonna work. Not worrying about
157
// it for now.
158
public static void main( String args[] ) throws InterruptedException
159
{
160
mainThread = Thread.currentThread();
161
try
162
{
163
init();
164
}
165
catch( TestPassedException e )
166
{
167
//The test passed, so just return from main and harness will
168
// interepret this return as a pass
169
return;
170
}
171
//At this point, neither test pass nor test fail has been
172
// called -- either would have thrown an exception and ended the
173
// test, so we know we have multiple threads.
174
175
//Test involves other threads, so sleep and wait for them to
176
// called pass() or fail()
177
try
178
{
179
Thread.sleep( sleepTime );
180
//Timed out, so fail the test
181
throw new RuntimeException( "Timed out after " + sleepTime/1000 + " seconds" );
182
}
183
catch (InterruptedException e)
184
{
185
//The test harness may have interrupted the test. If so, rethrow the exception
186
// so that the harness gets it and deals with it.
187
if( ! testGeneratedInterrupt ) throw e;
188
189
//reset flag in case hit this code more than once for some reason (just safety)
190
testGeneratedInterrupt = false;
191
192
if ( theTestPassed == false )
193
{
194
throw new RuntimeException( failureMessage );
195
}
196
}
197
198
}//main
199
200
public static synchronized void setTimeoutTo( int seconds )
201
{
202
sleepTime = seconds * 1000;
203
}
204
205
public static synchronized void pass()
206
{
207
Sysout.println( "The test passed." );
208
Sysout.println( "The test is over, hit Ctl-C to stop Java VM" );
209
//first check if this is executing in main thread
210
if ( mainThread == Thread.currentThread() )
211
{
212
//Still in the main thread, so set the flag just for kicks,
213
// and throw a test passed exception which will be caught
214
// and end the test.
215
theTestPassed = true;
216
throw new TestPassedException();
217
}
218
theTestPassed = true;
219
testGeneratedInterrupt = true;
220
mainThread.interrupt();
221
}//pass()
222
223
public static synchronized void fail()
224
{
225
//test writer didn't specify why test failed, so give generic
226
fail( "it just plain failed! :-)" );
227
}
228
229
public static synchronized void fail( String whyFailed )
230
{
231
Sysout.println( "The test failed: " + whyFailed );
232
Sysout.println( "The test is over, hit Ctl-C to stop Java VM" );
233
//check if this called from main thread
234
if ( mainThread == Thread.currentThread() )
235
{
236
//If main thread, fail now 'cause not sleeping
237
throw new RuntimeException( whyFailed );
238
}
239
theTestPassed = false;
240
testGeneratedInterrupt = true;
241
failureMessage = whyFailed;
242
mainThread.interrupt();
243
}//fail()
244
245
}// class MaximizedToIconified
246
247
//This exception is used to exit from any level of call nesting
248
// when it's determined that the test has passed, and immediately
249
// end the test.
250
class TestPassedException extends RuntimeException
251
{
252
}
253
254
//*********** End Standard Test Machinery Section **********
255
256
257
//************ Begin classes defined for the test ****************
258
259
// if want to make listeners, here is the recommended place for them, then instantiate
260
// them in init()
261
262
/* Example of a class which may be written as part of a test
263
class NewClass implements anInterface
264
{
265
static int newVar = 0;
266
267
public void eventDispatched(AWTEvent e)
268
{
269
//Counting events to see if we get enough
270
eventCount++;
271
272
if( eventCount == 20 )
273
{
274
//got enough events, so pass
275
276
MaximizedToIconified.pass();
277
}
278
else if( tries == 20 )
279
{
280
//tried too many times without getting enough events so fail
281
282
MaximizedToIconified.fail();
283
}
284
285
}// eventDispatched()
286
287
}// NewClass class
288
289
*/
290
291
292
//************** End classes defined for the test *******************
293
294
295
296
297
/****************************************************
298
Standard Test Machinery
299
DO NOT modify anything below -- it's a standard
300
chunk of code whose purpose is to make user
301
interaction uniform, and thereby make it simpler
302
to read and understand someone else's test.
303
****************************************************/
304
305
/**
306
This is part of the standard test machinery.
307
It creates a dialog (with the instructions), and is the interface
308
for sending text messages to the user.
309
To print the instructions, send an array of strings to Sysout.createDialog
310
WithInstructions method. Put one line of instructions per array entry.
311
To display a message for the tester to see, simply call Sysout.println
312
with the string to be displayed.
313
This mimics System.out.println but works within the test harness as well
314
as standalone.
315
*/
316
317
class Sysout
318
{
319
private static TestDialog dialog;
320
321
public static void createDialogWithInstructions( String[] instructions )
322
{
323
dialog = new TestDialog( new Frame(), "Instructions" );
324
dialog.printInstructions( instructions );
325
dialog.setVisible(true);
326
println( "Any messages for the tester will display here." );
327
}
328
329
public static void createDialog( )
330
{
331
dialog = new TestDialog( new Frame(), "Instructions" );
332
String[] defInstr = { "Instructions will appear here. ", "" } ;
333
dialog.printInstructions( defInstr );
334
dialog.setVisible(true);
335
println( "Any messages for the tester will display here." );
336
}
337
338
339
public static void printInstructions( String[] instructions )
340
{
341
dialog.printInstructions( instructions );
342
}
343
344
345
public static void println( String messageIn )
346
{
347
dialog.displayMessage( messageIn );
348
System.out.println(messageIn);
349
}
350
351
}// Sysout class
352
353
/**
354
This is part of the standard test machinery. It provides a place for the
355
test instructions to be displayed, and a place for interactive messages
356
to the user to be displayed.
357
To have the test instructions displayed, see Sysout.
358
To have a message to the user be displayed, see Sysout.
359
Do not call anything in this dialog directly.
360
*/
361
class TestDialog extends Dialog
362
{
363
364
TextArea instructionsText;
365
TextArea messageText;
366
int maxStringLength = 80;
367
368
//DO NOT call this directly, go through Sysout
369
public TestDialog( Frame frame, String name )
370
{
371
super( frame, name );
372
int scrollBoth = TextArea.SCROLLBARS_BOTH;
373
instructionsText = new TextArea( "", 15, maxStringLength, scrollBoth );
374
add( "North", instructionsText );
375
376
messageText = new TextArea( "", 5, maxStringLength, scrollBoth );
377
add("Center", messageText);
378
379
pack();
380
381
setVisible(true);
382
}// TestDialog()
383
384
//DO NOT call this directly, go through Sysout
385
public void printInstructions( String[] instructions )
386
{
387
//Clear out any current instructions
388
instructionsText.setText( "" );
389
390
//Go down array of instruction strings
391
392
String printStr, remainingStr;
393
for( int i=0; i < instructions.length; i++ )
394
{
395
//chop up each into pieces maxSringLength long
396
remainingStr = instructions[ i ];
397
while( remainingStr.length() > 0 )
398
{
399
//if longer than max then chop off first max chars to print
400
if( remainingStr.length() >= maxStringLength )
401
{
402
//Try to chop on a word boundary
403
int posOfSpace = remainingStr.
404
lastIndexOf( ' ', maxStringLength - 1 );
405
406
if( posOfSpace <= 0 ) posOfSpace = maxStringLength - 1;
407
408
printStr = remainingStr.substring( 0, posOfSpace + 1 );
409
remainingStr = remainingStr.substring( posOfSpace + 1 );
410
}
411
//else just print
412
else
413
{
414
printStr = remainingStr;
415
remainingStr = "";
416
}
417
418
instructionsText.append( printStr + "\n" );
419
420
}// while
421
422
}// for
423
424
}//printInstructions()
425
426
//DO NOT call this directly, go through Sysout
427
public void displayMessage( String messageIn )
428
{
429
messageText.append( messageIn + "\n" );
430
System.out.println(messageIn);
431
}
432
433
}// TestDialog class
434
435