Package org.apache.jmeter.config.gui
Class ArgumentsPanel
java.lang.Object
java.awt.Component
java.awt.Container
javax.swing.JComponent
javax.swing.JPanel
org.apache.jmeter.gui.AbstractJMeterGuiComponent
org.apache.jmeter.config.gui.AbstractConfigGui
org.apache.jmeter.config.gui.ArgumentsPanel
- All Implemented Interfaces:
ActionListener
,ImageObserver
,MenuContainer
,Serializable
,EventListener
,Accessible
,ClearGui
,JMeterGUIComponent
,Printable
- Direct Known Subclasses:
HTTPArgumentsPanel
A GUI panel allowing the user to enter name-value argument pairs. These
arguments (or parameters) are usually used to provide configuration values
for some other component.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class javax.swing.JPanel
JPanel.AccessibleJPanel
Nested classes/interfaces inherited from class javax.swing.JComponent
JComponent.AccessibleJComponent
Nested classes/interfaces inherited from class java.awt.Container
Container.AccessibleAWTContainer
Nested classes/interfaces inherited from class java.awt.Component
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
static final String
static final String
protected ObjectTableModel
The model for the arguments table.Fields inherited from class org.apache.jmeter.gui.AbstractJMeterGuiComponent
bindingGroup, namePanel
Fields inherited from class javax.swing.JComponent
listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
Fields inherited from class java.awt.Component
accessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
Fields inherited from interface java.awt.image.ImageObserver
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
-
Constructor Summary
ConstructorDescriptionCreate a new ArgumentsPanel as a standalone component.ArgumentsPanel
(boolean disableButtons, String label) Create a new ArgumentsPanel as an embedded component, using the specified title.ArgumentsPanel
(String label) Create a new ArgumentsPanel as an embedded component, using the specified title.ArgumentsPanel
(String label, boolean enableUpDown) Create a new ArgumentsPanel as an embedded component, using the specified title.ArgumentsPanel
(String label, Color bkg) Create a new ArgumentsPanel with a border and color backgroundArgumentsPanel
(String label, Color bkg, boolean enableUpDown, boolean standalone) Create a new ArgumentsPanel with a border and color backgroundArgumentsPanel
(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model) Create a new ArgumentsPanel with a border and color backgroundArgumentsPanel
(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, boolean disableButtons) Create a new ArgumentsPanel with a border and color backgroundArgumentsPanel
(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, boolean disableButtons, Function<String[], ? extends Argument> argCreator) Create a new ArgumentsPanel with a border and color backgroundArgumentsPanel
(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, Function<String[], Argument> argCreator) Create a new ArgumentsPanel with a border and color background -
Method Summary
Modifier and TypeMethodDescriptionvoid
Invoked when an action occurs.protected void
Add a new argument row to the table.protected void
protected void
addFromClipboard
(String lineDelimiter, String argDelimiter) Add values from the clipboardprotected void
void
clear()
Clear all rows from the table.void
Clear border around "table with arguments".void
clearGui()
Provides a default implementation that resets the name field to the value of getStaticLabel(), reset comment and sets enabled to true.void
configure
(org.apache.jmeter.testelement.TestElement el) A newly created component can be initialized with the contents of a Test Element object by calling this method.protected Argument
createArgumentFromClipboard
(String[] clipboardCols) org.apache.jmeter.testelement.TestElement
JMeter test components are separated into a model and a GUI representation.protected void
Remove the currently selected argument from the table.protected JButton
Get the button used to add rows to the table.protected JButton
Get the button used to delete rows from the table.Get the component's resource name, which getStaticLabel uses to derive the component's label in the local language.This is the list of menu categories this gui component will be available under.protected JTable
getTable()
Get the table used to enter arguments.protected JLabel
Get the title label for this component.protected void
Initialize the table model used for the arguments table.protected Component
Create a panel containing the title label for the table.protected Argument
Create a new Argument object.void
modifyTestElement
(org.apache.jmeter.testelement.TestElement args) GUI components are responsible for populating TestElements they create with the data currently held in the GUI components.protected void
sizeColumns
(JTable _table) Resize the table columns to appropriate widths.protected void
Stop any editing that is currently being done on the table.static boolean
Methods inherited from class org.apache.jmeter.config.gui.AbstractConfigGui
createPopupMenu
Methods inherited from class org.apache.jmeter.gui.AbstractJMeterGuiComponent
configureTestElement, createTitleLabel, getComment, getDocAnchor, getName, getNamePanel, getPrintableComponent, getStaticLabel, isEnabled, makeBorder, makeScrollPane, makeScrollPane, makeTitlePanel, setComment, setEnabled, setName, wrapTitlePanel
Methods inherited from class javax.swing.JPanel
getAccessibleContext, getUI, getUIClassID, paramString, setUI, updateUI
Methods inherited from class javax.swing.JComponent
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, getBaseline, getBaselineResizeBehavior, getBorder, getBounds, getClientProperty, getComponentGraphics, getComponentPopupMenu, getConditionForKeyStroke, getDebugGraphicsOptions, getDefaultLocale, getFontMetrics, getGraphics, getHeight, getInheritsPopupMenu, getInputMap, getInputMap, getInputVerifier, getInsets, getInsets, getListeners, getLocation, getMaximumSize, getMinimumSize, getNextFocusableComponent, getPopupLocation, getPreferredSize, getRegisteredKeyStrokes, getRootPane, getSize, getToolTipLocation, getToolTipText, getToolTipText, getTopLevelAncestor, getTransferHandler, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, hide, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingOrigin, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeNotify, removeVetoableChangeListener, repaint, repaint, requestDefaultFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, resetKeyboardActions, reshape, revalidate, scrollRectToVisible, setActionMap, setAlignmentX, setAlignmentY, setAutoscrolls, setBackground, setBorder, setComponentPopupMenu, setDebugGraphicsOptions, setDefaultLocale, setDoubleBuffered, setFocusTraversalKeys, setFont, setForeground, setInheritsPopupMenu, setInputMap, setInputVerifier, setMaximumSize, setMinimumSize, setNextFocusableComponent, setOpaque, setPreferredSize, setRequestFocusEnabled, setToolTipText, setTransferHandler, setUI, setVerifyInputWhenFocusTarget, setVisible, unregisterKeyboardAction, update
Methods inherited from class java.awt.Container
add, add, add, add, add, addContainerListener, addImpl, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, getMousePosition, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setComponentZOrder, setFocusCycleRoot, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setLayout, transferFocusDownCycle, validate, validateTree
Methods inherited from class java.awt.Component
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBackground, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getForeground, getGraphicsConfiguration, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, postEvent, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setMixingCutoutShape, setSize, setSize, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.apache.jmeter.gui.JMeterGUIComponent
assignDefaultValues, canBeAdded, makeTestElement
-
Field Details
-
tableModel
The model for the arguments table. -
COLUMN_RESOURCE_NAMES_0
- See Also:
-
COLUMN_RESOURCE_NAMES_1
- See Also:
-
COLUMN_RESOURCE_NAMES_2
- See Also:
-
-
Constructor Details
-
ArgumentsPanel
public ArgumentsPanel()Create a new ArgumentsPanel as a standalone component. -
ArgumentsPanel
Create a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
label
- the title for the component.
-
ArgumentsPanel
Create a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
label
- the title for the component.enableUpDown
- Add up/down buttons
-
ArgumentsPanel
Create a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
disableButtons
- Remove Edit all buttonslabel
- the title for the component.
-
ArgumentsPanel
Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colour
-
ArgumentsPanel
Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colourenableUpDown
- Add up/down buttonsstandalone
- is standalone
-
ArgumentsPanel
public ArgumentsPanel(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model) Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colourenableUpDown
- Add up/down buttonsstandalone
- is standalonemodel
- the table model to use
-
ArgumentsPanel
public ArgumentsPanel(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, Function<String[], Argument> argCreator) Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colourenableUpDown
- Add up/down buttonsstandalone
- is standalonemodel
- the table model to useargCreator
- function to createArgument
s from Strings taken from clipboard
-
ArgumentsPanel
public ArgumentsPanel(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, boolean disableButtons) Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colourenableUpDown
- Add up/down buttonsstandalone
- is standalonemodel
- the table model to usedisableButtons
- Remove all buttons
-
ArgumentsPanel
public ArgumentsPanel(String label, Color bkg, boolean enableUpDown, boolean standalone, ObjectTableModel model, boolean disableButtons, Function<String[], ? extends Argument> argCreator) Create a new ArgumentsPanel with a border and color background- Parameters:
label
- text for labelbkg
- background colourenableUpDown
- Add up/down buttonsstandalone
- is standalonemodel
- the table model to usedisableButtons
- Remove all buttonsargCreator
- function to createArgument
s from Strings taken from clipboard
-
-
Method Details
-
getMenuCategories
This is the list of menu categories this gui component will be available under.- Specified by:
getMenuCategories
in interfaceJMeterGUIComponent
- Overrides:
getMenuCategories
in classAbstractConfigGui
- Returns:
- a Collection of Strings, where each element is one of the constants defined in MenuFactory
- See Also:
-
getLabelResource
Description copied from interface:JMeterGUIComponent
Get the component's resource name, which getStaticLabel uses to derive the component's label in the local language. The resource name is fixed, and does not vary with the selected language.Normally this method should be overridden in preference to overriding getStaticLabel(). However where the resource name is not available or required, getStaticLabel() may be overridden instead.
- Specified by:
getLabelResource
in interfaceJMeterGUIComponent
- Returns:
- the resource name
-
createTestElement
public org.apache.jmeter.testelement.TestElement createTestElement()Description copied from interface:JMeterGUIComponent
JMeter test components are separated into a model and a GUI representation. The model holds the data and the GUI displays it. The GUI class is responsible for knowing how to create and initialize with data the model class that it knows how to display, and this method is called when new test elements are created.Since 5.6.3, the default implementation is as follows, and subclasses should override
JMeterGUIComponent.makeTestElement()
public TestElement createTestElement() { TestElement element = makeTestElement(); assignDefaultValues(element); return el; }
Before 5.6.3 the canonical implementation was as follows, however, it is recommended to avoid overriding
JMeterGUIComponent.createTestElement()
and overrideJMeterGUIComponent.makeTestElement()
instead.public TestElement createTestElement() { TestElementXYZ el = new TestElementXYZ(); modifyTestElement(el); return el; }
- Specified by:
createTestElement
in interfaceJMeterGUIComponent
- Returns:
- the Test Element object that the GUI component represents.
-
modifyTestElement
public void modifyTestElement(org.apache.jmeter.testelement.TestElement args) Description copied from interface:JMeterGUIComponent
GUI components are responsible for populating TestElements they create with the data currently held in the GUI components. This method should overwrite whatever data is currently in the TestElement as it is called after a user has filled out the form elements in the gui with new information.If you override
AbstractJMeterGuiComponent
, you might want usingAbstractJMeterGuiComponent.bindingGroup
instead of overridingmodifyTestElement
.The canonical implementation looks like this:
@Override public void modifyTestElement(TestElement element) { super.modifyTestElement(element); // clear the element and assign basic fields like name, gui class, test class // Using the element setters (preferred): // If the field is empty, you probably want to remove the property instead of storing an empty string // See Streamline binding of UI elements to TestElement properties // for more details TestElementXYZ xyz = (TestElementXYZ) element; xyz.setState(StringUtils.defaultIfEmpty(guiState.getText(), null)); xyz.setCode(StringUtils.defaultIfEmpty(guiCode.getText(), null)); ... other GUI fields ... // or directly (do not use unless there is no setter for the field): element.setProperty(TestElementXYZ.STATE, StringUtils.defaultIfEmpty(guiState.getText(), null)) element.setProperty(TestElementXYZ.CODE, StringUtils.defaultIfEmpty(guiCode.getText(), null)) ... other GUI fields ... }
- Specified by:
modifyTestElement
in interfaceJMeterGUIComponent
- Overrides:
modifyTestElement
in classAbstractJMeterGuiComponent
- Parameters:
args
- the TestElement to modify
-
configure
public void configure(org.apache.jmeter.testelement.TestElement el) A newly created component can be initialized with the contents of a Test Element object by calling this method. The component is responsible for querying the Test Element object for the relevant information to display in its GUI.- Specified by:
configure
in interfaceJMeterGUIComponent
- Overrides:
configure
in classAbstractJMeterGuiComponent
- Parameters:
el
- the TestElement to configure
-
getTable
Get the table used to enter arguments.- Returns:
- the table used to enter arguments
-
getTableLabel
Get the title label for this component.- Returns:
- the title label displayed with the table
-
getDeleteButton
Get the button used to delete rows from the table.- Returns:
- the button used to delete rows from the table
-
getAddButton
Get the button used to add rows to the table.- Returns:
- the button used to add rows to the table
-
checkButtonsStatus
protected void checkButtonsStatus() -
clearGui
public void clearGui()Description copied from class:AbstractJMeterGuiComponent
Provides a default implementation that resets the name field to the value of getStaticLabel(), reset comment and sets enabled to true. Your GUI may need more things cleared, in which case you should override, clear the extra fields, and still call super.clearGui().- Specified by:
clearGui
in interfaceClearGui
- Overrides:
clearGui
in classAbstractJMeterGuiComponent
-
clear
public void clear()Clear all rows from the table. T.Elanjchezhiyan(chezhiyan@siptech.co.in) -
actionPerformed
Invoked when an action occurs. This implementation supports the add and delete buttons.- Specified by:
actionPerformed
in interfaceActionListener
- Parameters:
e
- the event that has occurred
-
deleteArgument
protected void deleteArgument()Remove the currently selected argument from the table. -
addArgument
protected void addArgument()Add a new argument row to the table. -
addFromClipboard
Add values from the clipboard- Parameters:
lineDelimiter
- Delimiter string to split clipboard into linesargDelimiter
- Delimiter string to split line into key-value pair
-
addFromClipboard
protected void addFromClipboard() -
createArgumentFromClipboard
-
makeNewArgument
Create a new Argument object.- Returns:
- a new Argument object
-
stopTableEditing
protected void stopTableEditing()Stop any editing that is currently being done on the table. This will save any changes that have already been made. Needed for subclasses -
initializeTableModel
protected void initializeTableModel()Initialize the table model used for the arguments table. -
testFunctors
public static boolean testFunctors() -
sizeColumns
Resize the table columns to appropriate widths.- Parameters:
_table
- the table to resize columns for
-
makeLabelPanel
Create a panel containing the title label for the table.- Returns:
- a panel containing the title label
-
clearBorderForMainPanel
public void clearBorderForMainPanel()Clear border around "table with arguments". Extra border is not required when the panel is already surrounded by a border.
-