1 /*
   2  * Copyright (c) 2008, 2016, 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   @key headful
  27   @bug       6785058
  28   @summary   Tests that an owner is activated on closing its owned dialog with the warning icon.
  29   @author    Anton Tarasov: area=awt.focus
  30   @library   ../../regtesthelpers
  31   @build     Util
  32   @run       main/othervm/policy=java.policy -Djava.security.manager CloseDialogActivateOwnerTest
  33 */
  34 
  35 import java.awt.*;
  36 import java.awt.event.*;
  37 import java.applet.Applet;
  38 import java.util.concurrent.atomic.AtomicBoolean;
  39 import java.lang.reflect.InvocationTargetException;
  40 import test.java.awt.regtesthelpers.Util;
  41 
  42 public class CloseDialogActivateOwnerTest extends Applet {
  43     Robot robot;
  44 
  45     public static void main(String[] args) {
  46         CloseDialogActivateOwnerTest app = new CloseDialogActivateOwnerTest();
  47         app.init();
  48         app.start();
  49     }
  50 
  51     public void init() {
  52         robot = Util.createRobot();
  53     }
  54 
  55     public void start() {
  56         final Frame frame = new Frame("Owner Frame");
  57         final Dialog dialog = new Dialog(frame, "Owned Dialog");
  58 
  59         frame.setSize(100, 100);
  60         dialog.setSize(100, 100);
  61 
  62         // Show the owner. Check that it's focused.
  63         if (!Util.trackWindowGainedFocus(frame, new Runnable() {
  64                 public void run() {
  65                     frame.setVisible(true);
  66                 }
  67             }, 2000, false))
  68         {
  69             throw new TestErrorException("the owner frame hasn't been activated on show");
  70         }
  71 
  72         // Show the owned dialog. Check that it's focused.
  73         if (!Util.trackWindowGainedFocus(dialog, new Runnable() {
  74                 public void run() {
  75                     dialog.setVisible(true);
  76                 }
  77             }, 2000, true))
  78         {
  79             throw new TestErrorException("the owned dialog hasn't been activated on show");
  80         }
  81 
  82         robot.delay(2000); // wait for the warning icon is shown
  83 
  84         // Close the dialog. Check that the owner is activated.
  85         if (!Util.trackWindowGainedFocus(frame, new Runnable() {
  86                 public void run() {
  87                     dialog.dispose();
  88                 }
  89             }, 2000, false))
  90         {
  91             throw new TestFailedException("the owner hasn't been activated on closing the owned dialog");
  92         }
  93 
  94         System.out.println("Test passed.");
  95     }
  96 }
  97 
  98 /**
  99  * Thrown when the behavior being verified is found wrong.
 100  */
 101 class TestFailedException extends RuntimeException {
 102     TestFailedException(String msg) {
 103         super("Test failed: " + msg);
 104     }
 105 }
 106 
 107 /**
 108  * Thrown when an error not related to the behavior being verified is encountered.
 109  */
 110 class TestErrorException extends Error {
 111     TestErrorException(String msg) {
 112         super("Unexpected error: " + msg);
 113     }
 114 }
 115