Skip to content

Commit

Permalink
8307128: Open source some drag and drop tests 4
Browse files Browse the repository at this point in the history
Reviewed-by: prr
  • Loading branch information
Alisen Chung committed May 9, 2023
1 parent 7f05f6f commit 9829424
Show file tree
Hide file tree
Showing 5 changed files with 1,680 additions and 0 deletions.
127 changes: 127 additions & 0 deletions test/jdk/java/awt/dnd/MouseExitGestureTriggerTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
/*
* Copyright (c) 1999, 2023, 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 javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTree;
import java.awt.EventQueue;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.dnd.DnDConstants;
import java.awt.dnd.DragGestureEvent;
import java.awt.dnd.DragGestureListener;
import java.awt.dnd.DragSource;
import java.awt.event.InputEvent;

/*
@test
@bug 4273712 4396746
@summary tests that mouse exit event doesn't trigger drag
@key headful
@run main MouseExitGestureTriggerTest
*/

public class MouseExitGestureTriggerTest {

boolean recognized = false;
volatile JFrame frame;
volatile JPanel panel;
volatile JTree tree;
volatile DragSource dragSource;
volatile Point srcPoint;
volatile Rectangle r;
volatile DragGestureListener dgl;
static final int FRAME_ACTIVATION_TIMEOUT = 2000;
static final int RECOGNITION_TIMEOUT = 1000;

public static void main(String[] args) throws Exception {
MouseExitGestureTriggerTest test = new MouseExitGestureTriggerTest();
EventQueue.invokeAndWait(test::init);
try {
test.start();
} finally {
EventQueue.invokeAndWait(() -> {
if (test.frame != null) {
test.frame.dispose();
}
});
}
}

public void init() {
frame = new JFrame("MouseExitGestureTriggerTest");
panel = new JPanel();
tree = new JTree();

dragSource = DragSource.getDefaultDragSource();
dgl = new DragGestureListener() {
public void dragGestureRecognized(DragGestureEvent dge) {
Thread.dumpStack();
recognized = true;
}
};

tree.setEditable(true);
dragSource.createDefaultDragGestureRecognizer(tree,
DnDConstants.ACTION_MOVE,
dgl);
panel.add(tree);
frame.getContentPane().add(panel);
frame.setLocation(200, 200);

frame.pack();
frame.setVisible(true);
}

public void start() throws Exception {
final Robot robot = new Robot();
Thread.sleep(FRAME_ACTIVATION_TIMEOUT);

clickRootNode(robot);
clickRootNode(robot);
clickRootNode(robot);

Thread.sleep(RECOGNITION_TIMEOUT);

EventQueue.invokeAndWait(() -> {
if (recognized) {
throw new RuntimeException("Mouse exit event triggered drag");
}
});
}

void clickRootNode(final Robot robot) throws Exception {
EventQueue.invokeAndWait(() -> {
srcPoint = tree.getLocationOnScreen();
r = tree.getRowBounds(0);
});
srcPoint.translate(r.x + 2 * r.width /3 , r.y + r.height / 2);
robot.mouseMove(srcPoint.x ,srcPoint.y);

robot.mousePress(InputEvent.BUTTON1_MASK);
Thread.sleep(10);
robot.mouseRelease(InputEvent.BUTTON1_MASK);
Thread.sleep(10);
}
}
Loading

3 comments on commit 9829424

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

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

@Rudometov
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 9829424 May 15, 2023

Choose a reason for hiding this comment

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

@Rudometov the backport was successfully created on the branch Rudometov-backport-98294242 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 98294242 from the openjdk/jdk repository.

The commit being backported was authored by Alisen Chung on 9 May 2023 and was reviewed by Phil Race.

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 Rudometov-backport-98294242:Rudometov-backport-98294242
$ git checkout Rudometov-backport-98294242
# 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 Rudometov-backport-98294242

Please sign in to comment.