/* | |
* 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.axis2.jaxws.dispatch; | |
import junit.framework.Test; | |
import junit.framework.TestSuite; | |
import org.apache.axis2.jaxws.TestLogger; | |
import org.apache.axis2.jaxws.framework.AbstractTestCase; | |
import javax.xml.ws.Dispatch; | |
import javax.xml.ws.ProtocolException; | |
import javax.xml.ws.Response; | |
import javax.xml.ws.Service; | |
import javax.xml.ws.WebServiceException; | |
import java.net.UnknownHostException; | |
import java.util.concurrent.ExecutionException; | |
import java.util.concurrent.Future; | |
public class StringDispatchTests extends AbstractTestCase { | |
public static Test suite() { | |
return getTestSetup(new TestSuite(StringDispatchTests.class)); | |
} | |
/** | |
* Invoke a sync Dispatch<String> in PAYLOAD mode | |
*/ | |
public void testSyncPayloadMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
response = dispatch.invoke(DispatchTestConstants.sampleBodyContent); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a sync Dispatch<String> in PAYLOAD mode | |
* Server response with exception. Section 4.3.2 | |
* says we should get a ProtocolException, not a | |
* WebServiceException. | |
*/ | |
public void testSyncPayloadMode_exception() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
Exception e = null; | |
try { | |
// The _bad string passes "THROW EXCEPTION", which causes the echo function on the | |
// server to throw a RuntimeException. We should get a ProtocolException here on the client | |
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent_bad); | |
} catch (Exception ex) { | |
e = ex; | |
} | |
assertNotNull("No exception received", e); | |
assertTrue("'e' should be of type ProtocolException", e instanceof ProtocolException); | |
// Invoke a second time to verify | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
e = null; | |
try { | |
// The _bad string passes "THROW EXCEPTION", which causes the echo function on the | |
// server to throw a RuntimeException. We should get a ProtocolException here on the client | |
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent_bad); | |
} catch (Exception ex) { | |
e = ex; | |
} | |
assertNotNull("No exception received", e); | |
assertTrue("'e' should be of type ProtocolException", e instanceof ProtocolException); | |
} | |
/** | |
* Invoke a sync Dispatch<String> in MESSAGE mode | |
*/ | |
public void testSyncWithMessageMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.MESSAGE); | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
String response = dispatch.invoke(DispatchTestConstants.sampleSoapMessage); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
// Invoke the Dispatch | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
response = dispatch.invoke(DispatchTestConstants.sampleSoapMessage); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a Dispatch<String> using the async callback API in PAYLOAD mode | |
*/ | |
public void testAsyncCallbackPayloadMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
// Create the callback for async responses | |
AsyncCallback<String> callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch"); | |
Future<?> monitor = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
String response = callback.getValue(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
// Create the callback for async responses | |
callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch"); | |
monitor = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
response = callback.getValue(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a Dispatch<String> using the async callback API in MESSAGE mode | |
*/ | |
public void testAsyncCallbackMessageMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.MESSAGE); | |
// Create the callback for async responses | |
AsyncCallback<String> callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch with Message Mode"); | |
Future<?> monitor = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
String response = callback.getValue(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
// Create the callback for async responses | |
callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch with Message Mode"); | |
monitor = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
response = callback.getValue(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a Dispatch<String> using the async polling API in PAYLOAD mode | |
*/ | |
public void testAsyncPollingPayloadMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch"); | |
Response<String> asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
String response = asyncResponse.get(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch"); | |
asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
response = asyncResponse.get(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(!response.contains("soap")); | |
assertTrue(!response.contains("Envelope")); | |
assertTrue(!response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a Dispatch<String> using the async polling API in MESSAGE mode | |
*/ | |
public void testAsyncPollingMessageMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.MESSAGE); | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch with Message Mode"); | |
Response<String> asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
String response = asyncResponse.get(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
// Invoke a second time to verify | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch with Message Mode"); | |
asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
response = asyncResponse.get(); | |
assertNotNull("dispatch invoke returned null", response); | |
TestLogger.logger.debug(response); | |
// Check to make sure the content is correct | |
assertTrue(response.contains("soap")); | |
assertTrue(response.contains("Envelope")); | |
assertTrue(response.contains("Body")); | |
assertTrue(response.contains("echoStringResponse")); | |
} | |
/** | |
* Invoke a Dispatch<String> one-way in PAYLOAD mode | |
*/ | |
public void testOneWayPayloadMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
TestLogger.logger.debug(">> Invoking one-way Dispatch"); | |
dispatch.invokeOneWay(DispatchTestConstants.sampleBodyContent); | |
// Invoke a second time to verify | |
TestLogger.logger.debug(">> Invoking one-way Dispatch"); | |
dispatch.invokeOneWay(DispatchTestConstants.sampleBodyContent); | |
} | |
/** | |
* Invoke a Dispatch<String> one-way in MESSAGE mode | |
*/ | |
public void testOneWayMessageMode() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.MESSAGE); | |
TestLogger.logger.debug(">> Invoking one-way Dispatch"); | |
dispatch.invokeOneWay(DispatchTestConstants.sampleSoapMessage); | |
// Invoke a second time to verify | |
TestLogger.logger.debug(">> Invoking one-way Dispatch"); | |
dispatch.invokeOneWay(DispatchTestConstants.sampleSoapMessage); | |
} | |
public void testSyncPayloadMode_badHostName() { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.BADURL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
// Invoke the Dispatch | |
Throwable ttemp = null; | |
try { | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent); | |
} catch (Throwable t) { | |
assertTrue(t instanceof WebServiceException); | |
assertTrue(t.getCause() instanceof UnknownHostException); | |
ttemp = t; | |
} | |
assertNotNull(ttemp); | |
// Invoke a second time to verify | |
// Invoke the Dispatch | |
ttemp = null; | |
try { | |
TestLogger.logger.debug(">> Invoking sync Dispatch"); | |
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent); | |
} catch (Throwable t) { | |
assertTrue(t instanceof WebServiceException); | |
assertTrue(t.getCause() instanceof UnknownHostException); | |
ttemp = t; | |
} | |
assertNotNull(ttemp); | |
} | |
public void testAsyncCallbackMessageMode_badHostName() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.BADURL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.MESSAGE); | |
// Create the callback for async responses | |
AsyncCallback<String> callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch with Message Mode"); | |
Future<?> monitor = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
if (callback.hasError()) { | |
Throwable t = callback.getError(); | |
t.printStackTrace(); | |
assertTrue(t.getClass().getName() + " does not match expected type ExecutionException", t instanceof ExecutionException); | |
Throwable cause = t.getCause(); | |
assertNotNull("There must be a cause under the ExecutionException", cause); | |
assertTrue(cause.getClass().getName() + " does not match expected type WebServiceException" ,cause instanceof WebServiceException); | |
Throwable hostException = t.getCause().getCause(); | |
assertNotNull("There must be a cause under the WebServiceException", hostException); | |
assertTrue(hostException.getClass().getName() + " does not match expected type UnknownHostException", hostException instanceof UnknownHostException); | |
} else { | |
fail("No fault thrown. Should have retrieved an UnknownHostException from callback"); | |
} | |
// Invoke a second time to verify | |
// Create the callback for async responses | |
callback = new AsyncCallback<String>(); | |
TestLogger.logger.debug(">> Invoking async (callback) Dispatch with Message Mode"); | |
monitor = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage, callback); | |
while (!monitor.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
if (callback.hasError()) { | |
Throwable t = callback.getError(); | |
t.printStackTrace(); | |
assertTrue(t.getClass().getName() + " does not match expected type ExecutionException", t instanceof ExecutionException); | |
Throwable cause = t.getCause(); | |
assertNotNull("There must be a cause under the ExecutionException", cause); | |
assertTrue(cause.getClass().getName() + " does not match expected type WebServiceException" ,cause instanceof WebServiceException); | |
Throwable hostException = t.getCause().getCause(); | |
assertNotNull("There must be a cause under the WebServiceException", hostException); | |
assertTrue(hostException.getClass().getName() + " does not match expected type UnknownHostException", hostException instanceof UnknownHostException); | |
} else { | |
fail("No fault thrown. Should have retrieved an UnknownHostException from callback"); | |
} | |
} | |
public void testAsyncPollingPayloadMode_badHostName() throws Exception { | |
TestLogger.logger.debug("---------------------------------------"); | |
TestLogger.logger.debug("test: " + getName()); | |
// Initialize the JAX-WS client artifacts | |
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE); | |
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.BADURL); | |
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT, | |
String.class, Service.Mode.PAYLOAD); | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch"); | |
Response<String> asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
Throwable ttemp = null; | |
try { | |
asyncResponse.get(); | |
} catch (Throwable t) { | |
assertTrue(t instanceof ExecutionException); | |
assertTrue(t.getCause() instanceof WebServiceException); | |
assertTrue(t.getCause().getCause() instanceof UnknownHostException); | |
ttemp = t; | |
} | |
assertNotNull(ttemp); | |
// Invoke a second time to verify | |
TestLogger.logger.debug(">> Invoking async (polling) Dispatch"); | |
asyncResponse = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent); | |
while (!asyncResponse.isDone()) { | |
TestLogger.logger.debug(">> Async invocation still not complete"); | |
Thread.sleep(1000); | |
} | |
ttemp = null; | |
try { | |
asyncResponse.get(); | |
} catch (Throwable t) { | |
assertTrue(t instanceof ExecutionException); | |
assertTrue(t.getCause() instanceof WebServiceException); | |
assertTrue(t.getCause().getCause() instanceof UnknownHostException); | |
ttemp = t; | |
} | |
assertNotNull(ttemp); | |
} | |
} |