Package org.apache.jmeter.gui
Class GuiPackage
java.lang.Object
org.apache.jmeter.gui.GuiPackage
- All Implemented Interfaces:
UndoHistory.HistoryListener,LocaleChangeListener
public final class GuiPackage
extends Object
implements LocaleChangeListener, UndoHistory.HistoryListener
GuiPackage is a static class that provides convenient access to information
about the current state of JMeter's GUI. Any GUI class can grab a handle to
GuiPackage by calling the static method
getInstance() and then use
it to query the GUI about it's state. When actions, for instance, need to
affect the GUI, they typically use GuiPackage to get access to different
parts of the GUI.-
Method Summary
Modifier and TypeMethodDescriptionaddSubTree(HashTree subTree) Add a subtree to the currently selected node.voidaddTestPlanListener(TestPlanListener listener) Adds a test plan listener.voidBegin a group of actions modeled as 1 undobooleancanRedo()booleancanUndo()voidClears the test plan and associated objects.voidclearTestPlan(org.apache.jmeter.testelement.TestElement element) Clears the test plan element and associated objectorg.apache.jmeter.testelement.TestElementcreateTestElement(Class<?> guiClass, Class<?> testClass) Create a TestElement corresponding to the specified GUI class.org.apache.jmeter.testelement.TestElementcreateTestElement(String objClass) Create a TestElement for a GUI or TestBean class.voiddisplayPopUp(Component invoker, MouseEvent e, JPopupMenu popup) Display the specified popup menu at the location specified by a mouse event with the specified source component.voiddisplayPopUp(MouseEvent e, JPopupMenu popup) Display the specified popup menu with the source component and location from the specified mouse event.voidEnd a group of actions modeled as 1 undoorg.apache.jmeter.testelement.TestElementConvenience method for grabbing the gui for the current node.Get the currently selected subtree.getGui(org.apache.jmeter.testelement.TestElement node) Get a JMeterGUIComponent for the specified test element.Get a JMeterGUIComponent for the specified test element.static GuiPackageRetrieve the singleton GuiPackage instance.ReturnGuiLogEventBus.Get the main JMeter frame.Get the main JMeter toolbar.Get the menu item LoggerPanel.Get the menu item SaveBeforeRunPanel.getNodeOf(org.apache.jmeter.testelement.TestElement userObject) Find the JMeterTreeNode for a certain TestElement object.Get a ValueReplacer for the test tree.Get the listener for JMeter's test tree.Get the model for JMeter's test tree.static voidinitInstance(JMeterTreeListener listener, JMeterTreeModel treeModel) When GuiPackage is requested for the first time, it should be given handles to JMeter's Tree Listener and TreeModel.voidbooleanisDirty()Retrieves the state of the 'dirty' property, a flag that indicates if there are test tree components that have been modified since they were last saved.voidlocaleChanged(LocaleChangeEvent event) voidnotifyChangeInHistory(UndoHistory history) Called when history changes, it updates toolbarvoidredo()Navigate forward through undo historyvoidRefresh GUI from node state.voidRegister process to stop on reloadvoidRegister as listener of: - UndoHistory - Locale ChangesvoidremoveNode(org.apache.jmeter.testelement.TestElement node) Remove a test element from the tree.voidremoveTestPlanListener(TestPlanListener listener) Removes a test plan listener.voidsetDirty(boolean dirty) The dirty property is a flag that indicates whether there are parts of JMeter's test tree that the user has not saved since last modification.voidsetLoggerPanel(LoggerPanel loggerPanel) voidsetMainFrame(MainFrame newMainFrame) Set the main JMeter frame.voidsetMainToolbar(JToolBar newToolbar) Set the main JMeter toolbar.voidsetMenuItemLoggerPanel(JCheckBoxMenuItem menuItemLoggerPanel) Set the menu item LoggerPanel.voidsetMenuItemSaveBeforeRunPanel(JCheckBoxMenuItem menuItemSaveBeforeRunPanel) Set the menu item SaveBeforeRunPanel.voidsetSaveBeforeRunByPreference(boolean saveBeforeRun) Should Save Before Run by Preference OnlyvoidSets the filepath of the current test plan.booleanShould Save Before Run Decide by Preference and if not exists by PropertybooleanShould Save Before Run by Preference Onlystatic voidshowErrorMessage(String message, String title) static voidshowInfoMessage(String message, String title) static voidshowMessage(String message, String title, int type) static voidshowWarningMessage(String message, String title) voidundo()Navigate back through undo historyvoidunregister(Stoppable stoppableToUnregister) Unregister stoppablevoidUpdate the GUI for the currently selected node.voidThis method should be called in order for GuiPackage to change the current node.voidTells hidden GUI components to update UIs when they are shown.
-
Method Details
-
getInstance
Retrieve the singleton GuiPackage instance.- Returns:
- the GuiPackage instance (may be null, e.g in non-Gui mode)
-
registerAsListener
public void registerAsListener()Register as listener of: - UndoHistory - Locale Changes -
initInstance
When GuiPackage is requested for the first time, it should be given handles to JMeter's Tree Listener and TreeModel.- Parameters:
listener- the TreeListener for JMeter's test treetreeModel- the model for JMeter's test tree
-
getGui
Get a JMeterGUIComponent for the specified test element. If the GUI has already been created, that instance will be returned. Otherwise, if a GUI component of the same type has been created, and the component is not marked as anUnsharedComponent, that shared component will be returned. Otherwise, a new instance of the component will be created. The TestElement's GUI_CLASS property will be used to determine the appropriate type of GUI component to use.- Parameters:
node- the test element which this GUI is being created for- Returns:
- the GUI component corresponding to the specified test element
-
getGui
public JMeterGUIComponent getGui(org.apache.jmeter.testelement.TestElement node, Class<?> guiClass, Class<?> testClass) Get a JMeterGUIComponent for the specified test element. If the GUI has already been created, that instance will be returned. Otherwise, if a GUI component of the same type has been created, and the component is not marked as anUnsharedComponent, that shared component will be returned. Otherwise, a new instance of the component will be created.- Parameters:
node- the test element which this GUI is being created forguiClass- the fully qualified class name of the GUI component which will be created if it doesn't already existtestClass- the fully qualified class name of the test elements which have to be edited by the returned GUI component- Returns:
- the GUI component corresponding to the specified test element
-
removeNode
@API(since="5.3", status=MAINTAINED) public void removeNode(org.apache.jmeter.testelement.TestElement node) Remove a test element from the tree. This removes the reference to any associated GUI component.- Parameters:
node- the test element being removed
-
getCurrentGui
Convenience method for grabbing the gui for the current node.- Returns:
- the GUI component associated with the currently selected node
-
getNodeOf
Find the JMeterTreeNode for a certain TestElement object.- Parameters:
userObject- the test element to search for- Returns:
- the tree node associated with the test element
-
createTestElement
public org.apache.jmeter.testelement.TestElement createTestElement(Class<?> guiClass, Class<?> testClass) Create a TestElement corresponding to the specified GUI class.- Parameters:
guiClass- the fully qualified class name of the GUI component or a TestBean class for TestBeanGUIs.testClass- the fully qualified class name of the test elements edited by this GUI component.- Returns:
- the test element corresponding to the specified GUI class.
-
createTestElement
Create a TestElement for a GUI or TestBean class.This is a utility method to help actions do with one single String parameter.
- Parameters:
objClass- the fully qualified class name of the GUI component or of the TestBean subclass for which a TestBeanGUI is wanted.- Returns:
- the test element corresponding to the specified GUI class.
-
updateCurrentGui
public void updateCurrentGui()Update the GUI for the currently selected node. The GUI component is configured to reflect the settings in the current tree node. -
refreshCurrentGui
public void refreshCurrentGui()Refresh GUI from node state. This method does not update the current node from GUI at the difference ofupdateCurrentGui() -
updateCurrentNode
public void updateCurrentNode()This method should be called in order for GuiPackage to change the current node. This will save any changes made to the earlier node before choosing the new node. -
getCurrentNode
-
getCurrentElement
public org.apache.jmeter.testelement.TestElement getCurrentElement() -
setDirty
public void setDirty(boolean dirty) The dirty property is a flag that indicates whether there are parts of JMeter's test tree that the user has not saved since last modification. VariousCommandactions set this property when components are modified/created/saved.- Parameters:
dirty- the new value of the dirty flag
-
isDirty
public boolean isDirty()Retrieves the state of the 'dirty' property, a flag that indicates if there are test tree components that have been modified since they were last saved.- Returns:
- true if some tree components have been modified since they were last saved, false otherwise
-
addSubTree
Add a subtree to the currently selected node.- Parameters:
subTree- the subtree to add.- Returns:
- the resulting subtree starting with the currently selected node
- Throws:
IllegalUserActionException- if a subtree cannot be added to the currently selected node
-
getCurrentSubTree
Get the currently selected subtree.- Returns:
- the subtree of the currently selected node
-
getTreeModel
Get the model for JMeter's test tree.- Returns:
- the JMeter tree model
-
getReplacer
Get a ValueReplacer for the test tree.- Returns:
- a ValueReplacer configured for the test tree
-
setMainFrame
Set the main JMeter frame.- Parameters:
newMainFrame- the new JMeter main frame
-
getMainFrame
Get the main JMeter frame.- Returns:
- the main JMeter frame
-
getTreeListener
Get the listener for JMeter's test tree.- Returns:
- the JMeter test tree listener
-
setMainToolbar
Set the main JMeter toolbar.- Parameters:
newToolbar- the new JMeter main toolbar
-
getMainToolbar
Get the main JMeter toolbar.- Returns:
- the main JMeter toolbar
-
displayPopUp
Display the specified popup menu with the source component and location from the specified mouse event.- Parameters:
e- the mouse event causing this popup to be displayedpopup- the popup menu to display
-
displayPopUp
Display the specified popup menu at the location specified by a mouse event with the specified source component.- Parameters:
invoker- the source componente- the mouse event causing this popup to be displayedpopup- the popup menu to display
-
localeChanged
- Specified by:
localeChangedin interfaceLocaleChangeListener
-
invalidateCachedUi
public void invalidateCachedUi() -
updateUIForHiddenComponents
@API(since="5.3", status=EXPERIMENTAL) public void updateUIForHiddenComponents()Tells hidden GUI components to update UIs when they are shown.When Look and Feel (or zoom scaling) changes, only visible components are updated. The hidden ones are updated as they are shown.
-
setTestPlanFile
Sets the filepath of the current test plan. It's shown in the main frame title and used on saving.- Parameters:
f- The filepath of the current test plan
-
getTestPlanFile
-
clearTestPlan
public void clearTestPlan()Clears the test plan and associated objects. Clears the test plan file name. -
clearTestPlan
public void clearTestPlan(org.apache.jmeter.testelement.TestElement element) Clears the test plan element and associated object- Parameters:
element- to clear
-
showErrorMessage
-
showInfoMessage
-
showWarningMessage
-
showMessage
-
unregister
Unregister stoppable- Parameters:
stoppableToUnregister- Stoppable to unregister
-
register
Register process to stop on reload- Parameters:
stoppable- TheStoppableto be registered
-
getStoppables
- Returns:
- copy of list of
Stoppables
-
setMenuItemLoggerPanel
Set the menu item LoggerPanel.- Parameters:
menuItemLoggerPanel- The menu item LoggerPanel
-
getMenuItemLoggerPanel
Get the menu item LoggerPanel.- Returns:
- the menu item LoggerPanel
-
setMenuItemSaveBeforeRunPanel
Set the menu item SaveBeforeRunPanel.- Parameters:
menuItemSaveBeforeRunPanel- The menu item SaveBeforeRunPanel
-
getMenuItemSaveBeforeRunPanel
Get the menu item SaveBeforeRunPanel.- Returns:
- the menu item SaveBeforeRunPanel
-
setLoggerPanel
- Parameters:
loggerPanel- LoggerPanel
-
getLoggerPanel
- Returns:
- the loggerPanel
-
undo
public void undo()Navigate back through undo history -
redo
public void redo()Navigate forward through undo history -
canRedo
public boolean canRedo()- Returns:
- true if history contains redo item
-
canUndo
public boolean canUndo()- Returns:
- true if history contains undo item
-
notifyChangeInHistory
Called when history changes, it updates toolbar- Specified by:
notifyChangeInHistoryin interfaceUndoHistory.HistoryListener
-
getNamingPolicy
- Returns:
TreeNodeNamingPolicy
-
getLogEventBus
ReturnGuiLogEventBus.- Returns:
GuiLogEventBus
-
beginUndoTransaction
public void beginUndoTransaction()Begin a group of actions modeled as 1 undo -
endUndoTransaction
public void endUndoTransaction()End a group of actions modeled as 1 undo -
shouldSaveBeforeRunByPreference
public boolean shouldSaveBeforeRunByPreference()Should Save Before Run by Preference Only- Returns:
- boolean
-
setSaveBeforeRunByPreference
public void setSaveBeforeRunByPreference(boolean saveBeforeRun) Should Save Before Run by Preference Only- Parameters:
saveBeforeRun- boolean
-
shouldSaveBeforeRun
public boolean shouldSaveBeforeRun()Should Save Before Run Decide by Preference and if not exists by Property- Returns:
- boolean Should Save Before Run
-
addTestPlanListener
Adds a test plan listener.- Parameters:
listener- to add
-
removeTestPlanListener
Removes a test plan listener.- Parameters:
listener- to remove
-