From 4f6a51d428d96dbb476d8412143748e841993372 Mon Sep 17 00:00:00 2001 From: antelder Date: Mon, 20 Sep 2010 12:32:50 +0000 Subject: Copy trunk samples to sanbox to experiment with renames and moves git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@998905 13f79535-47bb-0310-9956-ffa450edef68 --- .../JSELauncherBindingJSONRPCCalculator.java | 59 +++++++++++++++++++++ .../launcher/JSELauncherBindingRMICalculator.java | 61 ++++++++++++++++++++++ .../launcher/JSELauncherBindingSCACalculator.java | 59 +++++++++++++++++++++ .../launcher/JSELauncherBindingWSCalculator.java | 59 +++++++++++++++++++++ .../JSELauncherImplementationJavaCalculator.java | 46 ++++++++++++++++ .../JSELauncherImplementationScriptCalculator.java | 59 +++++++++++++++++++++ .../src/main/java/launcher/RuntimeIntegration.java | 43 +++++++++++++++ .../java/launcher/SampleLauncherException.java | 42 +++++++++++++++ 8 files changed, 428 insertions(+) create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/RuntimeIntegration.java create mode 100644 sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/SampleLauncherException.java (limited to 'sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher') diff --git a/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingJSONRPCCalculator.java new file mode 100644 index 0000000000..3d6af9f561 --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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/contribution-calculator/target/sample-contribution-binding-jsonrpc-calculator.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/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java new file mode 100644 index 0000000000..0c9c820ccb --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingRMICalculator.java @@ -0,0 +1,61 @@ +/* + * 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", "../../sca-features//binding-rmi/contribution-calculator-service/target/classes")); + Node node2 = NodeFactory.newInstance().createNode(new Contribution("c1", "../../sca-features//binding-rmi/contribution-calculator-reference/target/classes")); + + 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/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingSCACalculator.java new file mode 100644 index 0000000000..49960a7506 --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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", "../../sca-features/binding-sca/contribution-calculator/target/sample-contribution-binding-sca-calculator.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/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherBindingWSCalculator.java new file mode 100644 index 0000000000..71ff526589 --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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", "../../sca-features/binding-ws/contribution-calculator/target/sample-contribution-binding-ws-calculator.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/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationJavaCalculator.java new file mode 100644 index 0000000000..74202d5b86 --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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", "../../sca-features/implementation-java/contribution-calculator/target/classes")); + node.start(); + + node.stop(); + } + +} diff --git a/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/JSELauncherImplementationScriptCalculator.java new file mode 100644 index 0000000000..ca652718d7 --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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", "../implementation-script/contribution-calculator/target/sample-contribution-implementation-script-calculator.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/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/RuntimeIntegration.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/RuntimeIntegration.java new file mode 100644 index 0000000000..fdff16c12c --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/RuntimeIntegration.java @@ -0,0 +1,43 @@ +/* + * 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; + + +/** + * Base JSE launcher function + */ +public class RuntimeIntegration { + + + public Node startNode(Contribution... contributions){ + Node node = NodeFactory.newInstance().createNode(contributions); + node.start(); + return node; + } + + public void stopNode(Node node){ + node.stop(); + } + +} diff --git a/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/SampleLauncherException.java b/sandbox/samples/running-tuscany/launcher-embedded-jse/src/main/java/launcher/SampleLauncherException.java new file mode 100644 index 0000000000..f2ed3d421d --- /dev/null +++ b/sandbox/samples/running-tuscany/launcher-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); + } + +} -- cgit v1.2.3