/* * 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; } }