From cdd0b2d71315be4abe7c1acf99e5cbbe97dc625a Mon Sep 17 00:00:00 2001 From: kelvingoodson Date: Tue, 13 Jul 2010 16:53:31 +0000 Subject: async sample update git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@963791 13f79535-47bb-0310-9956-ffa450edef68 --- .../embedded-jse-async-sample-launcher/pom.xml | 2 +- sca-java-2.x/trunk/contrib/samples/async/pom.xml | 2 +- .../pom.xml | 2 +- .../main/java/calculator/CalculateViaAsyncRef.java | 12 +++++- .../src/main/java/calculator/CalculatorClient.java | 2 + .../java/calculator/CalculatorServiceImpl.java | 48 +++++++++++++++++++--- .../src/main/resources/CalculatorClient.composite | 2 +- 7 files changed, 60 insertions(+), 10 deletions(-) (limited to 'sca-java-2.x/trunk') diff --git a/sca-java-2.x/trunk/contrib/samples/async/embedded-jse-async-sample-launcher/pom.xml b/sca-java-2.x/trunk/contrib/samples/async/embedded-jse-async-sample-launcher/pom.xml index 5a71b7e412..cdf1c59f2b 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/embedded-jse-async-sample-launcher/pom.xml +++ b/sca-java-2.x/trunk/contrib/samples/async/embedded-jse-async-sample-launcher/pom.xml @@ -23,7 +23,7 @@ org.apache.tuscany.sca tuscany-sca 2.0-SNAPSHOT - ../../pom.xml + ../pom.xml embedded-jse-async-sample-launcher Embedded JSE Launcher for async samples diff --git a/sca-java-2.x/trunk/contrib/samples/async/pom.xml b/sca-java-2.x/trunk/contrib/samples/async/pom.xml index 8554487601..49f58baa34 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/pom.xml +++ b/sca-java-2.x/trunk/contrib/samples/async/pom.xml @@ -23,7 +23,7 @@ org.apache.tuscany.sca tuscany-sca 2.0-SNAPSHOT - ../../pom.xml + ../../../pom.xml tuscany-sample-async pom diff --git a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/pom.xml b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/pom.xml index 2d4ac4f8b1..a0f60bcf6b 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/pom.xml +++ b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/pom.xml @@ -23,7 +23,7 @@ org.apache.tuscany.sca tuscany-sca 2.0-SNAPSHOT - ../../pom.xml + ../pom.xml sample-contribution-implementation-java-calculator-async Apache Tuscany SCA Sample Contribution Implementation Java Calculator for Async Sample diff --git a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculateViaAsyncRef.java b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculateViaAsyncRef.java index e370bd915b..2d3fc97bb0 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculateViaAsyncRef.java +++ b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculateViaAsyncRef.java @@ -13,6 +13,16 @@ import javax.xml.ws.Response; public interface CalculateViaAsyncRef { - public Response calculate( Integer i1); + //public Response calculate( Integer i1); + + // Sync + public String calculate(Integer i1); + + // Aysnc Poll + public Future calculateAsync(Integer i1); + + // Async Callback + public Future calculateAsync(Integer i1, AsyncHandler handler); } + diff --git a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorClient.java b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorClient.java index 60c7d8d3ce..fd92647dd1 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorClient.java +++ b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorClient.java @@ -33,11 +33,13 @@ public class CalculatorClient { private CalculatorService calculatorService; + @Reference public void setCalculatorService(CalculatorService calculatorService) { this.calculatorService = calculatorService; } + @Init public void calculate() { diff --git a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorServiceImpl.java b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorServiceImpl.java index 8352a528d7..da9963087f 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorServiceImpl.java +++ b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/java/calculator/CalculatorServiceImpl.java @@ -18,20 +18,58 @@ */ package calculator; +import java.util.concurrent.ExecutionException; +import java.util.concurrent.Future; + +import javax.xml.ws.AsyncHandler; + +import org.oasisopen.sca.annotation.Reference; + /** * An implementation of the Calculator service. */ public class CalculatorServiceImpl implements CalculatorService { + + @Reference + protected CalculateViaAsyncRef calculatorRefSyncService; + + @Reference + protected CalculateViaAsyncRef calculatorRefAsyncService; @Override public String calculate(Integer n1) { - - // TODO brute force search for divisors of n1 (http://en.wikipedia.org/wiki/Brute-force_search) - // which should give a nice example of a method that takes a long time if given a - // big enough input parameter - return "1 2"; + + // sync + String result = calculatorRefSyncService.calculate(1); + + // async poll + Future future = calculatorRefAsyncService.calculateAsync(2); + + while (!future.isDone()){ + System.out.println("Waiting for poll"); + } + + try { + result = future.get(); + } catch (InterruptedException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (ExecutionException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + + // async callback +// AsyncHandler handler = new AsyncHandler(); +// future = calculatorRef.calculateAsync(3, handler); +/* + while (!future.isDone()){ + System.out.println("Waiting for callback"); + } +*/ + return result; } diff --git a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/resources/CalculatorClient.composite b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/resources/CalculatorClient.composite index dfd32761be..374ef27e2b 100644 --- a/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/resources/CalculatorClient.composite +++ b/sca-java-2.x/trunk/contrib/samples/async/sample-contribution-implementation-java-calculator-async/src/main/resources/CalculatorClient.composite @@ -25,6 +25,6 @@ - + -- cgit v1.2.3