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