/** * 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.cxf.systest.ws.addr_fromjava; import java.io.ByteArrayOutputStream; import java.net.URL; import java.util.List; import javax.xml.ws.BindingProvider; import javax.xml.ws.soap.SOAPFaultException; import org.apache.cxf.binding.soap.SoapMessage; import org.apache.cxf.binding.soap.interceptor.AbstractSoapInterceptor; import org.apache.cxf.binding.soap.interceptor.ReadHeadersInterceptor; import org.apache.cxf.endpoint.Client; import org.apache.cxf.ext.logging.LoggingFeature; import org.apache.cxf.frontend.ClientProxy; import org.apache.cxf.headers.Header; import org.apache.cxf.interceptor.Fault; import org.apache.cxf.phase.Phase; import org.apache.cxf.systest.ws.AbstractWSATestBase; import org.apache.cxf.systest.ws.addr_fromjava.client.AddNumberImpl; import org.apache.cxf.systest.ws.addr_fromjava.client.AddNumberImplService; import org.apache.cxf.systest.ws.addr_fromjava.client.AddNumbersException_Exception; import org.apache.cxf.systest.ws.addr_fromjava.server.Server; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; public class WSAFromJavaTest extends AbstractWSATestBase { static final String PORT = allocatePort(Server.class); @Before public void setUp() throws Exception { createBus(); } @BeforeClass public static void startServers() throws Exception { assertTrue("server did not launch correctly", launchServer(Server.class, true)); } @Test public void testAddNumbers() throws Exception { ByteArrayOutputStream input = setupInLogging(); ByteArrayOutputStream output = setupOutLogging(); AddNumberImpl port = getPort(); assertEquals(3, port.addNumbers(1, 2)); String expectedOut = "http://cxf.apache.org/input"; assertTrue(output.toString().indexOf(expectedOut) != -1); String expectedIn = "http://cxf.apache.org/output"; assertTrue(input.toString().indexOf(expectedIn) != -1); } @Test public void testAddNumbersFault() throws Exception { ByteArrayOutputStream input = setupInLogging(); ByteArrayOutputStream output = setupOutLogging(); AddNumberImpl port = getPort(); try { port.addNumbers(-1, 2); } catch (AddNumbersException_Exception e) { assert true; } catch (Exception e) { e.printStackTrace(); assert false; } assertTrue(output.toString().indexOf("http://cxf.apache.org/input") != -1); String expectedFault = "http://server.addr_fromjava.ws.systest.cxf.apache.org/AddNumberImpl/" + "addNumbers/Fault/AddNumbersException"; assertTrue(input.toString(), input.toString().indexOf(expectedFault) != -1); } @Test public void testAddNumbers2() throws Exception { ByteArrayOutputStream input = setupInLogging(); ByteArrayOutputStream output = setupOutLogging(); AddNumberImpl port = getPort(); assertEquals(3, port.addNumbers2(1, 2)); String base = "http://server.addr_fromjava.ws.systest.cxf.apache.org/AddNumberImpl"; String expectedOut = base + "/addNumbers2"; assertTrue(output.toString().indexOf(expectedOut) != -1); String expectedIn = base + "/addNumbers2Response"; assertTrue(input.toString().indexOf(expectedIn) != -1); } @Test public void testAddNumbers3Fault() throws Exception { ByteArrayOutputStream input = setupInLogging(); ByteArrayOutputStream output = setupOutLogging(); AddNumberImpl port = getPort(); try { port.addNumbers3(-1, 2); } catch (AddNumbersException_Exception e) { assert true; } catch (Exception e) { e.printStackTrace(); assert false; } assertTrue(output.toString(), output.toString().indexOf("http://cxf.apache.org/input") != -1); assertTrue(input.toString(), input.toString().indexOf("http://cxf.apache.org/fault3") != -1); } @Test public void testAddNumbersJaxWsContext() throws Exception { ByteArrayOutputStream output = setupOutLogging(); AddNumberImpl port = getPort(); BindingProvider bp = (BindingProvider)port; java.util.Map<String, Object> requestContext = bp.getRequestContext(); requestContext.put(BindingProvider.SOAPACTION_URI_PROPERTY, "cxf"); try { assertEquals(3, port.addNumbers(1, 2)); fail("Should have thrown an ActionNotSupported exception"); } catch (SOAPFaultException ex) { //expected } assertLogContains(output.toString(), "//wsa:Action", "cxf"); assertTrue(output.toString(), output.toString().indexOf("SOAPAction=\"cxf\"") != -1); } private AddNumberImpl getPort() throws Exception { URL wsdl = getClass().getResource("/wsdl_systest_wsspec/add_numbers-fromjava.wsdl"); assertNotNull("WSDL is null", wsdl); AddNumberImplService service = new AddNumberImplService(wsdl); assertNotNull("Service is null ", service); AddNumberImpl port = service.getAddNumberImplPort(); updateAddressPort(port, PORT); return port; } @Test public void testUnmatchedActions() throws Exception { AddNumberImpl port = getPort(); BindingProvider bp = (BindingProvider)port; java.util.Map<String, Object> requestContext = bp.getRequestContext(); requestContext.put(BindingProvider.SOAPACTION_URI_PROPERTY, "http://cxf.apache.org/input4"); try { //CXF-2035 port.addNumbers3(-1, -1); } catch (Exception e) { assertTrue(e.getMessage().contains("Unexpected wrapper")); } } @Test public void testFaultFromNonAddressService() throws Exception { new LoggingFeature().initialize(this.getBus()); AddNumberImpl port = getPort(); java.util.Map<String, Object> requestContext = ((BindingProvider)port).getRequestContext(); requestContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, "http://localhost:" + PORT + "/AddNumberImplPort-noaddr"); long start = System.currentTimeMillis(); port.addNumbers(1, 2); try { port.addNumbers3(-1, -1); } catch (Exception ex) { //ignore, expected } long end = System.currentTimeMillis(); assertTrue((end - start) < 50000); } static class RemoveRelatesToHeaderInterceptor extends AbstractSoapInterceptor { RemoveRelatesToHeaderInterceptor() { super(Phase.READ); addAfter(ReadHeadersInterceptor.class.getName()); } public void handleMessage(SoapMessage message) throws Fault { List<Header> headers = message.getHeaders(); Header h2 = null; for (Header h : headers) { if ("RelatesTo".equals(h.getName().getLocalPart())) { h2 = h; } } headers.remove(h2); } } @Test public void testNoRelatesToHeader() throws Exception { new LoggingFeature().initialize(this.getBus()); AddNumberImpl port = getPort(); Client c = ClientProxy.getClient(port); c.getInInterceptors().add(new RemoveRelatesToHeaderInterceptor()); long start = System.currentTimeMillis(); port.addNumbers(1, 2); try { port.addNumbers3(-1, -1); } catch (Exception ex) { //ignore, expected } long end = System.currentTimeMillis(); assertTrue((end - start) < 50000); } }