blob: cd242eec71b51589740d93250e33a7c5aa0928c9 [file] [log] [blame]
/*
* Copyright (c) 1997, 2016, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
package org.netbeans.jemmy.operators;
import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.Insets;
import java.awt.Window;
import java.awt.event.KeyEvent;
import java.awt.event.MouseEvent;
import java.util.Hashtable;
import javax.swing.JMenu;
import javax.swing.JMenuItem;
import javax.swing.JPopupMenu;
import javax.swing.MenuElement;
import javax.swing.MenuSelectionManager;
import javax.swing.SingleSelectionModel;
import javax.swing.event.PopupMenuListener;
import javax.swing.plaf.PopupMenuUI;
import org.netbeans.jemmy.Action;
import org.netbeans.jemmy.ComponentChooser;
import org.netbeans.jemmy.ComponentSearcher;
import org.netbeans.jemmy.JemmyException;
import org.netbeans.jemmy.JemmyProperties;
import org.netbeans.jemmy.Outputable;
import org.netbeans.jemmy.QueueTool;
import org.netbeans.jemmy.TestOut;
import org.netbeans.jemmy.TimeoutExpiredException;
import org.netbeans.jemmy.Timeoutable;
import org.netbeans.jemmy.Timeouts;
import org.netbeans.jemmy.WindowWaiter;
import org.netbeans.jemmy.drivers.DriverManager;
import org.netbeans.jemmy.drivers.MenuDriver;
/**
* <BR><BR>Timeouts used: <BR>
* JMenuOperator.WaitBeforePopupTimeout - time to sleep before popup expanding
* <BR>
* JMenuOperator.WaitPopupTimeout - time to wait popup displayed <BR>
* ComponentOperator.WaitComponentTimeout - time to wait button displayed <BR>
* WindowWaiter.WaitWindowTimeout - time to wait popup window displayed <BR>
* WindowWaiter.AfterWindowTimeout - time to sleep after popup window has been
* dispayed <BR>.
*
* @see org.netbeans.jemmy.Timeouts
*
* @author Alexandre Iline (alexandre.iline@oracle.com)
*
*/
public class JPopupMenuOperator extends JComponentOperator
implements Outputable, Timeoutable {
/**
* Identifier for a "label" property.
*
* @see #getDump
*/
public static final String LABEL_DPROP = "Label";
private TestOut output;
private Timeouts timeouts;
private MenuDriver driver;
/**
* Constructor.
*
* @param popup a component
*/
public JPopupMenuOperator(JPopupMenu popup) {
super(popup);
driver = DriverManager.getMenuDriver(getClass());
}
/**
* Constructs a JPopupMenuOperator object.
*
* @param cont a container
* @param chooser a component chooser specifying searching criteria.
* @param index an index between appropriate ones.
*/
public JPopupMenuOperator(ContainerOperator<?> cont, ComponentChooser chooser, int index) {
this((JPopupMenu) cont.
waitSubComponent(new JPopupMenuFinder(chooser),
index));
copyEnvironment(cont);
}
/**
* Constructs a JPopupMenuOperator object.
*
* @param cont a container
* @param chooser a component chooser specifying searching criteria.
*/
public JPopupMenuOperator(ContainerOperator<?> cont, ComponentChooser chooser) {
this(cont, chooser, 0);
}
/**
* Constructor. Waits component first. Constructor can be used in
* complicated cases when output or timeouts should differ from default.
*
* @param env an operator to copy environment from.
* @throws TimeoutExpiredException
*/
public JPopupMenuOperator(Operator env) {
this((JPopupMenu) waitComponent(WindowOperator.
waitWindow(new JPopupWindowFinder(),
0,
env.getTimeouts(),
env.getOutput()),
new JPopupMenuFinder(),
0,
env.getTimeouts(),
env.getOutput()));
copyEnvironment(env);
}
/**
* Constructor. Waits component in container first. Uses cont's timeout and
* output for waiting and to init operator.
*
* @param cont a container
* @throws TimeoutExpiredException
*/
public JPopupMenuOperator(ContainerOperator<?> cont) {
this((JPopupMenu) waitComponent(cont,
new JPopupMenuFinder(),
0));
copyEnvironment(cont);
}
/**
* Constructor. Waits component first.
*
* @throws TimeoutExpiredException
*/
public JPopupMenuOperator() {
this(Operator.getEnvironmentOperator());
}
/**
* Searches JPopupMenu in container.
*
* @param cont Container to search component in.
* @param chooser a component chooser specifying searching criteria.
* @param index Ordinal component index.
* @return JPopupMenu instance or null if component was not found.
*/
public static JPopupMenu findJPopupMenu(Container cont, ComponentChooser chooser, int index) {
return (JPopupMenu) findComponent(cont, new JPopupMenuFinder(chooser), index);
}
/**
* Searches JPopupMenu in container.
*
* @param cont Container to search component in.
* @param chooser a component chooser specifying searching criteria.
* @return JPopupMenu instance or null if component was not found.
*/
public static JPopupMenu findJPopupMenu(Container cont, ComponentChooser chooser) {
return findJPopupMenu(cont, chooser, 0);
}
/**
* Waits JPopupMenu in container.
*
* @param cont Container to search component in.
* @param chooser a component chooser specifying searching criteria.
* @param index Ordinal component index.
* @return JPopupMenu instance.
* @throws TimeoutExpiredException
*/
public static JPopupMenu waitJPopupMenu(Container cont, ComponentChooser chooser, int index) {
return (JPopupMenu) waitComponent(cont, new JPopupMenuFinder(chooser), index);
}
/**
* Waits JPopupMenu in container.
*
* @param cont Container to search component in.
* @param chooser a component chooser specifying searching criteria.
* @return JPopupMenu instance.
* @throws TimeoutExpiredException
*/
public static JPopupMenu waitJPopupMenu(Container cont, ComponentChooser chooser) {
return waitJPopupMenu(cont, chooser, 0);
}
/**
* Searches for a window which contains JPopupMenu.
*
* @param chooser a component chooser specifying criteria for JPopupMenu.
* @return a window containing JPopupMenu.
*/
public static Window findJPopupWindow(ComponentChooser chooser) {
return WindowWaiter.getWindow(new JPopupWindowFinder(chooser));
}
/**
* Waits for a window which contains JPopupMenu.
*
* @param chooser a component chooser specifying criteria for JPopupMenu.
* @return a window containing JPopupMenu.
* @throws TimeoutExpiredException
*/
public static Window waitJPopupWindow(ComponentChooser chooser) {
try {
return (new WindowWaiter()).waitWindow(new JPopupWindowFinder(chooser));
} catch (InterruptedException e) {
return null;
}
}
/**
* Waits popup defined by {@code popupChooser} parameter.
*
* @param popupChooser a component chooser specifying criteria for
* JPopupMenu.
* @return a JPopupMenu fitting the criteria.
*/
public static JPopupMenuOperator waitJPopupMenu(final ComponentChooser popupChooser) {
try {
WindowOperator wind = new WindowOperator(new WindowWaiter().waitWindow(new ComponentChooser() {
@Override
public boolean checkComponent(Component comp) {
ComponentSearcher searcher = new ComponentSearcher((Container) comp);
searcher.setOutput(JemmyProperties.getCurrentOutput().createErrorOutput());
return searcher.findComponent(popupChooser) != null;
}
@Override
public String getDescription() {
return "Window containing \"" + popupChooser.getDescription() + "\" popup";
}
@Override
public String toString() {
return "JPopupMenuOperator.waitJPopupMenu.ComponentChooser{description = " + getDescription() + '}';
}
}));
return new JPopupMenuOperator(wind);
} catch (InterruptedException e) {
throw (new JemmyException("Popup waiting has been interrupted", e));
}
}
/**
* Waits popup containing menu item with {@code menuItemText} text.
*
* @param menuItemText a text of a menu item which supposed to be displayed
* inside the popup.
* @return a JPopupMenu fitting the criteria.
*/
public static JPopupMenuOperator waitJPopupMenu(final String menuItemText) {
return (waitJPopupMenu(new ComponentChooser() {
@Override
public boolean checkComponent(Component comp) {
if (comp instanceof JPopupMenu) {
ComponentSearcher searcher = new ComponentSearcher((Container) comp);
searcher.setOutput(JemmyProperties.getCurrentOutput().createErrorOutput());
return (searcher.findComponent(new JMenuItemOperator.JMenuItemByLabelFinder(menuItemText,
Operator.getDefaultStringComparator()))
!= null);
} else {
return false;
}
}
@Override
public String getDescription() {
return "Popup containing \"" + menuItemText + "\" menu item";
}
@Override
public String toString() {
return "JPopupMenuOperator.waitJPopupMenu.ComponentChooser{description = " + getDescription() + '}';
}
}));
}
/**
* Calls popup by clicking on (x, y) point in component.
*
* @param oper Component operator to call popup on.
* @param x X coordinate of click point in the component coordinate system.
* @param y Y coordinate of click point in the component coordinate system.
* @param mouseButton Mouse button mask to call popup.
* @return an opened JPopupMenu
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(final ComponentOperator oper, int x, int y, int mouseButton) {
oper.makeComponentVisible();
//1.5 workaround
if (System.getProperty("java.specification.version").compareTo("1.4") > 0) {
QueueTool qt = new QueueTool();
qt.setOutput(oper.getOutput().createErrorOutput());
qt.waitEmpty(10);
qt.waitEmpty(10);
qt.waitEmpty(10);
}
//end of 1.5 workaround
oper.clickForPopup(x, y, mouseButton);
oper.getTimeouts().sleep("JMenuOperator.WaitBeforePopupTimeout");
return (waitJPopupMenu(waitJPopupWindow(new ComponentChooser() {
@Override
public boolean checkComponent(Component cmp) {
Component invoker = ((JPopupMenu) cmp).getInvoker();
return (invoker == oper.getSource()
|| (invoker instanceof Container
&& ((Container) invoker).isAncestorOf(oper.getSource()))
|| (oper.getSource() instanceof Container
&& ((Container) oper.getSource()).isAncestorOf(invoker)));
}
@Override
public String getDescription() {
return "Popup menu";
}
@Override
public String toString() {
return "JPopupMenuOperator.callPopup.ComponentChooser{description = " + getDescription() + '}';
}
}),
ComponentSearcher.getTrueChooser("Popup menu")));
}
/**
* Calls popup by clicking on (x, y) point in component.
*
* @param oper Component operator to call popup on.
* @param x X coordinate of click point in the component coordinate system.
* @param y Y coordinate of click point in the component coordinate system.
* @return an opened JPopupMenu
* @see ComponentOperator#getPopupMouseButton()
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(ComponentOperator oper, int x, int y) {
return callPopup(oper, x, y, getPopupMouseButton());
}
/**
* Calls popup by clicking on (x, y) point in component.
*
* @param comp Component to call popup on.
* @param x X coordinate of click point in the component coordinate system.
* @param y Y coordinate of click point in the component coordinate system.
* @param mouseButton Mouse button mask to call popup.
* @return an opened JPopupMenu
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(Component comp, int x, int y, int mouseButton) {
return callPopup(new ComponentOperator(comp), x, y, mouseButton);
}
/**
* Calls popup by clicking on (x, y) point in component.
*
* @param comp Component to call popup on.
* @param x X coordinate of click point in the component coordinate system.
* @param y Y coordinate of click point in the component coordinate system.
* @return an opened JPopupMenu
* @see ComponentOperator#getPopupMouseButton()
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(Component comp, int x, int y) {
return callPopup(comp, x, y, getPopupMouseButton());
}
/**
* Calls popup by clicking component center.
*
* @param comp Component to call popup on.
* @param mouseButton Mouse button mask to call popup.
* @return an opened JPopupMenu
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(Component comp, int mouseButton) {
ComponentOperator co = new ComponentOperator(comp);
co.makeComponentVisible();
co.clickForPopup(mouseButton);
return (findJPopupMenu(waitJPopupWindow(ComponentSearcher.getTrueChooser("Popup menu window")),
ComponentSearcher.getTrueChooser("Popup menu")));
}
/**
* Calls popup by clicking component center.
*
* @param comp Component to call popup on.
* @return an opened JPopupMenu
* @see ComponentOperator#getPopupMouseButton()
* @throws TimeoutExpiredException
*/
public static JPopupMenu callPopup(Component comp) {
return callPopup(comp, getPopupMouseButton());
}
static {
//necessary to init timeouts
JMenuOperator.performInit();
}
@Override
public void setOutput(TestOut out) {
super.setOutput(out);
output = out;
}
@Override
public TestOut getOutput() {
return output;
}
@Override
public void setTimeouts(Timeouts times) {
super.setTimeouts(times);
timeouts = times;
}
@Override
public Timeouts getTimeouts() {
return timeouts;
}
@Override
public void copyEnvironment(Operator anotherOperator) {
super.copyEnvironment(anotherOperator);
driver = DriverManager.getMenuDriver(this);
}
/**
* Pushes menu.
*
* @param choosers Array of choosers to find menuItems to push.
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(final ComponentChooser[] choosers) {
return ((JMenuItem) produceTimeRestricted(new Action<Object, Void>() {
@Override
public Object launch(Void obj) {
//TDB 1.5 menu workaround
getQueueTool().waitEmpty();
Object result = driver.pushMenu(JPopupMenuOperator.this,
JMenuOperator.converChoosers(choosers));
getQueueTool().waitEmpty();
return result;
}
@Override
public String getDescription() {
return JMenuOperator.createDescription(choosers);
}
@Override
public String toString() {
return "JPopupMenuOperator.pushMenu.ComponentChooser{description = " + getDescription() + '}';
}
}, "JMenuOperator.PushMenuTimeout"));
}
/**
* Executes {@code pushMenu(choosers)} in a separate thread.
*
* @param choosers Array of choosers to find menuItems to push.
* @see #pushMenu(ComponentChooser[])
*/
public void pushMenuNoBlock(final ComponentChooser[] choosers) {
produceNoBlocking(new NoBlockingAction<Object, Void>("Menu pushing") {
@Override
public Object doAction(Void param) {
//TDB 1.5 menu workaround
getQueueTool().waitEmpty();
Object result = driver.pushMenu(JPopupMenuOperator.this,
JMenuOperator.converChoosers(choosers));
getQueueTool().waitEmpty();
return result;
}
});
}
/**
* Pushes menu.
*
* @param names an array of menu texts.
* @param comparator a string comparision algorithm
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String[] names, StringComparator comparator) {
return pushMenu(JMenuItemOperator.createChoosers(names, comparator));
}
/**
* Pushes menu.
*
* @param names Menu items texts.
* @param ce Compare text exactly.
* @param ccs Compare text case sensitively.
* @see ComponentOperator#isCaptionEqual(String, String, boolean, boolean)
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
* @deprecated Use pushMenu(String[]) or pushMenu(String[],
* StringComparator)
*/
@Deprecated
public JMenuItem pushMenu(String[] names, boolean ce, boolean ccs) {
return pushMenu(names, new DefaultStringComparator(ce, ccs));
}
/**
* Executes {@code pushMenu(names, ce, ccs)} in a separate thread.
*
* @param names an array of menu texts.
* @param comparator a string comparision algorithm
*/
public void pushMenuNoBlock(String[] names, StringComparator comparator) {
pushMenuNoBlock(JMenuItemOperator.createChoosers(names, comparator));
}
/**
* Executes {@code pushMenu(names, ce, ccs)} in a separate thread.
*
* @param names Menu items texts.
* @param ce Compare text exactly.
* @param ccs Compare text case sensitively.
* @see #pushMenu(String[], boolean,boolean)
* @deprecated Use pushMenuNoBlock(String[]) or pushMenuNoBlock(String[],
* StringComparator)
*/
@Deprecated
public void pushMenuNoBlock(String[] names, boolean ce, boolean ccs) {
pushMenuNoBlock(names, new DefaultStringComparator(ce, ccs));
}
/**
* Pushes menu.
*
* @param names Menu items texts.
* @see ComponentOperator#isCaptionEqual(String, String, boolean, boolean)
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String[] names) {
return pushMenu(names, getComparator());
}
/**
* Executes {@code pushMenu(names)} in a separate thread.
*
* @param names Menu items texts.
* @see #pushMenu(String[])
*/
public void pushMenuNoBlock(String[] names) {
pushMenuNoBlock(names, getComparator());
}
/**
* Pushes menu.
*
* @param path a menu path.
* @param delim a path delimiter.
* @param comparator a string comparision algorithm
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String path, String delim, StringComparator comparator) {
return pushMenu(parseString(path, delim), comparator);
}
/**
* Pushes menu. Uses PathParser assigned to this operator.
*
* @param path a menu path.
* @param comparator a string comparision algorithm
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String path, StringComparator comparator) {
return pushMenu(parseString(path), comparator);
}
/**
* Pushes menu.
*
* @param path String menupath representation ("File/New", for example).
* @param delim String menupath divider ("/").
* @param ce Compare text exactly.
* @param ccs Compare text case sensitively.
* @see ComponentOperator#isCaptionEqual(String, String, boolean, boolean)
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
* @deprecated Use pushMenu(String, String) or pushMenu(String, String,
* StringComparator)
*/
@Deprecated
public JMenuItem pushMenu(String path, String delim, boolean ce, boolean ccs) {
return pushMenu(parseString(path, delim), ce, ccs);
}
/**
* Executes {@code pushMenu(names, delim, comparator)} in a separate
* thread.
*
* @param path a menu path.
* @param delim a path delimiter.
* @param comparator a string comparision algorithm
*/
public void pushMenuNoBlock(String path, String delim, StringComparator comparator) {
pushMenuNoBlock(parseString(path, delim), comparator);
}
/**
* Executes {@code pushMenu(names, comparator)} in a separate thread.
* Uses PathParser assigned to this operator.
*
* @param path a menu path.
* @param comparator a string comparision algorithm
*/
public void pushMenuNoBlock(String path, StringComparator comparator) {
pushMenuNoBlock(parseString(path), comparator);
}
/**
* Executes {@code pushMenu(path, delim, ce, ccs)} in a separate
* thread.
*
* @param path String menupath representation ("File/New", for example).
* @param delim String menupath divider ("/").
* @param ce Compare text exactly.
* @param ccs Compare text case sensitively.
* @see #pushMenu
* @deprecated Use pushMenuNoBlock(String, String) or
* pushMenuNoBlock(String, String, StringComparator)
*/
@Deprecated
public void pushMenuNoBlock(String path, String delim, boolean ce, boolean ccs) {
pushMenuNoBlock(parseString(path, delim), ce, ccs);
}
/**
* Pushes menu.
*
* @param path String menupath representation ("File/New", for example).
* @param delim String menupath divider ("/").
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String path, String delim) {
return pushMenu(parseString(path, delim));
}
/**
* Pushes menu. Uses PathParser assigned to this operator.
*
* @param path String menupath representation ("File/New", for example).
* @return Last pushed JMenuItem.
* @throws TimeoutExpiredException
*/
public JMenuItem pushMenu(String path) {
return pushMenu(parseString(path));
}
/**
* Executes {@code pushMenu(path, delim)} in a separate thread.
*
* @param path String menupath representation ("File/New", for example).
* @param delim String menupath divider ("/").
*/
public void pushMenuNoBlock(String path, String delim) {
pushMenuNoBlock(parseString(path, delim));
}
/**
* Executes {@code pushMenu(path)} in a separate thread.
*
* @param path String menupath representation ("File/New", for example).
*/
public void pushMenuNoBlock(String path) {
pushMenuNoBlock(parseString(path));
}
public JMenuItemOperator[] showMenuItems(ComponentChooser[] choosers) {
if (choosers == null || choosers.length == 0) {
return JMenuItemOperator.getMenuItems((MenuElement) getSource(), this);
} else {
return JMenuItemOperator.getMenuItems((JMenu) pushMenu(choosers), this);
}
}
/**
* Shows submenu of menu specified by a {@code path} parameter.
*
* @param path an array of menu texts.
* @param comparator a string comparision algorithm
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String[] path, StringComparator comparator) {
if (path == null || path.length == 0) {
return JMenuItemOperator.getMenuItems((MenuElement) getSource(), this);
} else {
return JMenuItemOperator.getMenuItems((JMenu) pushMenu(path, comparator), this);
}
}
/**
* Shows submenu of menu specified by a {@code path} parameter. Uses
* StringComparator assigned to the operator.
*
* @param path an array of menu texts.
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String[] path) {
return showMenuItems(path, getComparator());
}
/**
* Shows submenu of menu specified by a {@code path} parameter.
*
* @param path a string identifying the menu path.
* @param delim a path delimiter.
* @param comparator a string comparision algorithm
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String path, String delim, StringComparator comparator) {
return showMenuItems(parseString(path, delim), comparator);
}
/**
* Shows submenu of menu specified by a {@code path} parameter. Uses
* PathParser assigned to this operator.
*
* @param path a string identifying the menu path.
* @param comparator a string comparision algorithm
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String path, StringComparator comparator) {
return showMenuItems(parseString(path), comparator);
}
/**
* Shows submenu of menu specified by a {@code path} parameter. Uses
* StringComparator assigned to the operator.
*
* @param path a string identifying the menu path.
* @param delim a path delimiter.
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String path, String delim) {
return showMenuItems(path, delim, getComparator());
}
/**
* Shows submenu of menu specified by a {@code path} parameter. Uses
* PathParser assigned to this operator. Uses StringComparator assigned to
* the operator.
*
* @param path a string identifying the menu path.
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator[] showMenuItems(String path) {
return showMenuItems(path, getComparator());
}
public JMenuItemOperator showMenuItem(ComponentChooser[] choosers) {
ComponentChooser[] parentPath = getParentPath(choosers);
JMenu menu;
ContainerOperator<?> menuCont;
if (parentPath.length > 0) {
menu = (JMenu) pushMenu(getParentPath(choosers));
menuCont = new ContainerOperator<>(menu.getPopupMenu());
menuCont.copyEnvironment(this);
} else {
menuCont = this;
}
JMenuItemOperator result = new JMenuItemOperator(menuCont, choosers[choosers.length - 1]);
result.copyEnvironment(this);
return result;
}
/**
* Expends all menus to show menu item specified by a {@code path}
* parameter.
*
* @param path an array of menu texts.
* @param comparator a string comparision algorithm
* @return an operator for the last menu item in path.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String[] path, StringComparator comparator) {
String[] parentPath = getParentPath(path);
JMenu menu;
ContainerOperator<?> menuCont;
if (parentPath.length > 0) {
menu = (JMenu) pushMenu(getParentPath(path), comparator);
menuCont = new ContainerOperator<>(menu.getPopupMenu());
menuCont.copyEnvironment(this);
} else {
menuCont = this;
}
JMenuItemOperator result = new JMenuItemOperator(menuCont, path[path.length - 1]);
result.copyEnvironment(this);
return result;
}
/**
* Expands all menus to show menu item specified by a {@code path}
* parameter.
*
* @param path an array of menu texts.
* @return an operator for the last menu item in path.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String[] path) {
return showMenuItem(path, getComparator());
}
/**
* Expands all menus to show menu item specified by a {@code path}
* parameter.
*
* @param path a string identifying the menu path.
* @param delim a path delimiter.
* @param comparator a string comparision algorithm
* @return an operator for the last menu item in path.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String path, String delim, StringComparator comparator) {
return showMenuItem(parseString(path, delim), comparator);
}
/**
* Expands all menus to show menu item specified by a {@code path}
* parameter. Uses PathParser assigned to this operator.
*
* @param path a string identifying the menu path.
* @param comparator a string comparision algorithm
* @return an operator for the last menu item in path.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String path, StringComparator comparator) {
return showMenuItem(parseString(path), comparator);
}
/**
* Expands all menus to show menu item specified by a {@code path}
* parameter. Uses StringComparator assigned to the operator.
*
* @param path a string identifying the menu path.
* @param delim a path delimiter.
* @return an operator for the last menu item in path.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String path, String delim) {
return showMenuItem(path, delim, getComparator());
}
/**
* Expands all menus to show menu item specified by a {@code path}
* parameter. Uses PathParser assigned to this operator. Uses
* StringComparator assigned to the operator.
*
* @param path a string identifying the menu path.
* @return an array of operators created tor items from the submenu.
* @throws TimeoutExpiredException
*/
public JMenuItemOperator showMenuItem(String path) {
return showMenuItem(path, getComparator());
}
@Override
public Hashtable<String, Object> getDump() {
Hashtable<String, Object> result = super.getDump();
if (((JPopupMenu) getSource()).getLabel() != null) {
result.put(LABEL_DPROP, ((JPopupMenu) getSource()).getLabel());
}
return result;
}
////////////////////////////////////////////////////////
//Mapping //
/**
* Maps {@code JPopupMenu.add(String)} through queue
*/
public JMenuItem add(final String string) {
return (runMapping(new MapAction<JMenuItem>("add") {
@Override
public JMenuItem map() {
return ((JPopupMenu) getSource()).add(string);
}
}));
}
/**
* Maps {@code JPopupMenu.add(Action)} through queue
*/
public JMenuItem add(final javax.swing.Action action) {
return (runMapping(new MapAction<JMenuItem>("add") {
@Override
public JMenuItem map() {
return ((JPopupMenu) getSource()).add(action);
}
}));
}
/**
* Maps {@code JPopupMenu.add(JMenuItem)} through queue
*/
public JMenuItem add(final JMenuItem jMenuItem) {
return (runMapping(new MapAction<JMenuItem>("add") {
@Override
public JMenuItem map() {
return ((JPopupMenu) getSource()).add(jMenuItem);
}
}));
}
/**
* Maps {@code JPopupMenu.addPopupMenuListener(PopupMenuListener)}
* through queue
*/
public void addPopupMenuListener(final PopupMenuListener popupMenuListener) {
runMapping(new MapVoidAction("addPopupMenuListener") {
@Override
public void map() {
((JPopupMenu) getSource()).addPopupMenuListener(popupMenuListener);
}
});
}
/**
* Maps {@code JPopupMenu.addSeparator()} through queue
*/
public void addSeparator() {
runMapping(new MapVoidAction("addSeparator") {
@Override
public void map() {
((JPopupMenu) getSource()).addSeparator();
}
});
}
/**
* Maps {@code JPopupMenu.getComponentIndex(Component)} through queue
*/
public int getComponentIndex(final Component component) {
return (runMapping(new MapIntegerAction("getComponentIndex") {
@Override
public int map() {
return ((JPopupMenu) getSource()).getComponentIndex(component);
}
}));
}
/**
* Maps {@code JPopupMenu.getInvoker()} through queue
*/
public Component getInvoker() {
return (runMapping(new MapAction<Component>("getInvoker") {
@Override
public Component map() {
return ((JPopupMenu) getSource()).getInvoker();
}
}));
}
/**
* Maps {@code JPopupMenu.getLabel()} through queue
*/
public String getLabel() {
return (runMapping(new MapAction<String>("getLabel") {
@Override
public String map() {
return ((JPopupMenu) getSource()).getLabel();
}
}));
}
/**
* Maps {@code JPopupMenu.getMargin()} through queue
*/
public Insets getMargin() {
return (runMapping(new MapAction<Insets>("getMargin") {
@Override
public Insets map() {
return ((JPopupMenu) getSource()).getMargin();
}
}));
}
/**
* Maps {@code JPopupMenu.getSelectionModel()} through queue
*/
public SingleSelectionModel getSelectionModel() {
return (runMapping(new MapAction<SingleSelectionModel>("getSelectionModel") {
@Override
public SingleSelectionModel map() {
return ((JPopupMenu) getSource()).getSelectionModel();
}
}));
}
/**
* Maps {@code JPopupMenu.getSubElements()} through queue
*/
public MenuElement[] getSubElements() {
return ((MenuElement[]) runMapping(new MapAction<Object>("getSubElements") {
@Override
public Object map() {
return ((JPopupMenu) getSource()).getSubElements();
}
}));
}
/**
* Maps {@code JPopupMenu.getUI()} through queue
*/
public PopupMenuUI getUI() {
return (runMapping(new MapAction<PopupMenuUI>("getUI") {
@Override
public PopupMenuUI map() {
return ((JPopupMenu) getSource()).getUI();
}
}));
}
/**
* Maps {@code JPopupMenu.insert(Component, int)} through queue
*/
public void insert(final Component component, final int i) {
runMapping(new MapVoidAction("insert") {
@Override
public void map() {
((JPopupMenu) getSource()).insert(component, i);
}
});
}
/**
* Maps {@code JPopupMenu.insert(Action, int)} through queue
*/
public void insert(final javax.swing.Action action, final int i) {
runMapping(new MapVoidAction("insert") {
@Override
public void map() {
((JPopupMenu) getSource()).insert(action, i);
}
});
}
/**
* Maps {@code JPopupMenu.isBorderPainted()} through queue
*/
public boolean isBorderPainted() {
return (runMapping(new MapBooleanAction("isBorderPainted") {
@Override
public boolean map() {
return ((JPopupMenu) getSource()).isBorderPainted();
}
}));
}
/**
* Maps {@code JPopupMenu.isLightWeightPopupEnabled()} through queue
*/
public boolean isLightWeightPopupEnabled() {
return (runMapping(new MapBooleanAction("isLightWeightPopupEnabled") {
@Override
public boolean map() {
return ((JPopupMenu) getSource()).isLightWeightPopupEnabled();
}
}));
}
/**
* Maps {@code JPopupMenu.menuSelectionChanged(boolean)} through queue
*/
public void menuSelectionChanged(final boolean b) {
runMapping(new MapVoidAction("menuSelectionChanged") {
@Override
public void map() {
((JPopupMenu) getSource()).menuSelectionChanged(b);
}
});
}
/**
* Maps {@code JPopupMenu.pack()} through queue
*/
public void pack() {
runMapping(new MapVoidAction("pack") {
@Override
public void map() {
((JPopupMenu) getSource()).pack();
}
});
}
/**
* Maps
* {@code JPopupMenu.processKeyEvent(KeyEvent, MenuElement[], MenuSelectionManager)}
* through queue
*/
public void processKeyEvent(final KeyEvent keyEvent, final MenuElement[] menuElement, final MenuSelectionManager menuSelectionManager) {
runMapping(new MapVoidAction("processKeyEvent") {
@Override
public void map() {
((JPopupMenu) getSource()).processKeyEvent(keyEvent, menuElement, menuSelectionManager);
}
});
}
/**
* Maps
* {@code JPopupMenu.processMouseEvent(MouseEvent, MenuElement[], MenuSelectionManager)}
* through queue
*/
public void processMouseEvent(final MouseEvent mouseEvent, final MenuElement[] menuElement, final MenuSelectionManager menuSelectionManager) {
runMapping(new MapVoidAction("processMouseEvent") {
@Override
public void map() {
((JPopupMenu) getSource()).processMouseEvent(mouseEvent, menuElement, menuSelectionManager);
}
});
}
/**
* Maps {@code JPopupMenu.removePopupMenuListener(PopupMenuListener)}
* through queue
*/
public void removePopupMenuListener(final PopupMenuListener popupMenuListener) {
runMapping(new MapVoidAction("removePopupMenuListener") {
@Override
public void map() {
((JPopupMenu) getSource()).removePopupMenuListener(popupMenuListener);
}
});
}
/**
* Maps {@code JPopupMenu.setBorderPainted(boolean)} through queue
*/
public void setBorderPainted(final boolean b) {
runMapping(new MapVoidAction("setBorderPainted") {
@Override
public void map() {
((JPopupMenu) getSource()).setBorderPainted(b);
}
});
}
/**
* Maps {@code JPopupMenu.setInvoker(Component)} through queue
*/
public void setInvoker(final Component component) {
runMapping(new MapVoidAction("setInvoker") {
@Override
public void map() {
((JPopupMenu) getSource()).setInvoker(component);
}
});
}
/**
* Maps {@code JPopupMenu.setLabel(String)} through queue
*/
public void setLabel(final String string) {
runMapping(new MapVoidAction("setLabel") {
@Override
public void map() {
((JPopupMenu) getSource()).setLabel(string);
}
});
}
/**
* Maps {@code JPopupMenu.setLightWeightPopupEnabled(boolean)} through queue
*/
public void setLightWeightPopupEnabled(final boolean b) {
runMapping(new MapVoidAction("setLightWeightPopupEnabled") {
@Override
public void map() {
((JPopupMenu) getSource()).setLightWeightPopupEnabled(b);
}
});
}
/**
* Maps {@code JPopupMenu.setPopupSize(int, int)} through queue
*/
public void setPopupSize(final int i, final int i1) {
runMapping(new MapVoidAction("setPopupSize") {
@Override
public void map() {
((JPopupMenu) getSource()).setPopupSize(i, i1);
}
});
}
/**
* Maps {@code JPopupMenu.setPopupSize(Dimension)} through queue
*/
public void setPopupSize(final Dimension dimension) {
runMapping(new MapVoidAction("setPopupSize") {
@Override
public void map() {
((JPopupMenu) getSource()).setPopupSize(dimension);
}
});
}
/**
* Maps {@code JPopupMenu.setSelected(Component)} through queue
*/
public void setSelected(final Component component) {
runMapping(new MapVoidAction("setSelected") {
@Override
public void map() {
((JPopupMenu) getSource()).setSelected(component);
}
});
}
/**
* Maps {@code JPopupMenu.setSelectionModel(SingleSelectionModel)}
* through queue
*/
public void setSelectionModel(final SingleSelectionModel singleSelectionModel) {
runMapping(new MapVoidAction("setSelectionModel") {
@Override
public void map() {
((JPopupMenu) getSource()).setSelectionModel(singleSelectionModel);
}
});
}
/**
* Maps {@code JPopupMenu.setUI(PopupMenuUI)} through queue
*/
public void setUI(final PopupMenuUI popupMenuUI) {
runMapping(new MapVoidAction("setUI") {
@Override
public void map() {
((JPopupMenu) getSource()).setUI(popupMenuUI);
}
});
}
/**
* Maps {@code JPopupMenu.show(Component, int, int)} through queue
*/
public void show(final Component component, final int i, final int i1) {
runMapping(new MapVoidAction("show") {
@Override
public void map() {
((JPopupMenu) getSource()).show(component, i, i1);
}
});
}
//End of mapping //
////////////////////////////////////////////////////////
/**
* Checks component type.
*/
public static class JPopupMenuFinder extends Finder {
/**
* Constructs JPopupMenuFinder.
*
* @param sf other searching criteria.
*/
public JPopupMenuFinder(ComponentChooser sf) {
super(JPopupMenu.class, sf);
}
/**
* Constructs JPopupMenuFinder.
*/
public JPopupMenuFinder() {
super(JPopupMenu.class);
}
@Override
public boolean checkComponent(Component comp) {
return (comp.isShowing()
&& super.checkComponent(comp));
}
}
/**
* Allwos to find a window containing JPopupMenu.
*/
public static class JPopupWindowFinder implements ComponentChooser {
ComponentChooser subFinder;
ComponentChooser ppFinder;
/**
* Constructs JPopupWindowFinder.
*
* @param sf searching criteria for a JPopupMenu inside the window..
*/
public JPopupWindowFinder(ComponentChooser sf) {
subFinder = new JPopupMenuFinder(sf);
ppFinder = new ComponentChooser() {
@Override
public boolean checkComponent(Component comp) {
return (comp.isShowing()
&& comp.isVisible()
&& subFinder.checkComponent(comp));
}
@Override
public String getDescription() {
return subFinder.getDescription();
}
@Override
public String toString() {
return "JPopupMenuOperator.JPopupWindowFinder.ComponentChooser{description = " + getDescription() + '}';
}
};
}
/**
* Constructs JPopupWindowFinder.
*/
public JPopupWindowFinder() {
this(ComponentSearcher.getTrueChooser("Any JPopupWindow"));
}
@Override
public boolean checkComponent(Component comp) {
if (comp.isShowing() && comp instanceof Window) {
ComponentSearcher cs = new ComponentSearcher((Container) comp);
cs.setOutput(JemmyProperties.getCurrentOutput().createErrorOutput());
return (cs.findComponent(ppFinder)
!= null);
}
return false;
}
@Override
public String getDescription() {
return subFinder.getDescription();
}
@Override
public String toString() {
return "JPopupWindowFinder{" + "subFinder=" + subFinder + ", ppFinder=" + ppFinder + '}';
}
}
}