Class ArgumentsPanel
- All Implemented Interfaces:
- ActionListener,- ImageObserver,- MenuContainer,- Serializable,- EventListener,- Accessible,- ClearGui,- JMeterGUIComponent,- Printable
- Direct Known Subclasses:
- HTTPArgumentsPanel
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class javax.swing.JPanelJPanel.AccessibleJPanelNested classes/interfaces inherited from class javax.swing.JComponentJComponent.AccessibleJComponentNested classes/interfaces inherited from class java.awt.ContainerContainer.AccessibleAWTContainerNested classes/interfaces inherited from class java.awt.ComponentComponent.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Stringstatic final Stringstatic final Stringprotected ObjectTableModelThe model for the arguments table.Fields inherited from class org.apache.jmeter.gui.AbstractJMeterGuiComponentbindingGroup, namePanelFields inherited from class javax.swing.JComponentlistenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOWFields inherited from class java.awt.ComponentaccessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENTFields inherited from interface java.awt.image.ImageObserverABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
- 
Constructor SummaryConstructorsConstructorDescriptionCreate 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 SummaryModifier and TypeMethodDescriptionvoidInvoked when an action occurs.protected voidAdd a new argument row to the table.protected voidprotected voidaddFromClipboard(String lineDelimiter, String argDelimiter) Add values from the clipboardprotected voidvoidclear()Clear all rows from the table.voidClear border around "table with arguments".voidclearGui()Provides a default implementation that resets the name field to the value of getStaticLabel(), reset comment and sets enabled to true.voidconfigure(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 ArgumentcreateArgumentFromClipboard(String[] clipboardCols) org.apache.jmeter.testelement.TestElementJMeter test components are separated into a model and a GUI representation.protected voidRemove the currently selected argument from the table.protected JButtonGet the button used to add rows to the table.protected JButtonGet 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 JTablegetTable()Get the table used to enter arguments.protected JLabelGet the title label for this component.protected voidInitialize the table model used for the arguments table.protected ComponentCreate a panel containing the title label for the table.protected ArgumentCreate a new Argument object.voidmodifyTestElement(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 voidsizeColumns(JTable _table) Resize the table columns to appropriate widths.protected voidStop any editing that is currently being done on the table.static booleanMethods inherited from class org.apache.jmeter.config.gui.AbstractConfigGuicreatePopupMenuMethods inherited from class org.apache.jmeter.gui.AbstractJMeterGuiComponentconfigureTestElement, createTitleLabel, getComment, getDocAnchor, getName, getNamePanel, getPrintableComponent, getStaticLabel, isEnabled, makeBorder, makeScrollPane, makeScrollPane, makeTitlePanel, setComment, setEnabled, setName, wrapTitlePanelMethods inherited from class javax.swing.JPanelgetAccessibleContext, getUI, getUIClassID, paramString, setUI, updateUIMethods inherited from class javax.swing.JComponentaddAncestorListener, 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, updateMethods inherited from class java.awt.Containeradd, 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, validateTreeMethods inherited from class java.awt.Componentaction, 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, transferFocusUpCycleMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.jmeter.gui.JMeterGUIComponentassignDefaultValues, canBeAdded, makeTestElement
- 
Field Details- 
tableModelThe 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- 
ArgumentsPanelpublic ArgumentsPanel()Create a new ArgumentsPanel as a standalone component.
- 
ArgumentsPanelCreate a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
- label- the title for the component.
 
- 
ArgumentsPanelCreate a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
- label- the title for the component.
- enableUpDown- Add up/down buttons
 
- 
ArgumentsPanelCreate a new ArgumentsPanel as an embedded component, using the specified title.- Parameters:
- disableButtons- Remove Edit all buttons
- label- the title for the component.
 
- 
ArgumentsPanelCreate a new ArgumentsPanel with a border and color background- Parameters:
- label- text for label
- bkg- background colour
 
- 
ArgumentsPanelCreate a new ArgumentsPanel with a border and color background- Parameters:
- label- text for label
- bkg- background colour
- enableUpDown- Add up/down buttons
- standalone- is standalone
 
- 
ArgumentsPanelpublic 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 label
- bkg- background colour
- enableUpDown- Add up/down buttons
- standalone- is standalone
- model- the table model to use
 
- 
ArgumentsPanelpublic 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 label
- bkg- background colour
- enableUpDown- Add up/down buttons
- standalone- is standalone
- model- the table model to use
- argCreator- function to create- Arguments from Strings taken from clipboard
 
- 
ArgumentsPanelpublic 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 label
- bkg- background colour
- enableUpDown- Add up/down buttons
- standalone- is standalone
- model- the table model to use
- disableButtons- Remove all buttons
 
- 
ArgumentsPanelpublic 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 label
- bkg- background colour
- enableUpDown- Add up/down buttons
- standalone- is standalone
- model- the table model to use
- disableButtons- Remove all buttons
- argCreator- function to create- Arguments from Strings taken from clipboard
 
 
- 
- 
Method Details- 
getMenuCategoriesThis is the list of menu categories this gui component will be available under.- Specified by:
- getMenuCategoriesin interface- JMeterGUIComponent
- Overrides:
- getMenuCategoriesin class- AbstractConfigGui
- Returns:
- a Collection of Strings, where each element is one of the constants defined in MenuFactory
- See Also:
 
- 
getLabelResourceDescription copied from interface:JMeterGUIComponentGet 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:
- getLabelResourcein interface- JMeterGUIComponent
- Returns:
- the resource name
 
- 
createTestElementpublic org.apache.jmeter.testelement.TestElement createTestElement()Description copied from interface:JMeterGUIComponentJMeter 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:
- createTestElementin interface- JMeterGUIComponent
- Returns:
- the Test Element object that the GUI component represents.
 
- 
modifyTestElementpublic void modifyTestElement(org.apache.jmeter.testelement.TestElement args) Description copied from interface:JMeterGUIComponentGUI 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.bindingGroupinstead 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:
- modifyTestElementin interface- JMeterGUIComponent
- Overrides:
- modifyTestElementin class- AbstractJMeterGuiComponent
- Parameters:
- args- the TestElement to modify
 
- 
configurepublic 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:
- configurein interface- JMeterGUIComponent
- Overrides:
- configurein class- AbstractJMeterGuiComponent
- Parameters:
- el- the TestElement to configure
 
- 
getTableGet the table used to enter arguments.- Returns:
- the table used to enter arguments
 
- 
getTableLabelGet the title label for this component.- Returns:
- the title label displayed with the table
 
- 
getDeleteButtonGet the button used to delete rows from the table.- Returns:
- the button used to delete rows from the table
 
- 
getAddButtonGet the button used to add rows to the table.- Returns:
- the button used to add rows to the table
 
- 
checkButtonsStatusprotected void checkButtonsStatus()
- 
clearGuipublic void clearGui()Description copied from class:AbstractJMeterGuiComponentProvides 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:
- clearGuiin interface- ClearGui
- Overrides:
- clearGuiin class- AbstractJMeterGuiComponent
 
- 
clearpublic void clear()Clear all rows from the table. T.Elanjchezhiyan(chezhiyan@siptech.co.in)
- 
actionPerformedInvoked when an action occurs. This implementation supports the add and delete buttons.- Specified by:
- actionPerformedin interface- ActionListener
- Parameters:
- e- the event that has occurred
 
- 
deleteArgumentprotected void deleteArgument()Remove the currently selected argument from the table.
- 
addArgumentprotected void addArgument()Add a new argument row to the table.
- 
addFromClipboardAdd values from the clipboard- Parameters:
- lineDelimiter- Delimiter string to split clipboard into lines
- argDelimiter- Delimiter string to split line into key-value pair
 
- 
addFromClipboardprotected void addFromClipboard()
- 
createArgumentFromClipboard
- 
makeNewArgumentCreate a new Argument object.- Returns:
- a new Argument object
 
- 
stopTableEditingprotected 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
- 
initializeTableModelprotected void initializeTableModel()Initialize the table model used for the arguments table.
- 
testFunctorspublic static boolean testFunctors()
- 
sizeColumnsResize the table columns to appropriate widths.- Parameters:
- _table- the table to resize columns for
 
- 
makeLabelPanelCreate a panel containing the title label for the table.- Returns:
- a panel containing the title label
 
- 
clearBorderForMainPanelpublic void clearBorderForMainPanel()Clear border around "table with arguments". Extra border is not required when the panel is already surrounded by a border.
 
-