mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 14:54:52 +02:00
8341982: Simplify JButton/bug4323121.java
Reviewed-by: abhiscxk, honkar, dnguyen, achung
This commit is contained in:
parent
e13206d3a1
commit
6fa5cea984
1 changed files with 45 additions and 61 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -24,59 +24,81 @@
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 4323121
|
* @bug 4323121
|
||||||
* @summary Tests whether any button that extends JButton always
|
* @summary Tests whether a button model always returns true for isArmed()
|
||||||
returns true for isArmed()
|
* when mouse hovers over the button
|
||||||
* @key headful
|
* @key headful
|
||||||
* @run main bug4323121
|
* @run main bug4323121
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.awt.Graphics;
|
|
||||||
import java.awt.Point;
|
import java.awt.Point;
|
||||||
import java.awt.Robot;
|
import java.awt.Robot;
|
||||||
|
import java.awt.event.MouseAdapter;
|
||||||
import java.awt.event.MouseEvent;
|
import java.awt.event.MouseEvent;
|
||||||
import java.awt.event.MouseListener;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.awt.event.MouseMotionListener;
|
|
||||||
import javax.swing.JButton;
|
import javax.swing.JButton;
|
||||||
import javax.swing.JFrame;
|
import javax.swing.JFrame;
|
||||||
import javax.swing.SwingUtilities;
|
import javax.swing.SwingUtilities;
|
||||||
|
|
||||||
public class bug4323121 {
|
import static java.util.concurrent.TimeUnit.SECONDS;
|
||||||
|
|
||||||
|
public final class bug4323121 {
|
||||||
|
|
||||||
static JFrame frame;
|
static JFrame frame;
|
||||||
static testButton button;
|
static JButton button;
|
||||||
static volatile Point pt;
|
|
||||||
static volatile int buttonW;
|
static volatile Point buttonCenter;
|
||||||
static volatile int buttonH;
|
|
||||||
static volatile boolean failed = false;
|
private static final CountDownLatch mouseEntered = new CountDownLatch(1);
|
||||||
|
|
||||||
|
// Usage of this flag is thread-safe because of using the mouseEntered latch
|
||||||
|
private static boolean modelArmed;
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
Robot robot = new Robot();
|
Robot robot = new Robot();
|
||||||
robot.setAutoDelay(100);
|
robot.setAutoDelay(100);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
SwingUtilities.invokeAndWait(() -> {
|
SwingUtilities.invokeAndWait(() -> {
|
||||||
|
button = new JButton("gotcha");
|
||||||
|
button.addMouseListener(new MouseAdapter() {
|
||||||
|
@Override
|
||||||
|
public void mouseEntered(MouseEvent e) {
|
||||||
|
if (button.getModel().isArmed()) {
|
||||||
|
modelArmed = true;
|
||||||
|
}
|
||||||
|
mouseEntered.countDown();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
frame = new JFrame("bug4323121");
|
frame = new JFrame("bug4323121");
|
||||||
button = new testButton("gotcha");
|
|
||||||
frame.getContentPane().add(button);
|
frame.getContentPane().add(button);
|
||||||
|
|
||||||
frame.pack();
|
frame.pack();
|
||||||
frame.setLocationRelativeTo(null);
|
frame.setLocationRelativeTo(null);
|
||||||
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||||
frame.setVisible(true);
|
frame.setVisible(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
robot.waitForIdle();
|
robot.waitForIdle();
|
||||||
robot.delay(1000);
|
|
||||||
SwingUtilities.invokeAndWait(() -> {
|
SwingUtilities.invokeAndWait(() -> {
|
||||||
pt = button.getLocationOnScreen();
|
Point location = button.getLocationOnScreen();
|
||||||
buttonW = button.getSize().width;
|
buttonCenter = new Point(location.x + button.getWidth() / 2,
|
||||||
buttonH = button.getSize().height;
|
location.y + button.getHeight() / 2);
|
||||||
});
|
});
|
||||||
robot.mouseMove(pt.x + buttonW / 2, pt.y + buttonH / 2);
|
|
||||||
robot.waitForIdle();
|
robot.mouseMove(buttonCenter.x, buttonCenter.y);
|
||||||
if (failed) {
|
|
||||||
throw new RuntimeException("Any created button returns " +
|
if (!mouseEntered.await(1, SECONDS)) {
|
||||||
"true for isArmed()");
|
throw new RuntimeException("Mouse entered event wasn't received");
|
||||||
|
}
|
||||||
|
if (modelArmed) {
|
||||||
|
throw new RuntimeException("getModel().isArmed() returns true "
|
||||||
|
+ "when mouse hovers over the button");
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
SwingUtilities.invokeAndWait(() -> {
|
SwingUtilities.invokeAndWait(() -> {
|
||||||
if (frame != null) {
|
if (frame != null) {
|
||||||
frame.dispose();
|
frame.dispose();
|
||||||
}
|
}
|
||||||
|
@ -84,42 +106,4 @@ public class bug4323121 {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static class testButton extends JButton implements MouseMotionListener, MouseListener {
|
|
||||||
public testButton(String label) {
|
|
||||||
super(label);
|
|
||||||
addMouseMotionListener(this);
|
|
||||||
addMouseListener(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void paintComponent(Graphics g) {
|
|
||||||
super.paintComponent(g);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void paintBorder(Graphics g) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mousePressed(MouseEvent e) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseDragged(MouseEvent e) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseMoved(MouseEvent e) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseReleased(MouseEvent e) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseEntered(MouseEvent e) {
|
|
||||||
if (getModel().isArmed()) {
|
|
||||||
failed = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseExited(MouseEvent e) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void mouseClicked(MouseEvent e) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue