Simple Callback Sample Using Web Services ========================================= This sample demonstrates asynchronous messaging using a callback over the Web Service binding. It is very similar to the simple-callback sample. The only differences are that simplecallback.composite has been updated to use the Web Service binding, and there is a simplecallback.wsdl file. The README in the samples directory (the directory above this) provides general instructions about building and running samples. Take a look there first. If you just want to run it to see what happens open a command prompt, navigate to this sample directory and do: ant run OR if you don't have ant, on Windows do java -cp ..\..\lib\tuscany-sca-manifest.jar;target\sample-simple-callback-ws.jar simplecallback.SimpleCallbackClient and on *nix do java -cp ../../lib/tuscany-sca-manifest.jar:target/sample-simple-callback-ws.jar simplecallback.SimpleCallbackClient Sample Overview --------------- The sample provides a single composite with two components. MyClientComponent is wired to MyServiceComponent. The interface of MyServiceComponent describes one method as ONEWAY and with a callback semantic. When a message passes from client to service the response is returned via the callback asynchronously. simple-callback/ src/ main/ java/ simplecallback/ MyClient.java - client interface MyClientImpl.java - implements the client and service callback interfaces MyService.java - service interface MyServiceCallback.java - service callback interface, implemented by the client MyServiceImpl.java - implements the service interface SimpleCallbackClient.java - starts the SCA Runtime and deploys the simplecallback.composite. It then calls MyClientComponent which in turn calls MyServiceComponent resources/ simplecallback.composite - the SCA assembly for this sample wsdl/ simplecallback.wsdl - the service description and callback binding test/ java/ simplecallback/ SimpleCallbackTestCase.java - JUnit test case simple-callback.png - a pictorial representation of the sample .composite file build.xml - the Ant build file pom.xml - the Maven build file Building And Running The Sample Using Ant ----------------------------------------- With the binary distribution the sample can be built and run using Ant as follows cd simple-callback-ws ant compile ant run You should see the following output from the run target. run: [java] log4j:WARN No appenders could be found for logger (org.apache.axiom.om.util.StAXUtils). [java] log4j:WARN Please initialize the log4j system properly. [java] Main thread Thread[main,5,main] [java] aClientMethod on thread Thread[main,5,main] [java] setMyServiceCallback on thread Thread[pool-1-thread-3,5,main] [java] someMethod on thread Thread[pool-1-thread-3,5,main] [java] receiveResult on thread Thread[Axis2 Task,5,main] [java] Result: -> someMethod -> receiveResult [java] aClientMethod return from someMethod on thread Thread[main,5,main] Building And Running The Sample Using Maven ------------------------------------------- With either the binary or source distributions the sample can be built and run using Maven as follows. cd simple-callback-ws mvn You should see the following output from the test phase. ------------------------------------------------------- T E S T S ------------------------------------------------------- Running simplecallback.SimpleCallbackTestCase log4j:WARN No appenders could be found for logger (org.apache.axiom.om.util.StAXUtils). log4j:WARN Please initialize the log4j system properly. 01-Jul-2007 21:20:06 org.apache.catalina.core.StandardEngine start INFO: Starting Servlet Engine: Apache Tomcat/6.0.10 01-Jul-2007 21:20:07 org.apache.catalina.startup.ContextConfig defaultWebConfig INFO: No default web.xml 01-Jul-2007 21:20:07 org.apache.catalina.startup.DigesterFactory register WARNING: Could not get url for /javax/servlet/jsp/resources/jsp_2_0.xsd 01-Jul-2007 21:20:07 org.apache.catalina.startup.DigesterFactory register WARNING: Could not get url for /javax/servlet/jsp/resources/web-jsptaglibrary_1_1.dtd 01-Jul-2007 21:20:07 org.apache.catalina.startup.DigesterFactory register WARNING: Could not get url for /javax/servlet/jsp/resources/web-jsptaglibrary_1_2.dtd 01-Jul-2007 21:20:07 org.apache.catalina.startup.DigesterFactory register WARNING: Could not get url for /javax/servlet/jsp/resources/web-jsptaglibrary_2_0.xsd 01-Jul-2007 21:20:07 org.apache.catalina.startup.DigesterFactory register WARNING: Could not get url for /javax/servlet/resources/j2ee_web_services_1_1.xsd 01-Jul-2007 21:20:07 org.apache.coyote.http11.Http11Protocol init INFO: Initializing Coyote HTTP/1.1 on http-8080 01-Jul-2007 21:20:07 org.apache.coyote.http11.Http11Protocol start INFO: Starting Coyote HTTP/1.1 on http-8080 Main thread Thread[main,5,main] aClientMethod on thread Thread[main,5,main] setMyServiceCallback on thread Thread[pool-1-thread-1,5,main] someMethod on thread Thread[pool-1-thread-1,5,main] aClientMethod return from someMethod on thread Thread[main,5,main] Sleeping ... receiveResult on thread Thread[Axis2 Task,5,main] Result: -> someMethod -> receiveResult 01-Jul-2007 21:20:08 org.apache.coyote.http11.Http11Protocol destroy INFO: Stopping Coyote HTTP/1.1 on http-8080 Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 3.525 sec Results : Tests run: 1, Failures: 0, Errors: 0, Skipped: 0 This shows that the Junit test cases have run successfully.