Skip to content

Commit

Permalink
8296275: Write a test to verify setAccelerator method of JMenuItem
Browse files Browse the repository at this point in the history
Reviewed-by: mvs, aivanov
  • Loading branch information
Naveenam-Oracle authored and aivanov-jdk committed Dec 21, 2022
1 parent 85f9b37 commit b005013
Showing 1 changed file with 119 additions and 0 deletions.
119 changes: 119 additions & 0 deletions test/jdk/javax/swing/JMenuItem/JMenuItemSetAcceleratorTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
/*
* Copyright (c) 2016, 2022, 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.Dimension;
import java.awt.EventQueue;
import java.awt.FlowLayout;
import java.awt.Point;
import java.awt.Robot;
import java.awt.event.InputEvent;
import java.awt.event.KeyEvent;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import javax.swing.JFrame;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.KeyStroke;
import javax.swing.SwingUtilities;

/*
* @test
* @key headful
* @bug 8296275
* @summary To verify the setAccelerator method of JMenuItem.
* @requires (os.family=="mac")
* @run main JMenuItemSetAcceleratorTest
*/

public class JMenuItemSetAcceleratorTest {
private static JFrame frame;
private static final CountDownLatch actionLatch = new CountDownLatch(1);
private volatile static Point frameAt;
private volatile static Dimension frameSize;

private static void createAndShow() {
frame = new JFrame("JMenuItem.setAccelerator");
frame.setLayout(new FlowLayout());

JMenuBar bar = new JMenuBar();
JMenu menu = new JMenu("File");
JMenuItem menuItem = new JMenuItem("Menu Item");

menuItem.setAccelerator(
KeyStroke.getKeyStroke(KeyEvent.VK_M, InputEvent.META_DOWN_MASK));
menuItem.addActionListener(e -> {
System.out.println("menu item action.");
actionLatch.countDown();
});

menu.add(menuItem);
bar.add(menu);

frame.setJMenuBar(bar);
frame.setSize(200, 200);
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}

public static void main(String[] args) throws Exception {
try {
SwingUtilities.invokeAndWait(JMenuItemSetAcceleratorTest::createAndShow);

Robot robot = new Robot();
robot.setAutoDelay(50);
robot.setAutoWaitForIdle(true);

EventQueue.invokeAndWait(() -> {
frameAt = frame.getLocationOnScreen();
frameSize = frame.getSize();
});

robot.mouseMove(frameAt.x + frameSize.width / 2,
frameAt.y + frameSize.height / 2);
robot.mousePress(InputEvent.BUTTON1_DOWN_MASK);
robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK);
robot.waitForIdle();

robot.keyPress(KeyEvent.VK_META);
robot.keyPress(KeyEvent.VK_M);
robot.keyRelease(KeyEvent.VK_M);
robot.keyRelease(KeyEvent.VK_META);

if (!actionLatch.await(5, TimeUnit.SECONDS)) {
throw new RuntimeException(
"Hasn't received the JMenuItem action event by pressing "
+ "accelerator keys, test fails.");
}
System.out.println("Test passed, received action event on menu item.");
} finally {
SwingUtilities.invokeAndWait(JMenuItemSetAcceleratorTest::disposeFrame);
}
}

public static void disposeFrame() {
if (frame != null) {
frame.dispose();
}
}
}

3 comments on commit b005013

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@SoniaZaldana
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/backport jdk17u-dev

@openjdk
Copy link

@openjdk openjdk bot commented on b005013 Sep 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@SoniaZaldana the backport was successfully created on the branch SoniaZaldana-backport-b005013a in my personal fork of openjdk/jdk17u-dev. To create a pull request with this backport targeting openjdk/jdk17u-dev:master, just click the following link:

➡️ Create pull request

The title of the pull request is automatically filled in correctly and below you find a suggestion for the pull request body:

Hi all,

This pull request contains a backport of commit b005013a from the openjdk/jdk repository.

The commit being backported was authored by Naveen Narayanan on 21 Dec 2022 and was reviewed by Manukumar V S and Alexey Ivanov.

Thanks!

If you need to update the source branch of the pull then run the following commands in a local clone of your personal fork of openjdk/jdk17u-dev:

$ git fetch https://github.com/openjdk-bots/jdk17u-dev.git SoniaZaldana-backport-b005013a:SoniaZaldana-backport-b005013a
$ git checkout SoniaZaldana-backport-b005013a
# make changes
$ git add paths/to/changed/files
$ git commit --message 'Describe additional changes made'
$ git push https://github.com/openjdk-bots/jdk17u-dev.git SoniaZaldana-backport-b005013a

Please sign in to comment.