Clover coverage report - JFCUnit Test Coverage
Coverage timestamp: Mon Dec 20 2004 23:38:10 MST
file stats: LOC: 179   Methods: 4
NCLOC: 40   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
JSpinnerMouseEventDataTagHandler.java 0% 0% 0% 0%
coverage
 1   
 package junit.extensions.jfcunit.eventdata;
 2   
 
 3   
 import junit.extensions.xml.IXMLTestCase;
 4   
 import junit.extensions.xml.XMLException;
 5   
 
 6   
 import org.w3c.dom.Element;
 7   
 
 8   
 
 9   
 /**
 10   
  * This is a extension of the click and drag elements. Where the
 11   
  * type specified is JSpinnerMouseEventData.
 12   
  *
 13   
  * <h3>Description</h3>
 14   
  * <p>
 15   
  *   Nothing is invoked directly by this tag handler. The click and drag elements
 16   
  *   use this tag handler to customize the data specificly for the type specified.
 17   
  * </p>
 18   
  *
 19   
  * <h3>Parameters</h3>
 20   
  * <table border="1" cellpadding="2" cellspacing="0">
 21   
  *   <tr>
 22   
  *     <td valign="top"><b>Attribute</b></td>
 23   
  *     <td valign="top"><b>Description</b></td>
 24   
  *     <td align="center" valign="top"><b>Required</b></td>
 25   
  *     <td valign="top"><b>Default</b></td>
 26   
  *     <td valign="top"><b>Values</b></td>
 27   
  *   </tr>
 28   
  *   <tr>
 29   
  *     <td valign="top">type</td>
 30   
  *     <td valign="top">For this element the type must be set to JSpinnerMouseEventData</td>
 31   
  *     <td valign="top" align="center">Yes</td>
 32   
  *     <td valign="top">N/A</td>
 33   
  *     <td valign="top">N/A</td>
 34   
  *   </tr>
 35   
  *   <tr>
 36   
  *     <td valign="top">refid</td>
 37   
  *     <td valign="top">Id of a object reference which has been previously found.</td>
 38   
  *     <td valign="top" align="center">Yes</td>
 39   
  *     <td valign="top">N/A</td>
 40   
  *     <td valign="top">N/A</td>
 41   
  *   </tr>
 42   
  *   <tr>
 43   
  *     <td valign="top">sub</td>
 44   
  *     <td valign="top">The sub component of the spinner</td>
 45   
  *     <td valign="top" align="center">Yes</td>
 46   
  *     <td valign="top">Invalid</td>
 47   
  *     <td valign="top">editor up down</td>
 48   
  *   </tr>
 49   
  *   <tr>
 50   
  *     <td valign="top">clicks</td>
 51   
  *     <td valign="top">The number of clicks to be executed.</td>
 52   
  *     <td valign="top" align="center">No</td>
 53   
  *     <td valign="top">1</td>
 54   
  *     <td valign="top">Positive Integer</td>
 55   
  *   </tr>
 56   
  *   <tr>
 57   
  *     <td valign="top">modifiers</td>
 58   
  *     <td valign="top">The modifiers to be used for this event.</td>
 59   
  *     <td valign="top" align="center">No</td>
 60   
  *     <td valign="top">Button1 if popup is false otherwise Button3</td>
 61   
  *     <td valign="top">alt altgr control meta shift button1 button2 button3</td>
 62   
  *   </tr>
 63   
  *   <tr>
 64   
  *     <td valign="top">popup</td>
 65   
  *     <td valign="top">True if this is event is using the popup button.</td>
 66   
  *     <td valign="top" align="center">No</td>
 67   
  *     <td valign="top">false</td>
 68   
  *     <td valign="top">true false</td>
 69   
  *   </tr>
 70   
  *   <tr>
 71   
  *     <td valign="top">sleeptime</td>
 72   
  *     <td valign="top">Maximum sleep time</td>
 73   
  *     <td valign="top" align="center">No</td>
 74   
  *     <td valign="top">500</td>
 75   
  *     <td valign="top">Positive Integer representing the milli-seconds</td>
 76   
  *   </tr>
 77   
  *   <tr>
 78   
  *     <td valign="top">position</td>
 79   
  *     <td valign="top">Positioning of the mouse within the bounds of the component.</td>
 80   
  *     <td valign="top" align="center">No</td>
 81   
  *     <td valign="top">center</td>
 82   
  *     <td valign="top">center north northeast east southeast south southwest west northwest custom percentage</td>
 83   
  *   </tr>
 84   
  *   <tr>
 85   
  *     <td valign="top">reference</td>
 86   
  *     <td valign="top">Reference point or number for position calculation.</td>
 87   
  *     <td valign="top" align="center">No</td>
 88   
  *     <td valign="top">null</td>
 89   
  *     <td valign="top">integers &quot;x,y&quot;</td>
 90   
  *   </tr>
 91   
  *   <tr>
 92   
  *     <td valign="top">index</td>
 93   
  *     <td valign="top">Offset into the text sub component.</td>
 94   
  *     <td valign="top" align="center">No</td>
 95   
  *     <td valign="top">-1</td>
 96   
  *     <td valign="top">integers &quot;Positive Integer representing the offset into the text.&quot;</td>
 97   
  *   </tr>
 98   
  *
 99   
  * </table>
 100   
  * <h3>Example</h3>
 101   
  * <blockquote><pre>
 102   
  * &lt;click
 103   
  *    type=&quot;JSpinnerMouseEventData&quot;
 104   
  *    refid=&quot;Spinner&quot;
 105   
  *    sub=&quot;up&quot;
 106   
  * /&gt;
 107   
  * </pre></blockquote>
 108   
  * <p>
 109   
  * The above clicks once on the center of the up arrow of the
 110   
  * spinner component identified by Spinner.
 111   
  * </p>
 112   
  * @see junit.extensions.jfcunit.eventdata.JSpinnerMouseEventData
 113   
  * @author Kevin Wilson
 114   
  */
 115   
 public class JSpinnerMouseEventDataTagHandler extends BaseEventDataTagHandler {
 116   
     /**
 117   
      * Constructor for JSpinnerMouseEventDataTagHandler.
 118   
      *
 119   
      * @param element     The element to be processed
 120   
      * @param testCase    The IXMLTestCase that uses this element
 121   
      */
 122  0
     public JSpinnerMouseEventDataTagHandler(final Element element,
 123   
         final IXMLTestCase testCase) {
 124  0
         super(element, testCase);
 125   
     }
 126   
 
 127   
     /**
 128   
      * @see junit.extensions.xml.elements.AbstractTagHandler#processElement()
 129   
      * @throws XMLException may be thrown if element is not fully understood.
 130   
      */
 131  0
     public void processElement() throws XMLException {
 132  0
         validateElement();
 133   
 
 134  0
         setEventData(
 135   
             new JSpinnerMouseEventData(
 136   
                 getJFCTestCase(),
 137   
                 getComponent(),
 138   
                 getSubComponent(),
 139   
                 getClicks(),
 140   
                 getModifiers(),
 141   
                 getPopupTrigger(),
 142   
                 getSleepTime(),
 143   
                 getPosition(),
 144   
                 getReference(),
 145   
                 getOffset()));
 146   
     }
 147   
 
 148   
     /**
 149   
      * @see junit.extensions.xml.elements.AbstractTagHandler#validateElement()
 150   
      * @throws XMLException may be thrown.
 151   
      */
 152  0
     public void validateElement() throws XMLException {
 153   
         // do the default validations from the super class
 154  0
         super.validateElement();
 155   
 
 156  0
         checkRequiredAttribute(SUBCOMPONENT);
 157   
     }
 158   
 
 159   
     /**
 160   
      * Returns the subcomponent that corresponds to the value of the SUBCOMPONENT attribute for this
 161   
      * element. Defaults to INVALID_SUBCOMPONENT if no corresponding component is found.
 162   
      * @return int  The value of the component that corresponds to the value of the SUBCOMPONENT
 163   
      * attribute, INVALID_SUBCOMPONENT if not found.
 164   
      */
 165  0
     protected int getSubComponent() {
 166  0
         String sub = getString(SUBCOMPONENT);
 167   
 
 168  0
         if (UP.equals(sub)) {
 169  0
             return UP_ARROW_SUBCOMPONENT;
 170  0
         } else if (DOWN.equals(sub)) {
 171  0
             return DOWN_ARROW_SUBCOMPONENT;
 172  0
         } else if (EDITOR.equals(sub)) {
 173  0
             return EDITOR_SUBCOMPONENT;
 174   
         }
 175   
 
 176  0
         return INVALID_SUBCOMPONENT;
 177   
     }
 178   
 }
 179