/* | |
* 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 itest; | |
import static org.junit.Assert.assertEquals; | |
import static org.junit.Assert.assertNotNull; | |
import itest.nodes.Helloworld; | |
import java.net.URI; | |
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.Ignore; | |
import org.junit.Test; | |
import org.oasisopen.sca.client.SCAClientFactory; | |
/** | |
* This shows how to test the Calculator service component. | |
*/ | |
public class TwoRemoteNodesTestCase{ | |
private static Node serviceNode; | |
private static Node clientNode; | |
@BeforeClass | |
public static void setUpBeforeClass() throws Exception { | |
serviceNode = NodeFactory.newInstance().createNode(URI.create("tuscany:TwoRemoteNodesTestCase"), "../helloworld-service/target/classes", "../helloworld-iface/target/classes"); | |
serviceNode.start(); | |
clientNode = NodeFactory.getInstance().createNode(URI.create("tuscany:TwoRemoteNodesTestCase"), "../helloworld-client/target/classes", "../helloworld-iface/target/classes"); | |
clientNode.start(); | |
} | |
@Test | |
public void testNode() throws Exception { | |
Helloworld service = serviceNode.getService(Helloworld.class, "HelloworldService"); | |
assertNotNull(service); | |
assertEquals("Hello Petra", service.sayHello("Petra")); | |
Helloworld client = clientNode.getService(Helloworld.class, "HelloworldClient"); | |
assertNotNull(client); | |
assertEquals("Hi Hello Petra", client.sayHello("Petra")); | |
Helloworld scaClientService = SCAClientFactory.newInstance(URI.create("TwoRemoteNodesTestCase")).getService(Helloworld.class, "HelloworldService"); | |
assertNotNull(scaClientService); | |
assertEquals("Hello Petra", scaClientService.sayHello("Petra")); | |
} | |
@Ignore // Fails with Hazelcast 1.9.2.2, investigating... | |
@Test | |
public void testRemoteClient() throws Exception { | |
Helloworld scaClientClient = SCAClientFactory.newInstance(URI.create("TwoRemoteNodesTestCase")).getService(Helloworld.class, "HelloworldClient"); | |
assertNotNull(scaClientClient); | |
assertEquals("Hi Hello Petra", scaClientClient.sayHello("Petra")); | |
} | |
@AfterClass | |
public static void tearDownAfterClass() throws Exception { | |
if (serviceNode != null) { | |
serviceNode.stop(); | |
} | |
if (clientNode != null) { | |
clientNode.stop(); | |
} | |
} | |
} |