jdk/test/java/awt/Modal/ToBack/ToBackFDFTest.java
author avstepan
Wed, 19 Nov 2014 14:12:59 +0400
changeset 28069 907a72cb0feb
permissions -rw-r--r--
8054143: move awt automated tests from AWT_Modality to OpenJDK repository - part 6 Reviewed-by: pchelko

/*
 * Copyright (c) 2007, 2014, 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.testlibrary.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);
            }
        }
    }
}