82ed2a5fc0
Reviewed-by: serb
292 lines
10 KiB
Java
292 lines
10 KiB
Java
/*
|
|
* Copyright (c) 2007, 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.
|
|
*/
|
|
|
|
|
|
import java.awt.*;
|
|
import static jdk.test.lib.Asserts.*;
|
|
|
|
|
|
// FDF: Frame->Dialog->Frame
|
|
|
|
public class ToBackFDFTest {
|
|
|
|
private volatile CustomDialog dialog;
|
|
private volatile TestFrame leftFrame, rightFrame;
|
|
|
|
private static final int delay = 500;
|
|
private final ExtendedRobot robot;
|
|
|
|
private Dialog hiddenDialog;
|
|
private Frame hiddenFrame;
|
|
|
|
public enum DialogOwner {HIDDEN_DIALOG, NULL_DIALOG, HIDDEN_FRAME, NULL_FRAME, FRAME};
|
|
|
|
private DialogOwner owner;
|
|
private volatile boolean setModal;
|
|
|
|
private Dialog.ModalityType modalityType;
|
|
|
|
private ToBackFDFTest(Dialog.ModalityType modType,
|
|
boolean modal,
|
|
DialogOwner o) throws Exception {
|
|
modalityType = modType;
|
|
setModal = modal;
|
|
owner = o;
|
|
|
|
robot = new ExtendedRobot();
|
|
EventQueue.invokeLater(this::createGUI);
|
|
}
|
|
|
|
public ToBackFDFTest(Dialog.ModalityType modalityType,
|
|
DialogOwner o) throws Exception {
|
|
this(modalityType, false, o);
|
|
}
|
|
|
|
public ToBackFDFTest(boolean modal, DialogOwner o) throws Exception {
|
|
this(null, modal, o);
|
|
}
|
|
|
|
private void createGUI() {
|
|
|
|
leftFrame = new TestFrame();
|
|
leftFrame.setLocation(50, 50);
|
|
leftFrame.setBackground(Color.BLUE);
|
|
leftFrame.setVisible(true);
|
|
|
|
switch (owner) {
|
|
case HIDDEN_DIALOG:
|
|
hiddenDialog = new Dialog((Frame) null);
|
|
dialog = new CustomDialog(hiddenDialog);
|
|
break;
|
|
case NULL_DIALOG:
|
|
dialog = new CustomDialog((Dialog) null);
|
|
break;
|
|
case HIDDEN_FRAME:
|
|
hiddenFrame = new Frame();
|
|
dialog = new CustomDialog(hiddenFrame);
|
|
break;
|
|
case NULL_FRAME:
|
|
dialog = new CustomDialog((Frame) null);
|
|
break;
|
|
case FRAME:
|
|
dialog = new CustomDialog(leftFrame);
|
|
break;
|
|
}
|
|
|
|
if (modalityType == null) {
|
|
dialog.setModal(setModal);
|
|
modalityType = dialog.getModalityType();
|
|
} else if (modalityType != null) {
|
|
dialog.setModalityType(modalityType);
|
|
}
|
|
|
|
dialog.setBackground(Color.WHITE);
|
|
dialog.setLocation(150, 50);
|
|
|
|
rightFrame = new TestFrame();
|
|
rightFrame.setLocation(250, 50);
|
|
rightFrame.setBackground(Color.RED);
|
|
|
|
if (modalityType == Dialog.ModalityType.APPLICATION_MODAL) {
|
|
rightFrame.setModalExclusionType(
|
|
Dialog.ModalExclusionType.APPLICATION_EXCLUDE);
|
|
} else if (modalityType == Dialog.ModalityType.TOOLKIT_MODAL) {
|
|
rightFrame.setModalExclusionType(
|
|
Dialog.ModalExclusionType.TOOLKIT_EXCLUDE);
|
|
}
|
|
|
|
dialog.setVisible(true);
|
|
}
|
|
|
|
private void checkIfLeftOnTop(boolean refState, String msg) {
|
|
|
|
Point p = leftFrame.getLocationOnScreen();
|
|
int x = p.x + (int)(leftFrame.getWidth() * 0.9);
|
|
int y = p.y + (int)(leftFrame.getHeight() * 0.9);
|
|
boolean f = robot.getPixelColor(x, y).equals(leftFrame.getBackground());
|
|
assertEQ(refState, f, msg);
|
|
}
|
|
|
|
private void checkIfRightOnTop(boolean refState, String msg) {
|
|
|
|
Point p = rightFrame.getLocationOnScreen();
|
|
int x = p.x + (int)(rightFrame.getWidth() * 0.1);
|
|
int y = p.y + (int)(rightFrame.getHeight() * 0.9);
|
|
boolean f = robot.getPixelColor(x, y).equals(rightFrame.getBackground());
|
|
assertEQ(refState, f, msg);
|
|
}
|
|
|
|
private void Test() throws Exception {
|
|
|
|
String type =
|
|
dialog.getModalityType().toString().toLowerCase().replace('_', ' ');
|
|
|
|
final String msg1 = "The " + type + "dialog was " +
|
|
"overlapped by the blocked frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg1); });
|
|
|
|
EventQueue.invokeAndWait(() -> { leftFrame.toFront(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg2 = "The dialog is still overlapped by the right frame" +
|
|
" after calling toFront method for the blocked (left) frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg2); });
|
|
|
|
final String msg3 = "The " + type + " dialog was overlapped by the " +
|
|
"blocked frame after calling toFront method for the blocked frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg3); });
|
|
|
|
|
|
if (owner == DialogOwner.FRAME) { return; }
|
|
|
|
EventQueue.invokeAndWait(() -> { leftFrame.toBack(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg4 = "Calling toBack " +
|
|
"for the blocked frame pushed the blocking dialog to back.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg4); });
|
|
|
|
final String msg5 = "The " + type + " dialog was overlapped " +
|
|
"by the blocked frame after toBack was called for the left frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg5); });
|
|
}
|
|
|
|
private void docTest() throws Exception {
|
|
|
|
if (owner == DialogOwner.FRAME) { Test(); }
|
|
else {
|
|
|
|
final String msg1 = "toBack was called for the dialog.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(true, msg1); });
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(true, msg1); });
|
|
|
|
EventQueue.invokeAndWait(() -> { dialog.toFront(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg2 = "Dialog still behind " +
|
|
"the right frame even after calling toFront method.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg2); });
|
|
final String msg3 = "The document modal dialog " +
|
|
"gone behind the blocked left frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg3); });
|
|
|
|
EventQueue.invokeAndWait(() -> { leftFrame.toBack(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg4 = "Calling toBack for the left " +
|
|
"frame pushed the document modal dialog to back.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg4); });
|
|
final String msg5 = "The document modal dialog " +
|
|
"was pushed behind the left frame when toBack called for the frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg5); });
|
|
}
|
|
}
|
|
|
|
private void modelessTest() throws Exception {
|
|
|
|
if (owner == DialogOwner.FRAME) {
|
|
final String msg = "The modeless dialog was " +
|
|
"pushed behind the parent left frame after toBack call.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg); });
|
|
} else {
|
|
final String msg =
|
|
"Dialog should not overlap the frame after calling toBack.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(true, msg); });
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(true, msg); });
|
|
}
|
|
|
|
EventQueue.invokeAndWait(() -> { dialog.toFront(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg1 = "The frames should not overlap the dialog " +
|
|
"after calling toFront for it.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg1); });
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg1); });
|
|
|
|
if (owner == DialogOwner.FRAME) { return; }
|
|
|
|
EventQueue.invokeAndWait(() -> { leftFrame.toBack(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
final String msg2 = "Calling toBack method for the " +
|
|
"left frame pushed the modeless dialog to back.";
|
|
EventQueue.invokeAndWait(() -> { checkIfRightOnTop(false, msg2); });
|
|
final String msg3 = "The modeless dialog was pushed " +
|
|
"behind the left frame after toBack was called for the frame.";
|
|
EventQueue.invokeAndWait(() -> { checkIfLeftOnTop(false, msg3); });
|
|
}
|
|
|
|
public void doTest() throws Exception {
|
|
|
|
try {
|
|
robot.waitForIdle(delay);
|
|
|
|
dialog.clickOpenButton(robot);
|
|
robot.waitForIdle(delay);
|
|
|
|
dialog.clickCloseButton(robot);
|
|
robot.waitForIdle(delay);
|
|
|
|
EventQueue.invokeAndWait(() -> { dialog.toBack(); });
|
|
robot.waitForIdle(delay);
|
|
|
|
switch (modalityType) {
|
|
case APPLICATION_MODAL:
|
|
case TOOLKIT_MODAL:
|
|
Test();
|
|
break;
|
|
case DOCUMENT_MODAL:
|
|
docTest();
|
|
break;
|
|
case MODELESS:
|
|
modelessTest();
|
|
break;
|
|
}
|
|
} finally {
|
|
EventQueue.invokeAndWait(this::closeAll);
|
|
}
|
|
}
|
|
|
|
private void closeAll() {
|
|
if (dialog != null) { dialog.dispose(); }
|
|
if (leftFrame != null) { leftFrame.dispose(); }
|
|
if (rightFrame != null) { rightFrame.dispose(); }
|
|
if (hiddenDialog != null) { hiddenDialog.dispose(); }
|
|
if (hiddenFrame != null) { hiddenFrame.dispose(); }
|
|
}
|
|
|
|
|
|
class CustomDialog extends TestDialog {
|
|
|
|
public CustomDialog(Dialog d) { super(d); }
|
|
public CustomDialog(Frame f) { super(f); }
|
|
|
|
@Override
|
|
public void doOpenAction() {
|
|
if (rightFrame != null) {
|
|
rightFrame.setVisible(true);
|
|
}
|
|
}
|
|
}
|
|
}
|