summaryrefslogtreecommitdiffstats
path: root/sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java
diff options
context:
space:
mode:
Diffstat (limited to 'sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java')
-rw-r--r--sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java271
1 files changed, 55 insertions, 216 deletions
diff --git a/sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java b/sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java
index 3ebe40846d..a30b51f3cd 100644
--- a/sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java
+++ b/sca-java-1.x/trunk/itest/wsdlgen-verify/src/test/java/wsdlgen/verify/DataTypesTestCase.java
@@ -19,72 +19,19 @@
package wsdlgen.verify;
-import java.io.BufferedReader;
-import java.io.InputStream;
-import java.io.InputStreamReader;
-import java.net.URL;
-import java.util.HashMap;
-import java.util.Map;
-
-import javax.wsdl.Binding;
-import javax.wsdl.Definition;
-import javax.wsdl.Fault;
-import javax.wsdl.Input;
-import javax.wsdl.Message;
-import javax.wsdl.Operation;
-import javax.wsdl.Output;
-import javax.wsdl.Part;
-import javax.wsdl.Port;
-import javax.wsdl.PortType;
-import javax.wsdl.Service;
-import javax.wsdl.Types;
-import javax.wsdl.extensions.ExtensibilityElement;
-import javax.wsdl.extensions.schema.Schema;
-import javax.wsdl.factory.WSDLFactory;
-import javax.wsdl.xml.WSDLReader;
-import javax.xml.namespace.QName;
-import javax.xml.transform.Result;
-import javax.xml.transform.Source;
-import javax.xml.transform.Transformer;
-import javax.xml.transform.TransformerFactory;
-import javax.xml.transform.dom.DOMSource;
-import javax.xml.transform.stream.StreamResult;
-
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNotNull;
-
-import org.w3c.dom.Attr;
import org.w3c.dom.Element;
-import org.w3c.dom.NamedNodeMap;
-import org.w3c.dom.Node;
-import org.w3c.dom.NodeList;
-
-import org.apache.tuscany.sca.host.embedded.SCADomain;
+import static org.junit.Assert.assertEquals;
/**
* Test ?wsdl works and that the returned WSDL is correct
*
* @version $Rev: 814373 $ $Date: 2009-09-13 19:06:29 +0100 (Sun, 13 Sep 2009) $
*/
-public class DataTypesTestCase {
- private static final String SCHEMA_NS = "http://www.w3.org/2001/XMLSchema";
- private static final String SCHEMA_NAME = "schema";
- private static final QName SCHEMA_QNAME = new QName(SCHEMA_NS, SCHEMA_NAME);
-
- private static SCADomain domain;
- private static Map<String, Element> schemaMap;
- private static PortType portType;
-
- private Map<String, String> prefixMap;
-
- public DataTypesTestCase() {
- // create a new instance of this for each of the tests
- prefixMap = new HashMap<String, String>();
- }
+public class DataTypesTestCase extends BaseFramework {
@Test
public void testSimpleInt() throws Exception {
@@ -98,8 +45,23 @@ public class DataTypesTestCase {
assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
}
+/*
+ @Test
+ public void testSimpleMultiArrayInt() throws Exception {
+ Element paramElement = parameterElement("testSimpleMultiArrayInt");
+ assertEquals("ns1:intArray", paramElement.getAttribute("type"));
+ assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
+ }
+*/
+
+ @Test
+ public void testList() throws Exception {
+ Element paramElement = parameterElement("testList");
+ assertEquals("xs:anyType", paramElement.getAttribute("type"));
+ assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
+ }
+
@Test
- @Ignore("TUSCANY-3799")
public void testSimpleListString() throws Exception {
Element paramElement = parameterElement("testSimpleListString");
assertEquals("xs:string", paramElement.getAttribute("type"));
@@ -107,6 +69,27 @@ public class DataTypesTestCase {
}
@Test
+ public void testReturnSimpleListString() throws Exception {
+ Element retElement = returnElement("testReturnSimpleListString");
+ assertEquals("xs:string", retElement.getAttribute("type"));
+ assertEquals("unbounded", retElement.getAttribute("maxOccurs"));
+ }
+
+ @Test
+ public void testListByteArray() throws Exception {
+ Element paramElement = parameterElement("testListByteArray");
+ assertEquals("xs:base64Binary", paramElement.getAttribute("type"));
+ assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
+ }
+
+ @Test
+ public void testListWildcard() throws Exception {
+ Element paramElement = parameterElement("testListWildcard");
+ assertEquals("xs:anyType", paramElement.getAttribute("type"));
+ assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
+ }
+
+ @Test
public void testComplex() throws Exception {
String paramType = parameterType("testComplex");
assertEquals("tns:complexNumber", paramType);
@@ -128,176 +111,32 @@ public class DataTypesTestCase {
assertEquals("xs:anyType", returnType("testDynamicSDO"));
}
- private Element parameterElement(String methodName) {
- Operation op = portType.getOperation(methodName, null, null);
- Input in = op.getInput();
- Message msg = in.getMessage();
- Part part = msg.getPart(msg.getQName().getLocalPart());
- QName elementQName = part.getElementName();
- return schemaElement(elementQName);
- }
-
- private String parameterType(String methodName) {
- return parameterElement(methodName).getAttribute("type");
- }
-
- private Element returnElement(String methodName) {
- Operation op = portType.getOperation(methodName, null, null);
- Output out = op.getOutput();
- Message msg = out.getMessage();
- Part part = msg.getPart(msg.getQName().getLocalPart());
- QName elementQName = part.getElementName();
- return schemaElement(elementQName);
- }
-
- private String returnType(String methodName) {
- return returnElement(methodName).getAttribute("type");
- }
-
- private Element faultElement(String methodName, String faultName) {
- Operation op = portType.getOperation(methodName, null, null);
- Fault fault = op.getFault(faultName);
- Message msg = fault.getMessage();
- Part part = msg.getPart(msg.getQName().getLocalPart());
- QName elementQName = part.getElementName();
- return schemaElement(elementQName);
- }
-
- private String faultType(String methodName, String faultName) {
- return faultElement(methodName, faultName).getAttribute("type");
- }
-
- private Element schemaElement(QName elementQName) {
- // find schema definition for wrapper element
- Element schema = schemaMap.get(elementQName.getNamespaceURI());
-
- // find namespace prefixes for this schema definition
- NamedNodeMap attrNodes = schema.getAttributes();
- for (int i = 0; i < attrNodes.getLength(); i++) {
- Attr attr = (Attr)attrNodes.item(i);
- String attrName = attr.getName();
- if (attrName.startsWith("xmlns:")) {
- prefixMap.put(attrName.substring(6), attr.getValue());
- }
- }
-
- // find wrapper element definition in schema
- String elementName = elementQName.getLocalPart();
- Element wrapper = null;
- NodeList childNodes = schema.getElementsByTagNameNS(SCHEMA_NS, "element");
- for (int i = 0; i < childNodes.getLength(); i++) {
- Node childNode = childNodes.item(i);
- if (childNode instanceof Element) {
- String name = ((Element)childNode).getAttribute("name");
- if (elementName.equals(name)) {
- wrapper = (Element)childNode;
- break;
- }
- }
- }
-
- // find type definition for wrapper element
- String typeName = wrapper.getAttribute("type");
- Element wrapperType = null;
- if ("".equals(typeName)) {
- childNodes = wrapper.getElementsByTagNameNS(SCHEMA_NS, "complexType");
- wrapperType = (Element)childNodes.item(0);
- } else {
- wrapperType = typeDefinition(typeName);
- }
-
- return firstChild(wrapperType);
- }
-
- private Element typeDefinition(String typeName) {
- String typePrefix = typeName.substring(0, typeName.indexOf(":"));
- String typeLocalName = typeName.substring(typeName.indexOf(":") + 1);
- Element typeSchema = schemaMap.get(prefixMap.get(typePrefix));
- Element typeElement = null;
- NodeList childNodes = typeSchema.getElementsByTagNameNS(SCHEMA_NS, "complexType");
- for (int i = 0; i < childNodes.getLength(); i++) {
- Node childNode = childNodes.item(i);
- if (childNode instanceof Element) {
- String name = ((Element)childNode).getAttribute("name");
- if (typeLocalName.equals(name)) {
- typeElement = (Element)childNode;
- break;
- }
- }
- }
- return typeElement;
- }
-
- private Element firstChild(Element complexType) {
- // find xs:sequence child element
- NodeList childNodes = complexType.getElementsByTagNameNS(SCHEMA_NS, "sequence");
- Element sequence = (Element)childNodes.item(0);
-
- // find first xs:element child element
- childNodes = sequence.getElementsByTagNameNS(SCHEMA_NS, "element");
- return (Element)childNodes.item(0);
+/*
+ @Test
+ public void testWebParam() throws Exception {
+ Element paramElement = parameterElement("testWebParam");
+ assertEquals("simpleInt", paramElement.getAttribute("name"));
+ assertEquals("xs:int", paramElement.getAttribute("type"));
}
- private static void readWSDL() throws Exception {
- if (portType == null) {
- InputStream inp = new URL("http://localhost:8085/DataTypes?wsdl").openStream();
- BufferedReader br = new BufferedReader(new InputStreamReader(inp));
- String line;
- while((line = br.readLine()) != null) {
- System.out.println(line);
- }
- br.close();
-
- WSDLReader wsdlReader = WSDLFactory.newInstance().newWSDLReader();
- wsdlReader.setFeature("javax.wsdl.verbose",false);
- wsdlReader.setFeature("javax.wsdl.importDocuments",true);
-
- Definition definition = wsdlReader.readWSDL("http://localhost:8085/DataTypes?wsdl");
- assertNotNull(definition);
-
- // find portType
- Service service = definition.getService(new QName("http://verify.wsdlgen/", "DataTypesService"));
- Port port = service.getPort("DataTypesPort");
- Binding binding = port.getBinding();
- portType = binding.getPortType();
-
- // find schema definitions
- Types types = definition.getTypes();
- schemaMap = new HashMap<String, Element>();
- for (Object ext : types.getExtensibilityElements()) {
- ExtensibilityElement extElement = (ExtensibilityElement)ext;
- if (SCHEMA_QNAME.equals(extElement.getElementType())) {
- if (extElement instanceof Schema) {
- Element schemaElement = ((Schema)extElement).getElement();
- schemaMap.put(schemaElement.getAttribute("targetNamespace"), schemaElement);
- }
- }
- }
- }
+ @Test
+ @Ignore
+ public void testWebParamArray() throws Exception {
+ Element paramElement = parameterElement("testWebParamArray");
+ assertEquals("arrayInt", paramElement.getAttribute("name"));
+ assertEquals("xs:int", paramElement.getAttribute("type"));
+ assertEquals("unbounded", paramElement.getAttribute("maxOccurs"));
}
+*/
- /*
- * Used for debugging DOM problems
- */
- private void printDOM(Node node){
- try {
- Transformer transformer = TransformerFactory.newInstance().newTransformer();
- Source source = new DOMSource(node);
- Result result = new StreamResult(System.out);
- transformer.transform(source, result);
- } catch (Exception ex){
- ex.printStackTrace();
- }
- }
@BeforeClass
public static void setUpBeforeClass() throws Exception {
- domain = SCADomain.newInstance("DataTypes.composite");
- readWSDL();
+ BaseFramework.start("DataTypes");
}
@AfterClass
public static void tearDownAfterClass() throws Exception {
- domain.close();
+ BaseFramework.stop();
}
}