From 1618160f4f2dbb67727df2d341c505f105aa1e2c Mon Sep 17 00:00:00 2001 From: antelder Date: Tue, 26 Oct 2010 11:07:13 +0000 Subject: Delete and redo release branch git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1027464 13f79535-47bb-0310-9956-ffa450edef68 --- .../samples/running-tuscany/embedded-jse/README | 15 +++ .../samples/running-tuscany/embedded-jse/build.xml | 141 +++++++++++++++++++++ .../samples/running-tuscany/embedded-jse/pom.xml | 92 ++++++++++++++ .../main/java/calculator/CalculatorService.java | 38 ++++++ .../JSELauncherBindingJSONRPCCalculator.java | 59 +++++++++ .../launcher/JSELauncherBindingRMICalculator.java | 60 +++++++++ .../launcher/JSELauncherBindingSCACalculator.java | 59 +++++++++ .../launcher/JSELauncherBindingWSCalculator.java | 59 +++++++++ .../JSELauncherImplementationJavaCalculator.java | 46 +++++++ ...ELauncherImplementationJavaCalculatorAsync.java | 44 +++++++ .../JSELauncherImplementationScriptCalculator.java | 59 +++++++++ .../java/launcher/SampleLauncherException.java | 42 ++++++ .../src/test/java/launcher/LauncherTestCase.java | 62 +++++++++ 13 files changed, 776 insertions(+) create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/README create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/build.xml create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/pom.xml create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/calculator/CalculatorService.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculatorAsync.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/SampleLauncherException.java create mode 100644 sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/test/java/launcher/LauncherTestCase.java (limited to 'sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse') diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/README b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/README new file mode 100644 index 0000000000..b10f588d0d --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/README @@ -0,0 +1,15 @@ +JSE Sample Launchers +==================== + +This directory contains sample java launchers for the +tuscany sample contributions. + +To use this sample JSE launcher with ant execute the command + +ant run- + +where run- is one of the targets in the build.xml file + +To use this sample launcher to run all of the contributions as junit test cases, +execute the command "mvn" in the launcher directory. + diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/build.xml b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/build.xml new file mode 100644 index 0000000000..ae72c3cca2 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/build.xml @@ -0,0 +1,141 @@ + + + + + + Root of Tuscany binary distribution is - ${tuscany.home} + + + + + + + + + + + + + + + + + + + + + + + + + + + Please use 'ant run-name-of-sample-contribution-to-run' for example, try one of + 'ant sample-binding-sca-calculator-contribution' + 'ant sample-binding-ws-calculator-contribution' + 'ant sample-binding-rmi-calculator-contribution' + 'ant sample-implementation-java-calculator-contribution' + 'ant sample-implementation-java-calculator-async-contribution' + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/pom.xml b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/pom.xml new file mode 100644 index 0000000000..462c89ffe1 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/pom.xml @@ -0,0 +1,92 @@ + + + + 4.0.0 + + org.apache.tuscany.sca + tuscany-samples + 2.0-Beta1-SNAPSHOT + ../pom.xml + + sample-launcher-embedded-jse + Apache Tuscany SCA Sample Launcher Embedded JSE + + + + org.apache.tuscany.sca + tuscany-base-runtime-pom + 2.0-Beta1-SNAPSHOT + pom + + + + org.apache.tuscany.sca + tuscany-osgi-runtime-pom + 2.0-Beta1-SNAPSHOT + pom + + + + org.apache.tuscany.sca + tuscany-binding-rmi-runtime + 2.0-Beta1-SNAPSHOT + + + + org.apache.tuscany.sca + tuscany-binding-ws-runtime-axis2 + 2.0-Beta1-SNAPSHOT + + + + org.apache.tuscany.sca + tuscany-host-jetty + 2.0-Beta1-SNAPSHOT + + + + org.apache.tuscany.sca + tuscany-implementation-script-runtime + 2.0-Beta1-SNAPSHOT + + + + org.apache.tuscany.sca + tuscany-binding-jsonrpc-runtime + 2.0-Beta1-SNAPSHOT + + + + junit + junit + 4.8.1 + test + + + + + + ${artifactId} + + + + + + diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/calculator/CalculatorService.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/calculator/CalculatorService.java new file mode 100644 index 0000000000..12d80ffd1c --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/calculator/CalculatorService.java @@ -0,0 +1,38 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ +package calculator; + +import org.oasisopen.sca.annotation.Remotable; + + +/** + * The Calculator service interface. + */ +@Remotable +public interface CalculatorService { + + double add(double n1, double n2); + + double subtract(double n1, double n2); + + double multiply(double n1, double n2); + + double divide(double n1, double n2); + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java new file mode 100644 index 0000000000..b4ef6b6ea7 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java @@ -0,0 +1,59 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherBindingJSONRPCCalculator { + + public static void main(String[] args) throws Exception { + JSELauncherBindingJSONRPCCalculator launcher = new JSELauncherBindingJSONRPCCalculator(); + launcher.launchBindingSCACalculator(); + } + + /* + * Using the Tuscany Node API to load a contribution. + * Using the Tuscany Node API to get a local service proxy + */ + public void launchBindingSCACalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../binding-jsonrpc/calculator-contribution/target/sample-binding-jsonrpc-calculator-contribution.jar")); + node.start(); + + CalculatorService calculator = node.getService(CalculatorService.class, "CalculatorServiceComponent"); + + // TODO - could use JUnit assertions but don't want to have to handle JUnit dependency from Ant script + double result = calculator.add(3, 2); + System.out.println("3 + 2 = " + result); + if (result != 5.0){ + throw new SampleLauncherException(); + } + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java new file mode 100644 index 0000000000..b3c99edfa1 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java @@ -0,0 +1,60 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherBindingRMICalculator { + + public static void main(String[] args) throws Exception { + JSELauncherBindingRMICalculator launcher = new JSELauncherBindingRMICalculator(); + launcher.launchBindingRMICalculator(); + } + + + public void launchBindingRMICalculator(){ + + Node node1 = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/binding-rmi/calculator-service-contribution/target/sample-binding-rmi-calculator-service-contribution.jar")); + Node node2 = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/binding-rmi/calculator-reference-contribution/target/sample-binding-rmi-calculator-reference-contribution.jar")); + + node1.start(); + node2.start(); + + CalculatorService calculator = node2.getService(CalculatorService.class, "CalculatorServiceComponent"); + + double result = calculator.add(3, 2); + System.out.println("3 + 2 = " + result); + if (result != 5.0){ + throw new SampleLauncherException(); + } + + node1.stop(); + node2.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java new file mode 100644 index 0000000000..43de9e646f --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java @@ -0,0 +1,59 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherBindingSCACalculator { + + public static void main(String[] args) throws Exception { + JSELauncherBindingSCACalculator launcher = new JSELauncherBindingSCACalculator(); + launcher.launchBindingSCACalculator(); + } + + /* + * Using the Tuscany Node API to load a contribution. + * Using the Tuscany Node API to get a local service proxy + */ + public void launchBindingSCACalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/binding-sca/calculator-contribution/target/sample-binding-sca-calculator-contribution.jar")); + node.start(); + + CalculatorService calculator = node.getService(CalculatorService.class, "CalculatorServiceComponent"); + + // TODO - could use JUnit assertions but don't want to have to handle JUnit dependency from Ant script + double result = calculator.add(3, 2); + System.out.println("3 + 2 = " + result); + if (result != 5.0){ + throw new SampleLauncherException(); + } + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java new file mode 100644 index 0000000000..7c212a75dd --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java @@ -0,0 +1,59 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherBindingWSCalculator { + + public static void main(String[] args) throws Exception { + JSELauncherBindingWSCalculator launcher = new JSELauncherBindingWSCalculator(); + launcher.launchBindingWSCalculator(); + } + + /* + * Using the Tuscany Node API to load a contribution. + * Using the Tuscany Node API to get a local service proxy + */ + public void launchBindingWSCalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/binding-ws/calculator-contribution/target/sample-binding-ws-calculator-contribution.jar")); + node.start(); + + CalculatorService calculator = node.getService(CalculatorService.class, "CalculatorServiceComponent"); + + // TODO - could use JUnit assertions but don't want to have to handle JUnit dependency from Ant script + double result = calculator.add(3, 2); + System.out.println("3 + 2 = " + result); + if (result != 5.0){ + throw new SampleLauncherException(); + } + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java new file mode 100644 index 0000000000..6e865f3822 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java @@ -0,0 +1,46 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherImplementationJavaCalculator { + + public static void main(String[] args) throws Exception { + JSELauncherImplementationJavaCalculator launcher = new JSELauncherImplementationJavaCalculator(); + launcher.launchImplementationJavaCalculator(); + } + + public void launchImplementationJavaCalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/implementation-java/calculator-contribution/target/sample-implementation-java-calculator-contribution.jar")); + node.start(); + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculatorAsync.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculatorAsync.java new file mode 100644 index 0000000000..98cab93b5f --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculatorAsync.java @@ -0,0 +1,44 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherImplementationJavaCalculatorAsync { + + public static void main(String[] args) throws Exception { + JSELauncherImplementationJavaCalculatorAsync launcher = new JSELauncherImplementationJavaCalculatorAsync(); + launcher.launchImplementationJavaCalculator(); + } + + public void launchImplementationJavaCalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/async/calculator-contribution/target/sample-implementation-java-calculator-async-contribution.jar")); + node.start(); + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java new file mode 100644 index 0000000000..4f6e951671 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java @@ -0,0 +1,59 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package launcher; + +import org.apache.tuscany.sca.node.Contribution; +import org.apache.tuscany.sca.node.Node; +import org.apache.tuscany.sca.node.NodeFactory; + +import calculator.CalculatorService; + +/** + * This client program shows how to create an embedded SCA runtime, load a contribution, + * start it and locate and invoke an SCA component + */ +public class JSELauncherImplementationScriptCalculator { + + public static void main(String[] args) throws Exception { + JSELauncherImplementationScriptCalculator launcher = new JSELauncherImplementationScriptCalculator(); + launcher.launchImplementationScriptCalculator(); + } + + /* + * Using the Tuscany Node API to load a contribution. + * Using the Tuscany Node API to get a local service proxy + */ + public void launchImplementationScriptCalculator(){ + Node node = NodeFactory.newInstance().createNode(new Contribution("c1", "../../learning-more/implementation-script/calculator-contribution/target/sample-implementation-script-calculator-contribution.jar")); + node.start(); + + CalculatorService calculator = node.getService(CalculatorService.class, "CalculatorServiceComponent"); + + // TODO - could use JUnit assertions but don't want to have to handle JUnit dependency from Ant script + double result = calculator.add(3, 2); + System.out.println("3 + 2 = " + result); + if (result != 5.0){ + throw new SampleLauncherException(); + } + + node.stop(); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/SampleLauncherException.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/SampleLauncherException.java new file mode 100644 index 0000000000..f2ed3d421d --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/main/java/launcher/SampleLauncherException.java @@ -0,0 +1,42 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ +package launcher; + +/** + * This exception signals problems in the management of SCA component execution. + */ +public class SampleLauncherException extends RuntimeException { + /** + * Constructs a SampleLauncherException with no detail message. + */ + public SampleLauncherException() { + super(); + } + + /** + * Constructs a SampleLauncherException with the specified detail + * message. + * + * @param message the detail message + */ + public SampleLauncherException(String message) { + super(message); + } + +} diff --git a/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/test/java/launcher/LauncherTestCase.java b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/test/java/launcher/LauncherTestCase.java new file mode 100644 index 0000000000..4c6a93f870 --- /dev/null +++ b/sca-java-2.x/branches/2.0-Beta1/samples/running-tuscany/embedded-jse/src/test/java/launcher/LauncherTestCase.java @@ -0,0 +1,62 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ +package launcher; + +import org.junit.Test; + +/** + * Test sample contributions. + */ +public class LauncherTestCase { + + @Test + public void testBindingJSONRPCCalculator() throws Exception { + JSELauncherBindingSCACalculator.main(null); + } + + @Test + public void testBindingSCACalculator() throws Exception { + JSELauncherBindingSCACalculator.main(null); + } + + @Test + public void testBindingWSCalculator() throws Exception { + JSELauncherBindingWSCalculator.main(null); + } + + @Test + public void testBindingRMICalculator() throws Exception { + JSELauncherBindingRMICalculator.main(null); + } + + @Test + public void testImplementationJavaCalculator() throws Exception { + JSELauncherImplementationJavaCalculator.main(null); + } + + @Test + public void testImplementationScriptCalculator() throws Exception { + JSELauncherImplementationScriptCalculator.main(null); + } + + @Test + public void testImplementationJavaCalculatorAsync() throws Exception { + JSELauncherImplementationJavaCalculatorAsync.main(null); + } +} -- cgit v1.2.3