blob: 0bf04e87f458e79d829203372a82efe468d3b3d7 [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.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 org.apache.axis2.jaxws.message.util.Reader2Writer;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamReader;
import javax.xml.transform.Source;
import javax.xml.transform.dom.DOMSource;
import javax.xml.ws.Dispatch;
import javax.xml.ws.Response;
import javax.xml.ws.Service;
import javax.xml.ws.WebServiceException;
import java.io.ByteArrayInputStream;
import java.util.concurrent.Future;
/**
* This class tests the JAX-WS Dispatch with various forms of the
* javax.xml.transform.dom.DOMSource
*/
public class DOMSourceDispatchTests extends AbstractTestCase{
private static final XMLInputFactory inputFactory = XMLInputFactory.newInstance();
public static Test suite() {
return getTestSetup(new TestSuite(DOMSourceDispatchTests.class));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.PAYLOAD);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleBodyContent);
TestLogger.logger.debug(">> Invoking sync Dispatch");
Source response = dispatch.invoke(request);
assertNotNull("dispatch invoke returned null",response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(!responseText.contains("soap"));
assertTrue(!responseText.contains("Envelope"));
assertTrue(!responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
public void testSyncMessageMode() 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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.MESSAGE);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleSoapMessage);
TestLogger.logger.debug(">> Invoking sync Dispatch");
Source response = dispatch.invoke(request);
assertNotNull("dispatch invoke returned null",response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
// Invoke a second time
response = dispatch.invoke(request);
assertNotNull("dispatch invoke returned null",response);
// Turn the Source into a String so we can check it
responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.PAYLOAD);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleBodyContent);
// Setup the callback for async responses
AsyncCallback<Source> callbackHandler = new AsyncCallback<Source>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
Future<?> monitor = dispatch.invokeAsync(request, callbackHandler);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
Source response = callbackHandler.getValue();
assertNotNull(response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(!responseText.contains("soap"));
assertTrue(!responseText.contains("Envelope"));
assertTrue(!responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
// Invoke a second time
// Setup the callback for async responses
callbackHandler = new AsyncCallback<Source>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
monitor = dispatch.invokeAsync(request, callbackHandler);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
response = callbackHandler.getValue();
assertNotNull(response);
// Turn the Source into a String so we can check it
responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(!responseText.contains("soap"));
assertTrue(!responseText.contains("Envelope"));
assertTrue(!responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.MESSAGE);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleSoapMessage);
// Setup the callback for async responses
AsyncCallback<Source> callbackHandler = new AsyncCallback<Source>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
Future<?> monitor = dispatch.invokeAsync(request, callbackHandler);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
Source response = callbackHandler.getValue();
assertNotNull(response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
// Invoke a second time
// Setup the callback for async responses
callbackHandler = new AsyncCallback<Source>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
monitor = dispatch.invokeAsync(request, callbackHandler);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
response = callbackHandler.getValue();
assertNotNull(response);
// Turn the Source into a String so we can check it
responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.PAYLOAD);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleBodyContent);
TestLogger.logger.debug(">> Invoking async (polling) Dispatch");
Response<Source> asyncResponse = dispatch.invokeAsync(request);
while (!asyncResponse.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
Source response = asyncResponse.get();
assertNotNull(response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(!responseText.contains("soap"));
assertTrue(!responseText.contains("Envelope"));
assertTrue(!responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
// Invoke a second time
TestLogger.logger.debug(">> Invoking async (polling) Dispatch");
asyncResponse = dispatch.invokeAsync(request);
while (!asyncResponse.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
response = asyncResponse.get();
assertNotNull(response);
// Turn the Source into a String so we can check it
responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(!responseText.contains("soap"));
assertTrue(!responseText.contains("Envelope"));
assertTrue(!responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.MESSAGE);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleSoapMessage);
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
Response<Source> asyncResponse = dispatch.invokeAsync(request);
while (!asyncResponse.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
Source response = asyncResponse.get();
assertNotNull(response);
// Turn the Source into a String so we can check it
String responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
// Invoke a second time
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
asyncResponse = dispatch.invokeAsync(request);
while (!asyncResponse.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
response = asyncResponse.get();
assertNotNull(response);
// Turn the Source into a String so we can check it
responseText = createStringFromSource(response);
TestLogger.logger.debug(responseText);
// Check to make sure the content is correct
assertTrue(responseText.contains("soap"));
assertTrue(responseText.contains("Envelope"));
assertTrue(responseText.contains("Body"));
assertTrue(responseText.contains("echoStringResponse"));
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.PAYLOAD);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleBodyContent);
TestLogger.logger.debug(">> Invoking One Way Dispatch");
dispatch.invokeOneWay(request);
// Invoke a second time
TestLogger.logger.debug(">> Invoking One Way Dispatch");
dispatch.invokeOneWay(request);
}
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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.MESSAGE);
// Create the DOMSource
DOMSource request = createDOMSourceFromString(DispatchTestConstants.sampleSoapMessage);
TestLogger.logger.debug(">> Invoking One Way Dispatch");
dispatch.invokeOneWay(request);
// Invoke a second time
TestLogger.logger.debug(">> Invoking One Way Dispatch");
dispatch.invokeOneWay(request);
}
public void testBadDOMSource() 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<Source> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
Source.class, Service.Mode.PAYLOAD);
// Create the DOMSource
DOMSource request = new DOMSource();
try {
dispatch.invokeOneWay(request);
fail("WebServiceException was expected");
} catch (WebServiceException e) {
TestLogger.logger.debug("A Web Service Exception was expected: " + e.toString());
assertTrue(e.getMessage() != null);
} catch (Exception e) {
fail("WebServiceException was expected, but received " + e);
}
// Invoke a second time
try {
dispatch.invokeOneWay(request);
fail("WebServiceException was expected");
} catch (WebServiceException e) {
TestLogger.logger.debug("A Web Service Exception was expected: " + e.toString());
assertTrue(e.getMessage() != null);
} catch (Exception e) {
fail("WebServiceException was expected, but received " + e);
}
}
/**
* Create a DOMSource with the provided String as the content
* @param input
* @return
*/
private DOMSource createDOMSourceFromString(String input) throws Exception {
byte[] bytes = input.getBytes();
ByteArrayInputStream stream = new ByteArrayInputStream(bytes);
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
domFactory.setNamespaceAware(true);
DocumentBuilder domBuilder = domFactory.newDocumentBuilder();
Document domTree = domBuilder.parse(stream);
Node node = domTree.getDocumentElement();
DOMSource domSource = new DOMSource(node);
return domSource;
}
/**
* Create a String from the provided Source
* @param input
* @return
*/
private String createStringFromSource(Source input) throws Exception {
XMLStreamReader reader = inputFactory.createXMLStreamReader(input);
Reader2Writer r2w = new Reader2Writer(reader);
String text = r2w.getAsString();
return text;
}
}