View Javadoc

1   //$Id: ParserTest.java 360 2009-08-09 18:20:30Z jg_hamburg $
2   /********************************************************************************
3    * DDTUnit, a Datadriven Approach to Unit- and Moduletesting
4    * Copyright (c) 2004, Joerg and Kai Gellien
5    * All rights reserved.
6    *
7    * The Software is provided under the terms of the Common Public License 1.0
8    * as provided with the distribution of DDTUnit in the file cpl-v10.html.
9    * Redistribution and use in source and binary forms, with or without
10   * modification, are permitted provided that the following conditions
11   * are met:
12   *
13   *     + Redistributions of source code must retain the above copyright
14   *       notice, this list of conditions and the following disclaimer.
15   *
16   *     + Redistributions in binary form must reproduce the above
17   *       copyright notice, this list of conditions and the following
18   *       disclaimer in the documentation and/or other materials provided
19   *       with the distribution.
20   *
21   *     + Neither the name of the authors or DDTUnit, nor the
22   *       names of its contributors may be used to endorse or promote
23   *       products derived from this software without specific prior
24   *       written permission.
25   *
26   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27   * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28   * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29   * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
30   * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
31   * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
32   * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
33   * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
34   * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
35   * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36   * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37   ********************************************************************************/
38  package junitx.ddtunit.data.processing.parser;
39  
40  import junit.framework.TestCase;
41  import junitx.ddtunit.data.TypedObject;
42  import junitx.ddtunit.data.processing.IParser;
43  import junitx.ddtunit.resources.SimpleVO;
44  
45  import org.slf4j.Logger;
46  import org.slf4j.LoggerFactory;
47  
48  /**
49   * Read object definition from xml resource and generate single object instance.
50   * 
51   * @author jg
52   */
53  public class ParserTest extends TestCase {
54      private String expectedString = "Hallo obj5";
55  
56      private int expectedInt = 4711;
57  
58      private String objDef = "<obj id=\"myObj\" type=\"string\">"
59              + expectedString + "</obj>";
60  
61      private String obj2Def = "<obj id=\"myObj\" type=\"junitx.ddtunit.resources.SimpleVO\">"
62              + "<stringValue>" + expectedString + "</stringValue>" + "</obj>";
63  
64      private String obj3Def = "<obj id=\"myObj\" baseid=\"obj5\" "
65              + "type=\"junitx.ddtunit.resources.SimpleVO\">" + "<integerValue>"
66              + expectedInt + "</integerValue>" + "</obj>";
67  
68      private static final String XML_HEADER = "<?xml version=\"1.0\"?>";
69  
70      public ParserTest(String name) {
71          super(name);
72  //        BasicConfigurator.configure();
73      }
74  
75      /*
76       * Read in object definition as defined in xml resource for a single
77       * &lt;obj&gt; definition and instanciate appropriate object.
78       */
79      public void testParseElementFromStringBufferAutoHeader() {
80          IParser parser = new ParserImpl();
81          TypedObject myObj = parser.parseElement(objDef, true);
82          assertEquals("Wrong object generated", expectedString, myObj.getValue());
83      }
84  
85      /*
86       * Read in object definition as defined in xml resource for a single
87       * &lt;obj&gt; definition and instanciate appropriate object.
88       */
89      public void testParseElementFromStringBufferPredefinedHeader() {
90          IParser parser = new ParserImpl();
91          TypedObject myObj = parser.parseElement(obj2Def, true);
92          assertNotNull("Generated object should not be null", myObj);
93          assertNotNull("Generated value should not be null", myObj.getValue());
94          SimpleVO simple = (SimpleVO) myObj.getValue();
95          assertEquals("Wrong object generated", expectedString, simple
96              .getStringValue());
97      }
98  }