提交 dfd5d64b 编写于 作者: A aefimov

8196491: Newlines in JAXB string values of SOAP-requests are escaped to "
"

Reviewed-by: lancea, rgrigoriadi
上级 5aae5b10
/* /*
* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
/* /*
* @test * @test
* @bug 8172297 * @bug 8172297 8196491
* @summary Test that carriage-return and new-line characters * @summary Test that carriage-return and new-line characters
* are preserved in webservice parameters * are preserved in webservice parameters
* @compile ws/HelloWorld.java ws/HelloWorldImpl.java Main.java * @compile ws/HelloWorld.java ws/HelloWorldImpl.java Main.java
...@@ -33,13 +33,21 @@ ...@@ -33,13 +33,21 @@
import java.io.IOException; import java.io.IOException;
import java.net.ServerSocket; import java.net.ServerSocket;
import java.net.URL; import java.net.URL;
import java.util.Collections;
import java.util.Set;
import java.util.concurrent.CountDownLatch; import java.util.concurrent.CountDownLatch;
import javax.xml.namespace.QName; import javax.xml.namespace.QName;
import javax.xml.soap.SOAPMessage;
import javax.xml.ws.Endpoint; import javax.xml.ws.Endpoint;
import javax.xml.ws.Service; import javax.xml.ws.Service;
import javax.xml.ws.handler.Handler;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
import org.testng.Assert; import org.testng.Assert;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import ws.HelloWorld; import ws.HelloWorld;
...@@ -47,9 +55,8 @@ import ws.HelloWorldImpl; ...@@ -47,9 +55,8 @@ import ws.HelloWorldImpl;
public class Main { public class Main {
@Test @Test(dataProvider="callHandlerDataProvider")
public void runTest() throws Exception { public void runTest(boolean callGetMessageInHandler) throws Exception {
//
CountDownLatch serverInitSignal = new CountDownLatch(1); CountDownLatch serverInitSignal = new CountDownLatch(1);
CountDownLatch testDoneSignal = new CountDownLatch(1); CountDownLatch testDoneSignal = new CountDownLatch(1);
...@@ -58,23 +65,31 @@ public class Main { ...@@ -58,23 +65,31 @@ public class Main {
serverInitSignal.await(); serverInitSignal.await();
boolean paramModified = runClientCode(serverThread.getPort()); boolean paramModified = runClientCode(serverThread.getPort(), callGetMessageInHandler);
testDoneSignal.countDown(); testDoneSignal.countDown();
Assert.assertFalse(paramModified, "WS parameter was modified during round trip."); Assert.assertEquals(callGetMessageInHandler, paramModified,
"WS parameter has not been processed as expected");
}
@DataProvider
public Object[][] callHandlerDataProvider() {
return new Object[][]{{true}, {false}};
} }
/* /*
* Connects to launched web service endpoint, sends message with CR/NL symbols and * Connects to launched web service endpoint, sends message with CR/NL symbols and
* checks if it was modified during the round trip client/server communication. * checks if it was modified during the round trip client/server communication.
*/ */
private boolean runClientCode(int port) throws Exception { private boolean runClientCode(int port, boolean callGetMessage) throws Exception {
System.out.println("Launching WS client connection on " + port + " port"); System.out.println("Launching WS client connection on " + port + " port");
URL url = new URL("http://localhost:" + port + "/ws/hello?wsdl"); URL url = new URL("http://localhost:" + port + "/ws/hello?wsdl");
QName qname = new QName("http://ws/", "HelloWorldImplService"); QName qname = new QName("http://ws/", "HelloWorldImplService");
Service service = Service.create(url, qname); Service service = Service.create(url, qname);
registerHandler(service, callGetMessage);
HelloWorld hello = (HelloWorld) service.getPort(HelloWorld.class); HelloWorld hello = (HelloWorld) service.getPort(HelloWorld.class);
logStringContent("Client input parameter", WS_PARAM_VALUE); logStringContent("Client input parameter", WS_PARAM_VALUE);
...@@ -85,6 +100,45 @@ public class Main { ...@@ -85,6 +100,45 @@ public class Main {
return !WS_PARAM_VALUE.equals(response); return !WS_PARAM_VALUE.equals(response);
} }
/*
* Register message handler and call SOAPMessageContext.getMessage
* to emulate issue reported in JDK-8196491
*/
private void registerHandler(Service service, final boolean callGetMessage) {
System.out.printf( "Client %s call getMessage inside message handler%n",
callGetMessage ? "will" : "will not" );
// Set custom SOAP message handler resolver
service.setHandlerResolver(portInfo -> {
Handler h = new SOAPHandler<SOAPMessageContext>() {
@Override
public boolean handleMessage(SOAPMessageContext context) {
if (callGetMessage) {
// Trigger exception from JDK-8196491
SOAPMessage msg = context.getMessage();
}
return true;
}
@Override
public boolean handleFault(SOAPMessageContext context) {
return true;
}
@Override
public void close(MessageContext context) {
}
@Override
public Set<QName> getHeaders() {
return null;
}
};
return Collections.singletonList(h);
});
}
/* /*
* Outputs the parameter value with newline and carriage-return symbols * Outputs the parameter value with newline and carriage-return symbols
* replaced with #CR and #NL text abbreviations. * replaced with #CR and #NL text abbreviations.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册