| /* |
| * 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 org.apache.tuscany.sca.binding.hazelcast; |
| |
| import static org.junit.Assert.assertEquals; |
| import static org.junit.Assert.assertNotNull; |
| import static org.junit.Assert.fail; |
| |
| import org.apache.tuscany.sca.node.Node; |
| import org.apache.tuscany.sca.node.NodeFactory; |
| import org.junit.AfterClass; |
| import org.junit.BeforeClass; |
| import org.junit.Test; |
| import org.oasisopen.sca.ServiceRuntimeException; |
| |
| public class HazelcastBindingTestCase { |
| |
| private static Node serviceNode; |
| private static Node clientNode; |
| |
| @BeforeClass |
| public static void setUpBeforeClass() throws Exception { |
| // Note use of NodeFactory.newInstance() so as to start separate runtimes |
| serviceNode = NodeFactory.newInstance("uri:HazelcastBindingTestCase?bind=127.0.0.1").createNode("service.composite", new String[]{"target/test-classes"}); |
| serviceNode.start(); |
| clientNode = NodeFactory.newInstance("uri:HazelcastBindingTestCase?bind=127.0.0.1").createNode("client.composite", new String[]{"target/test-classes"}); |
| clientNode.start(); |
| } |
| |
| @Test |
| public void testNestedClient() throws Exception { |
| Node client2Node = NodeFactory.newInstance("uri:HazelcastBindingTestCase?bind=127.0.0.1").createNode("client2.composite", new String[]{"target/test-classes"}); |
| client2Node.start(); |
| TestService service = client2Node.getService(TestService.class, "TestServiceClient2"); |
| assertNotNull(service); |
| assertEquals("Petra", service.echoString("Petra")); |
| client2Node.stop(); |
| } |
| |
| @Test |
| public void testEchoString() throws Exception { |
| TestService service = clientNode.getService(TestService.class, "TestServiceClient"); |
| assertNotNull(service); |
| assertEquals("Petra", service.echoString("Petra")); |
| } |
| |
| @Test |
| public void testOnewayString() throws Exception { |
| TestService service = clientNode.getService(TestService.class, "TestServiceClient"); |
| assertNotNull(service); |
| service.onewayString("Petra"); |
| } |
| |
| @Test |
| public void testEchoComplexType() throws Exception { |
| TestService service = clientNode.getService(TestService.class, "TestServiceClient"); |
| assertNotNull(service); |
| ComplexType ct = new ComplexType(); |
| ct.setString("beate"); |
| assertEquals("beate", service.echoComplexType(ct).getString()); |
| } |
| |
| @Test |
| public void testDeclaredException() throws Exception { |
| TestService service = clientNode.getService(TestService.class, "TestServiceClient"); |
| assertNotNull(service); |
| try { |
| service.testExceptions("Sue"); |
| fail(); |
| } catch (BadStringException e) { |
| assertEquals("Sue", e.getMessage()); |
| } |
| } |
| |
| @Test |
| public void testRuntimeException() throws Exception { |
| TestService service = clientNode.getService(TestService.class, "TestServiceClient"); |
| assertNotNull(service); |
| try { |
| service.testExceptions("runtime"); |
| fail(); |
| } catch (ServiceRuntimeException e) { |
| assertEquals("org.oasisopen.sca.ServiceRuntimeException: Remote exception: class java.lang.RuntimeException:runtime", e.getMessage()); |
| } |
| } |
| |
| @AfterClass |
| public static void tearDownAfterClass() throws Exception { |
| if (clientNode != null) { |
| clientNode.stop(); |
| } |
| if (serviceNode != null) { |
| serviceNode.stop(); |
| } |
| } |
| } |
| |