8342508: Use latch in BasicMenuUI/bug4983388.java instead of delay
Reviewed-by: azvegint, abhiscxk, serb
This commit is contained in:
parent
47ebf8d868
commit
02ec8ca2d6
@ -26,28 +26,41 @@
|
|||||||
* @key headful
|
* @key headful
|
||||||
* @bug 4983388 8015600
|
* @bug 4983388 8015600
|
||||||
* @summary shortcuts on menus do not work on JDS
|
* @summary shortcuts on menus do not work on JDS
|
||||||
* @author Oleg Mokhovikov
|
|
||||||
* @library ../../../../regtesthelpers
|
* @library ../../../../regtesthelpers
|
||||||
* @build Util
|
* @build Util
|
||||||
* @run main bug4983388
|
* @run main bug4983388
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.Robot;
|
||||||
import javax.swing.*;
|
|
||||||
import javax.swing.event.MenuListener;
|
|
||||||
import javax.swing.event.MenuEvent;
|
|
||||||
import java.awt.event.KeyEvent;
|
import java.awt.event.KeyEvent;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
|
||||||
|
import javax.swing.JFrame;
|
||||||
|
import javax.swing.JMenu;
|
||||||
|
import javax.swing.JMenuBar;
|
||||||
|
import javax.swing.SwingUtilities;
|
||||||
|
import javax.swing.UIManager;
|
||||||
|
import javax.swing.UnsupportedLookAndFeelException;
|
||||||
|
import javax.swing.event.MenuEvent;
|
||||||
|
import javax.swing.event.MenuListener;
|
||||||
|
|
||||||
|
import static java.util.concurrent.TimeUnit.SECONDS;
|
||||||
|
|
||||||
public class bug4983388 {
|
public class bug4983388 {
|
||||||
static volatile boolean bMenuSelected = false;
|
|
||||||
static JFrame frame;
|
static JFrame frame;
|
||||||
|
|
||||||
|
private static final CountDownLatch menuSelected = new CountDownLatch(1);
|
||||||
|
|
||||||
private static class TestMenuListener implements MenuListener {
|
private static class TestMenuListener implements MenuListener {
|
||||||
|
@Override
|
||||||
public void menuCanceled(MenuEvent e) {}
|
public void menuCanceled(MenuEvent e) {}
|
||||||
|
@Override
|
||||||
public void menuDeselected(MenuEvent e) {}
|
public void menuDeselected(MenuEvent e) {}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void menuSelected(MenuEvent e) {
|
public void menuSelected(MenuEvent e) {
|
||||||
System.out.println("menuSelected");
|
System.out.println("menuSelected");
|
||||||
bMenuSelected = true;
|
menuSelected.countDown();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,28 +69,24 @@ public class bug4983388 {
|
|||||||
JMenu menu = new JMenu("File");
|
JMenu menu = new JMenu("File");
|
||||||
menu.setMnemonic('F');
|
menu.setMnemonic('F');
|
||||||
menuBar.add(menu);
|
menuBar.add(menu);
|
||||||
frame = new JFrame();
|
menu.addMenuListener(new TestMenuListener());
|
||||||
|
|
||||||
|
frame = new JFrame("bug4983388");
|
||||||
frame.setJMenuBar(menuBar);
|
frame.setJMenuBar(menuBar);
|
||||||
frame.setLocationRelativeTo(null);
|
frame.setLocationRelativeTo(null);
|
||||||
frame.pack();
|
frame.setSize(250, 100);
|
||||||
frame.setVisible(true);
|
frame.setVisible(true);
|
||||||
MenuListener listener = new TestMenuListener();
|
|
||||||
menu.addMenuListener(listener);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
UIManager.setLookAndFeel("com.sun.java.swing.plaf.gtk.GTKLookAndFeel");
|
UIManager.setLookAndFeel("com.sun.java.swing.plaf.gtk.GTKLookAndFeel");
|
||||||
} catch (UnsupportedLookAndFeelException | ClassNotFoundException ex) {
|
} catch (UnsupportedLookAndFeelException | ClassNotFoundException ex) {
|
||||||
System.err.println("GTKLookAndFeel is not supported on this platform. Using defailt LaF for this platform.");
|
System.err.println("GTKLookAndFeel is not supported on this platform. "
|
||||||
|
+ "Using default LaF for this platform.");
|
||||||
}
|
}
|
||||||
|
|
||||||
SwingUtilities.invokeAndWait(new Runnable() {
|
SwingUtilities.invokeAndWait(bug4983388::createAndShowGUI);
|
||||||
public void run() {
|
|
||||||
createAndShowGUI();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Robot robot = new Robot();
|
Robot robot = new Robot();
|
||||||
robot.setAutoDelay(50);
|
robot.setAutoDelay(50);
|
||||||
@ -85,13 +94,13 @@ public class bug4983388 {
|
|||||||
robot.delay(500);
|
robot.delay(500);
|
||||||
|
|
||||||
Util.hitMnemonics(robot, KeyEvent.VK_F);
|
Util.hitMnemonics(robot, KeyEvent.VK_F);
|
||||||
robot.waitForIdle();
|
|
||||||
robot.delay(500);
|
|
||||||
|
|
||||||
SwingUtilities.invokeAndWait(() -> frame.dispose());
|
try {
|
||||||
|
if (!menuSelected.await(1, SECONDS)) {
|
||||||
if (!bMenuSelected) {
|
|
||||||
throw new RuntimeException("shortcuts on menus do not work");
|
throw new RuntimeException("shortcuts on menus do not work");
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
|
SwingUtilities.invokeAndWait(frame::dispose);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user