You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@tuscany.apache.org by an...@apache.org on 2012/08/17 13:39:30 UTC

svn commit: r1374206 - in /tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test: java/sample/HelloworldDynamicWSImpl.java java/test/DynamicEndpointTestCase.java java/test/EndpointHelper.java resources/helloworld.wsdl resources/resources.zip

Author: antelder
Date: Fri Aug 17 11:39:29 2012
New Revision: 1374206

URL: http://svn.apache.org/viewvc?rev=1374206&view=rev
Log:
Change the dynamically added endpoint tests to use wsdl resource from a contribution and simplify the endpoint creation helper

Added:
    tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/resources/resources.zip   (with props)
Removed:
    tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/resources/helloworld.wsdl
Modified:
    tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/sample/HelloworldDynamicWSImpl.java
    tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/DynamicEndpointTestCase.java
    tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/EndpointHelper.java

Modified: tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/sample/HelloworldDynamicWSImpl.java
URL: http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/sample/HelloworldDynamicWSImpl.java?rev=1374206&r1=1374205&r2=1374206&view=diff
==============================================================================
--- tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/sample/HelloworldDynamicWSImpl.java (original)
+++ tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/sample/HelloworldDynamicWSImpl.java Fri Aug 17 11:39:29 2012
@@ -18,15 +18,20 @@
  */
 package sample;
 
-import java.io.File;
 import java.io.IOException;
 
 import javax.xml.namespace.QName;
 
 import org.apache.tuscany.sca.Node;
+import org.apache.tuscany.sca.assembly.Endpoint;
 import org.apache.tuscany.sca.common.xml.dom.DOMHelper;
+import org.apache.tuscany.sca.contribution.processor.ContributionReadException;
+import org.apache.tuscany.sca.impl.NodeImpl;
+import org.apache.tuscany.sca.interfacedef.InvalidInterfaceException;
+import org.apache.tuscany.sca.monitor.ValidationException;
 import org.apache.tuscany.sca.runtime.DOMInvoker;
 import org.apache.tuscany.sca.runtime.TuscanyComponentContext;
+import org.oasisopen.sca.NoSuchServiceException;
 import org.oasisopen.sca.annotation.Context;
 import org.oasisopen.sca.annotation.Init;
 import org.xml.sax.SAXException;
@@ -37,30 +42,41 @@ import test.EndpointHelper;
 public class HelloworldDynamicWSImpl implements Helloworld {
 
     @Context
-    TuscanyComponentContext context;
+    private TuscanyComponentContext context;
+
     private DOMHelper domHelper;
-    private DOMInvoker domInvoker;
+    private Node node;
 
     @Init
     public void init() {
-        try {
-
-            domHelper = DOMHelper.getInstance(context.getExtensionPointRegistry());
-            Node node = context.getNode();
-            EndpointHelper.addWSEndpoint(node, "SomeEndpointName", new File("src/test/resources/helloworld.wsdl").toURI().toURL(), new QName("http://sample/", "Helloworld"), "http://localhost:8089/testComponent/Helloworld");
-
-            domInvoker = node.getDOMInvoker("SomeEndpointName");
-        
-        } catch (Exception e) {
-            throw new RuntimeException(e);
-        }
+        domHelper = DOMHelper.getInstance(context.getExtensionPointRegistry());
+        node = context.getNode();
     }
     
     public String sayHello(String name) {
-        org.w3c.dom.Node arg = getRequestDOM(name);
-        org.w3c.dom.Node response = domInvoker.invoke("sayHello", arg);
-        return "Remote WS says: " + getResponseString(response);
+        try {
+            
+            String curi = node.installContribution("src/test/resources/resources.zip");
+
+            Endpoint endpoint = EndpointHelper.createWSEndpoint("SomeEndpointName", new QName("http://sample/", "Helloworld"), "http://localhost:8080/testComponent/Helloworld", curi, node);
+
+            ((NodeImpl)node).getEndpointRegistry().addEndpoint(endpoint);
+
+            DOMInvoker domInvoker = node.getDOMInvoker("SomeEndpointName");
             
+            org.w3c.dom.Node arg = getRequestDOM(name);
+            org.w3c.dom.Node response = domInvoker.invoke("sayHello", arg);
+            return "Remote WS says: " + getResponseString(response);
+            
+        } catch (ContributionReadException e) {
+            throw new RuntimeException(e);
+        } catch (ValidationException e) {
+            throw new RuntimeException(e);
+        } catch (NoSuchServiceException e) {
+            throw new RuntimeException(e);
+        } catch (InvalidInterfaceException e) {
+            throw new RuntimeException(e);
+        }
     }
 
     private String getResponseString(org.w3c.dom.Node responseDOM) {

Modified: tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/DynamicEndpointTestCase.java
URL: http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/DynamicEndpointTestCase.java?rev=1374206&r1=1374205&r2=1374206&view=diff
==============================================================================
--- tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/DynamicEndpointTestCase.java (original)
+++ tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/DynamicEndpointTestCase.java Fri Aug 17 11:39:29 2012
@@ -18,7 +18,6 @@
  */
 package test;
 
-import java.io.File;
 import java.io.IOException;
 
 import javax.xml.namespace.QName;
@@ -28,8 +27,10 @@ import junit.framework.TestCase;
 
 import org.apache.tuscany.sca.Node;
 import org.apache.tuscany.sca.TuscanyRuntime;
+import org.apache.tuscany.sca.assembly.Endpoint;
 import org.apache.tuscany.sca.common.xml.dom.DOMHelper;
 import org.apache.tuscany.sca.core.ExtensionPointRegistry;
+import org.apache.tuscany.sca.impl.NodeImpl;
 import org.apache.tuscany.sca.runtime.DOMInvoker;
 import org.junit.Test;
 import org.xml.sax.SAXException;
@@ -64,7 +65,11 @@ public class DynamicEndpointTestCase ext
     @Test
     public void testInvoke() throws Exception {
         
-        EndpointHelper.addWSEndpoint(node, "SomeEndpointName", new File("src/test/resources/helloworld.wsdl").toURI().toURL(), new QName("http://sample/", "Helloworld"), "http://localhost:8089/testComponent/Helloworld");
+        String curi = node.installContribution("src/test/resources/resources.zip");
+
+        Endpoint endpoint = EndpointHelper.createWSEndpoint("SomeEndpointName", new QName("http://sample/", "Helloworld"), "http://localhost:8080/testComponent/Helloworld", curi, node);
+
+        ((NodeImpl)node).getEndpointRegistry().addEndpoint(endpoint);
 
         DOMInvoker domInvoker = node.getDOMInvoker("SomeEndpointName");
 

Modified: tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/EndpointHelper.java
URL: http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/EndpointHelper.java?rev=1374206&r1=1374205&r2=1374206&view=diff
==============================================================================
--- tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/EndpointHelper.java (original)
+++ tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/java/test/EndpointHelper.java Fri Aug 17 11:39:29 2012
@@ -1,8 +1,5 @@
 package test;
 
-import java.net.URI;
-import java.net.URL;
-
 import javax.wsdl.PortType;
 import javax.wsdl.Service;
 import javax.xml.namespace.QName;
@@ -15,27 +12,22 @@ import org.apache.tuscany.sca.assembly.E
 import org.apache.tuscany.sca.binding.ws.WebServiceBinding;
 import org.apache.tuscany.sca.binding.ws.WebServiceBindingFactory;
 import org.apache.tuscany.sca.contribution.Contribution;
-import org.apache.tuscany.sca.contribution.ContributionFactory;
-import org.apache.tuscany.sca.contribution.processor.ContributionResolveException;
-import org.apache.tuscany.sca.contribution.processor.ExtensibleURLArtifactProcessor;
+import org.apache.tuscany.sca.contribution.processor.ContributionReadException;
 import org.apache.tuscany.sca.contribution.processor.ProcessorContext;
-import org.apache.tuscany.sca.contribution.processor.URLArtifactProcessorExtensionPoint;
-import org.apache.tuscany.sca.contribution.resolver.ExtensibleModelResolver;
-import org.apache.tuscany.sca.contribution.resolver.ModelResolver;
-import org.apache.tuscany.sca.contribution.resolver.ModelResolverExtensionPoint;
 import org.apache.tuscany.sca.core.ExtensionPointRegistry;
 import org.apache.tuscany.sca.core.FactoryExtensionPoint;
 import org.apache.tuscany.sca.impl.NodeImpl;
+import org.apache.tuscany.sca.interfacedef.InvalidInterfaceException;
 import org.apache.tuscany.sca.interfacedef.wsdl.WSDLDefinition;
 import org.apache.tuscany.sca.interfacedef.wsdl.WSDLFactory;
 import org.apache.tuscany.sca.interfacedef.wsdl.WSDLInterface;
 import org.apache.tuscany.sca.interfacedef.wsdl.WSDLInterfaceContract;
 import org.apache.tuscany.sca.interfacedef.wsdl.WSDLObject;
+import org.apache.tuscany.sca.monitor.ValidationException;
 
 public class EndpointHelper {
 
-    // TODO: change this to be a method on Node that takes a configured Binding to add a new endpoint
-    public static void addWSEndpoint(Node node, String endpointName, URL wsdlURL, QName portTypeQN, String targetURL) {
+    public static Endpoint createWSEndpoint(String endpointName, QName wsdlPortQN, String targetURL, String curi, Node node) throws ContributionReadException, ValidationException, InvalidInterfaceException {
         ExtensionPointRegistry extensionPoints = ((NodeImpl)node).getExtensionPointRegistry();
         FactoryExtensionPoint modelFactories = extensionPoints.getExtensionPoint(FactoryExtensionPoint.class);
         AssemblyFactory assemblyFactory = modelFactories.getFactory(AssemblyFactory.class);
@@ -47,7 +39,23 @@ public class EndpointHelper {
         WebServiceBinding wsBinding = webServiceBindingFactory.createWebServiceBinding();
         wsBinding.setURI(targetURL);
         
-        WSDLInterfaceContract wsdlIC = getWSDLInterfaceContract(wsdlURL, portTypeQN, modelFactories, extensionPoints);
+        WSDLFactory wif = modelFactories.getFactory(WSDLFactory.class);
+
+        Contribution c = node.getContribution(curi);
+        WSDLDefinition wd = wif.createWSDLDefinition();
+        wd.setUnresolved(true);
+        wd.setNamespace(wsdlPortQN.getNamespaceURI());
+        wd.setNameOfPortTypeToResolve(wsdlPortQN);
+        ProcessorContext ctx = new ProcessorContext();
+        wd = c.getModelResolver().resolveModel(WSDLDefinition.class, wd, ctx);
+        WSDLObject<PortType> pt = wd.getWSDLObject(PortType.class, wsdlPortQN);
+        
+        WSDLInterface nwi = wif.createWSDLInterface(pt.getElement(), wd, c.getModelResolver(), null);
+        nwi.setWsdlDefinition(wd);
+
+        WSDLInterfaceContract wsdlIC = wif.createWSDLInterfaceContract();
+        wsdlIC.setInterface(nwi);
+        
         wsBinding.setBindingInterfaceContract(wsdlIC);
 
         wsBinding.setGeneratedWSDLDocument(((WSDLInterface)wsdlIC.getInterface()).getWsdlDefinition().getDefinition());
@@ -61,41 +69,7 @@ public class EndpointHelper {
         newEndpoint.setBinding(wsBinding);
         newEndpoint.setURI(endpointName);
         newEndpoint.setRemote(true);
-        
-        ((NodeImpl)node).getEndpointRegistry().addEndpoint(newEndpoint);
+        return newEndpoint;
     }
      
-     private static WSDLInterfaceContract getWSDLInterfaceContract(URL wsdlURL, QName portTypeQN, FactoryExtensionPoint modelFactories, ExtensionPointRegistry extensionPoints) {
-         try {
-
-             ContributionFactory contributionFactory = modelFactories.getFactory(ContributionFactory.class);
-             Contribution contribution = contributionFactory.createContribution();
-             ModelResolverExtensionPoint modelResolvers = extensionPoints.getExtensionPoint(ModelResolverExtensionPoint.class);
-             ModelResolver modelResolver = new ExtensibleModelResolver(contribution, modelResolvers, modelFactories);
-             contribution.setModelResolver(modelResolver);
-
-             ExtensibleURLArtifactProcessor aproc = new ExtensibleURLArtifactProcessor(extensionPoints.getExtensionPoint(URLArtifactProcessorExtensionPoint.class));
-
-             ProcessorContext ctx = new ProcessorContext();
-             WSDLDefinition wd = aproc.read(null, new URI("anything.wsdl"), wsdlURL, ctx, WSDLDefinition.class);
-             modelResolver.addModel(wd, ctx);
-             modelResolver.resolveModel(WSDLDefinition.class, wd, ctx);
-             final WSDLObject<PortType> pt = wd.getWSDLObject(PortType.class, portTypeQN);
-             if(pt == null)
-                 throw new ContributionResolveException("Couldn't find " + portTypeQN);
-             
-             WSDLFactory wif = modelFactories.getFactory(WSDLFactory.class);
-             final WSDLInterface nwi = wif.createWSDLInterface(pt.getElement(), wd, modelResolver, null);
-             nwi.setWsdlDefinition(wd);
-
-             WSDLInterfaceContract wsdlIC = wif.createWSDLInterfaceContract();
-             wsdlIC.setInterface(nwi);
-
-             return wsdlIC;
-
-         } catch(Exception e) {
-             throw new RuntimeException(e);
-         }
-     }
-     
 }

Added: tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/resources/resources.zip
URL: http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/resources/resources.zip?rev=1374206&view=auto
==============================================================================
Binary file - no diff available.

Propchange: tuscany/sca-java-2.x/trunk/testing/itest/dynamic/src/test/resources/resources.zip
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream