Class JUnitTestSamplerGui

All Implemented Interfaces:
ActionListener, ItemListener, ImageObserver, MenuContainer, Serializable, EventListener, Accessible, ChangeListener, ClearGui, JMeterGUIComponent, Printable

public class JUnitTestSamplerGui extends AbstractSamplerGui implements ChangeListener, ActionListener, ItemListener
The JUnitTestSamplerGui class provides the user interface for the JUnitSampler.
See Also:
  • Constructor Details

    • JUnitTestSamplerGui

      public JUnitTestSamplerGui()
      Constructor for JUnitTestSamplerGui
  • Method Details

    • getLabelResource

      public String 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 interface JMeterGUIComponent
      Returns:
      the resource name
    • clearGui

      public void clearGui()
      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 interface ClearGui
      Overrides:
      clearGui in class AbstractJMeterGuiComponent
    • createTestElement

      public org.apache.jmeter.testelement.TestElement createTestElement()
      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.

      The canonical implementation looks like this:

       public TestElement createTestElement() {
           TestElementXYZ el = new TestElementXYZ();
           modifyTestElement(el);
           return el;
       }
       
      Specified by:
      createTestElement in interface JMeterGUIComponent
      Returns:
      the Test Element object that the GUI component represents.
    • modifyTestElement

      public void modifyTestElement(org.apache.jmeter.testelement.TestElement el)
      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.

      The canonical implementation looks like this:

       public void modifyTestElement(TestElement element) {
           element.clear(); // many implementations use this
           configureTestElement(element);
           // Using the element setters (preferred):
           TestElementXYZ xyz = (TestElementXYZ) element;
           xyz.setState(guiState.getText());
           xyz.setCode(guiCode.getText());
           ... other GUI fields ...
           // or directly (do not use unless there is no setter for the field):
           element.setProperty(TestElementXYZ.STATE, guiState.getText())
           element.setProperty(TestElementXYZ.CODE, guiCode.getText())
           ... other GUI fields ...
       }
       
      Specified by:
      modifyTestElement in interface JMeterGUIComponent
      Parameters:
      el - the TestElement to modify
    • configure

      public void configure(org.apache.jmeter.testelement.TestElement el)
      A newly created gui 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.

      AbstractJMeterGuiComponent provides a partial implementation of this method, setting the name of the component and its enabled status. Subclasses should override this method, performing their own configuration as needed, but also calling this super-implementation.

      Specified by:
      configure in interface JMeterGUIComponent
      Overrides:
      configure in class AbstractJMeterGuiComponent
      Parameters:
      el - the TestElement to configure
    • actionPerformed

      public void actionPerformed(ActionEvent evt)
      Handle action events for this component. This method currently handles events for the classname combo box, and sets up the associated method names.
      Specified by:
      actionPerformed in interface ActionListener
      Parameters:
      evt - the ActionEvent to be handled
    • itemStateChanged

      public void itemStateChanged(ItemEvent event)
      Handle change events: currently handles events for the JUnit4 checkbox, and sets up the relevant class names.
      Specified by:
      itemStateChanged in interface ItemListener
    • stateChanged

      public void stateChanged(ChangeEvent event)
      the current implementation checks to see if the source of the event is the filterpkg field.
      Specified by:
      stateChanged in interface ChangeListener