blob: a5d65298954a85455b3902b28193664560f7dc52 [file] [log] [blame]
/*
* 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.sca.axis2;
import junit.framework.Assert;
import org.apache.tuscany.sca.binding.sca.axis2.helloworld.HelloWorldClient;
import org.apache.tuscany.sca.node.Contribution;
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.ServiceUnavailableException;
public class SimpleTestCase {
public static Node nodeA;
public static Node nodeB;
@BeforeClass
public static void init() throws Exception {
System.out.println("Setting up nodes");
try {
// create and start nodes
Contribution contrib = new Contribution("reference", "./target/test-classes/ws/simpleReference");
nodeA = NodeFactory.getInstance().createNode("HelloWorld.composite", contrib);
nodeA.start();
contrib = new Contribution("service", "./target/test-classes/ws/simpleService");
nodeB = NodeFactory.getInstance().createNode("HelloWorld.composite", contrib);
nodeB.start();
} catch (Exception ex) {
System.err.println("Exception when creating domain " + ex.getMessage());
ex.printStackTrace(System.err);
throw ex;
}
}
@AfterClass
public static void destroy() throws Exception {
nodeA.stop();
nodeB.stop();
}
@Test
public void testHelloWorldLocal() throws Exception {
HelloWorldClient helloWorldClientA = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientLocal");
Assert.assertEquals(helloWorldClientA.getGreetings("fred"), "Hello fred");
}
@Test
public void testHelloWorldRemote() throws Exception {
HelloWorldClient helloWorldClientA;
helloWorldClientA = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientRemote");
try {
helloWorldClientA.getGreetings("fred");
} catch (ServiceUnavailableException ex){
Assert.fail();
}
}
@Test
public void testHelloWorldLocalAndRemote() throws Exception {
HelloWorldClient helloWorldClientA = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientLocalAndRemote");
HelloWorldClient helloWorldClientB = nodeB.getService(HelloWorldClient.class, "BHelloWorldClientLocalAndRemote");
Assert.assertEquals(helloWorldClientA.getGreetings("fred"), "Hello fred");
Assert.assertEquals(helloWorldClientB.getGreetings("fred"), "Hello fred");
}
@Test
public void testHelloWorldMultipleServices() throws Exception {
HelloWorldClient helloWorldClientA = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientMultipleServices");
HelloWorldClient helloWorldClientA2 = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientMultipleServices2");
HelloWorldClient helloWorldClientB = nodeB.getService(HelloWorldClient.class, "BHelloWorldClientMultipleServices");
Assert.assertEquals(helloWorldClientA.getGreetings("fred"), "Hello fred");
Assert.assertEquals(helloWorldClientA2.getGreetings("fred"), "Hello fred");
Assert.assertEquals(helloWorldClientB.getGreetings("fred"), "Hello fred");
}
@Test
public void testHelloWorldMultipleBindings() throws Exception {
HelloWorldClient helloWorldClientA;
helloWorldClientA = nodeA.getService(HelloWorldClient.class, "AHelloWorldClientMultipleBindings");
Assert.assertEquals(helloWorldClientA.getGreetings("fred"), "Hello fred");
}
}