From 7ea174b274f7e92d0ea46dfa8a689d96f0583b42 Mon Sep 17 00:00:00 2001 From: slaws Date: Fri, 14 May 2010 14:50:41 +0000 Subject: Add a contribution for a binding-sca based calculator app. This is a copy of the existing calculator module but modified to include a "client" component so we can launch it from JSE, mvn, OSGi etc without having to worry about how to get a calculator proxy. git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@944299 13f79535-47bb-0310-9956-ffa450edef68 --- .../contribution-binding-sca-calculator/README | 109 +++++++++++++++++++++ 1 file changed, 109 insertions(+) create mode 100644 sca-java-2.x/trunk/samples/contribution-binding-sca-calculator/README (limited to 'sca-java-2.x/trunk/samples/contribution-binding-sca-calculator/README') diff --git a/sca-java-2.x/trunk/samples/contribution-binding-sca-calculator/README b/sca-java-2.x/trunk/samples/contribution-binding-sca-calculator/README new file mode 100644 index 0000000000..20a913075c --- /dev/null +++ b/sca-java-2.x/trunk/samples/contribution-binding-sca-calculator/README @@ -0,0 +1,109 @@ +Calculator Sample +================= +This sample implements a simple calculator using SCA components. It also optionally demonstrates tracing Tuscany code. + +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 ..\..\features\tuscany-sca-manifest.jar;target\sample-calculator.jar calculator.CalculatorClient + +and on *nix do + +java -cp ../../features/tuscany-sca-manifest.jar:target/sample-calculator.jar calculator.CalculatorClient + +If you want to see an example of tracing the Tuscany code ... then try the command +--------------------------------------------------------- +ant runtraced + +or on Windows run the command + +java -javaagent:..\..\bin/aspectjweaver.jar -cp ..\..\features\tuscany-sca-manifest.jar;target\sample-calculator.jar calculator.CalculatorClient + +or on *nix run the command + +java -javaagent:../../bin/aspectjweaver.jar -cp ../../features/tuscany-sca-manifest.jar:target/sample-calculator.jar calculator.CalculatorClient + +Sample Overview +--------------- +The sample provides a single calculator service with a default SCA (java) +binding. The CalculatorClient exercises this interface by calling add, +subtract, multiply and divide operations. This results in messages passing to +the appropriate components in the composite across the local wires. + +calculator/ + src/ + main/ + java/ + calculator/ + CalculatorService.java - the first component, calls +-/* as + appropriate + CalculatorServiceImpl.java + AddService.java - adds two numbers + AddServiceImpl.java + SubtractService.java - subtracts one number from another + SubtractServiceImpl.java + MultiplyService.java - multiplies two numbers + MultiplyServiceImpl.java + DivideService.java - divides one number by another + DivideServiceImpl.java + CalculatorClient.java - starts the SCA Runtime and + deploys the Calculator.composite. + It then calls the deployed Calculator + Components services + resources/ + Calculator.composite - the SCA assembly for this sample + test/ + java/ + calculator/ + CalculatorTestCase.java - JUnit test case + calculator.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 calculator +ant compile +ant run + +You should see the following output from the run target. + +run: + [java] 3 + 2=5.0 + [java] 3 - 2=1.0 + [java] 3 * 2=6.0 + [java] 3 / 2=1.5 + +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 calculator +mvn + +You should see the following output from the test phase. + +------------------------------------------------------- + T E S T S +------------------------------------------------------- +Running calculator.CalculatorTestCase +Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 1.272 sec + +Results : + +Tests run: 1, Failures: 0, Errors: 0, Skipped: 0 + +This shows that the Junit test cases have run successfully. -- cgit v1.2.3