/hg/icedtea8-forest/jdk: 7 new changesets

andrew at icedtea.classpath.org andrew at icedtea.classpath.org
Tue Oct 17 02:42:48 UTC 2017


changeset 5b91bf11d0f4 in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=5b91bf11d0f4
author: andrew
date: Wed Oct 11 16:25:08 2017 +0100

	8188030, PR3459, RH1484079: AWT java apps fail to start when some minimal fonts are present
	Summary: Handle CFF fonts
	Reviewed-by: andrew, prr


changeset fed53dfb884f in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=fed53dfb884f
author: aefimov
date: Tue Dec 20 14:08:20 2016 +0300

	8146086, PR3439: Publishing two webservices on same port fails with "java.net.BindException: Address already in use"
	Reviewed-by: coffeys


changeset b107345220cb in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=b107345220cb
author: andrew
date: Mon Oct 16 19:02:19 2017 +0100

	8165852, PR3468: (fs) Mount point not found for a file which is present in overlayfs
	Summary: Check /proc/mounts for directories not in /etc/mtab
	Contributed-by: Fridrich Strba <fridrich.strba at suse.com>


changeset 161fbe4c53ff in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=161fbe4c53ff
author: andrew
date: Mon Oct 16 20:59:08 2017 +0100

	PR3469: Alternative path to tzdb.dat
	Summary: Allow an alternative tzdb.dat location to be specified in tz.properties
	Contributed-by: Fridrich Strba <fridrich.strba at suse.com>


changeset bcaa659478cc in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=bcaa659478cc
author: vtewari
date: Mon Oct 16 22:25:11 2017 +0100

	8075484, PR3473, RH1490713: SocketInputStream.socketRead0 can hang even with soTimeout set
	Reviewed-by: chegar, dsamersoff, msheppar, clanger


changeset bf62c56e3604 in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=bf62c56e3604
author: clanger
date: Mon Jul 17 11:47:12 2017 +0200

	8184673, PR3475, RH1487266: Fix compatibility issue in AlgorithmChecker for 3rd party JCE providers
	Reviewed-by: ascarpino, mullan


changeset 5dcb55da00c1 in /hg/icedtea8-forest/jdk
details: http://icedtea.classpath.org/hg/icedtea8-forest/jdk?cmd=changeset;node=5dcb55da00c1
author: andrew
date: Mon Oct 16 23:47:52 2017 +0100

	PR3479: ECC and NSS JVM crash
	Summary: SunEC provider can have multiple instances, leading to premature NSS shutdown
	Contributed-by: Martin Balao <mbalao at redhat.com>


diffstat:

 make/mapfiles/libsunec/mapfile-vers                                    |   1 -
 src/aix/native/java/net/aix_close.c                                    |  19 +-
 src/share/classes/sun/security/ec/SunEC.java                           |  13 -
 src/share/classes/sun/security/provider/certpath/AlgorithmChecker.java |   2 +-
 src/share/classes/sun/util/calendar/ZoneInfoFile.java                  |  33 +++-
 src/share/native/sun/security/ec/ECC_JNI.cpp                           |   8 +-
 src/solaris/classes/sun/nio/fs/LinuxFileStore.java                     |  12 +-
 src/solaris/native/java/net/SocketInputStream.c                        |  53 +++++-
 src/solaris/native/java/net/bsd_close.c                                |  13 +-
 src/solaris/native/java/net/linux_close.c                              |  18 +-
 src/solaris/native/java/net/net_util_md.c                              |  18 ++
 src/solaris/native/java/net/net_util_md.h                              |   4 +
 src/solaris/native/sun/awt/fontpath.c                                  |   1 +
 test/javax/xml/ws/publish/WSTest.java                                  |  86 ++++++++++
 14 files changed, 228 insertions(+), 53 deletions(-)

diffs (truncated from 522 to 500 lines):

diff -r 7b1a2f967cd8 -r 5dcb55da00c1 make/mapfiles/libsunec/mapfile-vers
--- a/make/mapfiles/libsunec/mapfile-vers	Mon Jul 31 04:13:27 2017 +0100
+++ b/make/mapfiles/libsunec/mapfile-vers	Mon Oct 16 23:47:52 2017 +0100
@@ -32,7 +32,6 @@
                 Java_sun_security_ec_ECDSASignature_verifySignedDigest;
                 Java_sun_security_ec_ECDHKeyAgreement_deriveKey;
 		Java_sun_security_ec_SunEC_initialize;
-		Java_sun_security_ec_SunEC_cleanup;
         local:
                 *;
 };
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/aix/native/java/net/aix_close.c
--- a/src/aix/native/java/net/aix_close.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/aix/native/java/net/aix_close.c	Mon Oct 16 23:47:52 2017 +0100
@@ -1,5 +1,6 @@
 /*
- * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, SAP SE and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -340,6 +341,10 @@
     BLOCKING_IO_RETURN_INT( s, recv(s, buf, len, 0) );
 }
 
+int NET_NonBlockingRead(int s, void* buf, size_t len) {
+    BLOCKING_IO_RETURN_INT(s, recv(s, buf, len, MSG_NONBLOCK));
+}
+
 int NET_ReadV(int s, const struct iovec * vector, int count) {
     BLOCKING_IO_RETURN_INT( s, readv(s, vector, count) );
 }
@@ -441,8 +446,8 @@
  * Auto restarts with adjusted timeout if interrupted by
  * signal other than our wakeup signal.
  */
-int NET_Timeout(int s, long timeout) {
-    long prevtime = 0, newtime;
+int NET_Timeout0(int s, long timeout, long currentTime) {
+    long prevtime = currentTime, newtime;
     struct timeval t;
     fdEntry_t *fdEntry = getFdEntry(s);
 
@@ -454,14 +459,6 @@
         return -1;
     }
 
-    /*
-     * Pick up current time as may need to adjust timeout
-     */
-    if (timeout > 0) {
-        gettimeofday(&t, NULL);
-        prevtime = t.tv_sec * 1000  +  t.tv_usec / 1000;
-    }
-
     for(;;) {
         struct pollfd pfd;
         int rv;
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/share/classes/sun/security/ec/SunEC.java
--- a/src/share/classes/sun/security/ec/SunEC.java	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/share/classes/sun/security/ec/SunEC.java	Mon Oct 16 23:47:52 2017 +0100
@@ -83,21 +83,8 @@
     }
 
     /**
-     * Cleanup native resources during finalisation.
-     */
-    @Override
-    protected void finalize() {
-        cleanup();
-    }
-
-    /**
      * Initialize the native code.
      */
     private static native void initialize();
 
-    /**
-     * Cleanup in the native layer.
-     */
-    private static native void cleanup();
-
 }
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/share/classes/sun/security/provider/certpath/AlgorithmChecker.java
--- a/src/share/classes/sun/security/provider/certpath/AlgorithmChecker.java	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/share/classes/sun/security/provider/certpath/AlgorithmChecker.java	Mon Oct 16 23:47:52 2017 +0100
@@ -270,7 +270,7 @@
 
         AlgorithmParameters currSigAlgParams = algorithmId.getParameters();
         PublicKey currPubKey = cert.getPublicKey();
-        String currSigAlg = ((X509Certificate)cert).getSigAlgName();
+        String currSigAlg = x509Cert.getSigAlgName();
 
         // Check the signature algorithm and parameters against constraints.
         if (!constraints.permits(SIGNATURE_PRIMITIVE_SET, currSigAlg,
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/share/classes/sun/util/calendar/ZoneInfoFile.java
--- a/src/share/classes/sun/util/calendar/ZoneInfoFile.java	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/share/classes/sun/util/calendar/ZoneInfoFile.java	Mon Oct 16 23:47:52 2017 +0100
@@ -31,6 +31,7 @@
 import java.io.DataInputStream;
 import java.io.File;
 import java.io.FileInputStream;
+import java.io.InputStream;
 import java.io.IOException;
 import java.io.StreamCorruptedException;
 import java.security.AccessController;
@@ -47,6 +48,7 @@
 import java.util.Map;
 import java.util.Map.Entry;
 import java.util.Objects;
+import java.util.Properties;
 import java.util.Set;
 import java.util.SimpleTimeZone;
 import java.util.concurrent.ConcurrentHashMap;
@@ -251,7 +253,15 @@
         AccessController.doPrivileged(new PrivilegedAction<Object>() {
             public Object run() {
                 try {
-                    String libDir = System.getProperty("java.home") + File.separator + "lib";
+                    final String homeDir = System.getProperty("java.home");
+                    if (homeDir == null) {
+                        throw new Error("java.home is not set");
+                    }
+                    String libDir = homeDir + File.separator + "lib";
+                    String otherDir = getZoneInfoDir(libDir);
+                    if (otherDir != null)
+                        libDir = otherDir;
+
                     try (DataInputStream dis = new DataInputStream(
                              new BufferedInputStream(new FileInputStream(
                                  new File(libDir, "tzdb.dat"))))) {
@@ -265,6 +275,27 @@
         });
     }
 
+    private static String getZoneInfoDir(final String libDir) {
+        return AccessController.doPrivileged (new PrivilegedAction<String>() {
+            public String run() {
+                File f = new File(libDir + File.separator + "tz.properties");
+                try (BufferedInputStream bin = new BufferedInputStream(new FileInputStream(f))) {
+                    Properties props = new Properties();
+                    props.load(bin);
+                    String dir = props.getProperty("sun.zoneinfo.dir");
+                    if (dir == null)
+                        return null;
+                    File tzdbdat = new File(dir, "tzdb.dat");
+                    if (tzdbdat.exists())
+                        return dir;
+                    return null;
+                } catch (Exception x) {
+                    return null;
+                }
+            }
+        });
+    }
+
     private static void addOldMapping() {
         for (String[] alias : oldMappings) {
             aliases.put(alias[0], alias[1]);
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/share/native/sun/security/ec/ECC_JNI.cpp
--- a/src/share/native/sun/security/ec/ECC_JNI.cpp	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/share/native/sun/security/ec/ECC_JNI.cpp	Mon Oct 16 23:47:52 2017 +0100
@@ -525,14 +525,12 @@
 }
 
 JNIEXPORT void
-JNICALL Java_sun_security_ec_SunEC_cleanup
-  (JNIEnv *env, jclass UNUSED(clazz))
+JNICALL JNI_OnUnload
+  (JavaVM *vm, void *reserved)
 {
 #ifdef SYSTEM_NSS
     RNG_RNGShutdown();
-    if (SECOID_Shutdown() != SECSuccess) {
-	ThrowException(env, INTERNAL_ERROR);
-    }
+    SECOID_Shutdown();
 #endif
 }
 
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/classes/sun/nio/fs/LinuxFileStore.java
--- a/src/solaris/classes/sun/nio/fs/LinuxFileStore.java	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/classes/sun/nio/fs/LinuxFileStore.java	Mon Oct 16 23:47:52 2017 +0100
@@ -74,8 +74,16 @@
             } catch (UnixException x) {
                 x.rethrowAsIOException(parent);
             }
-            if (attrs.dev() != dev())
-                break;
+            if (attrs.dev() != dev()) {
+
+                // step 3: lookup mounted file systems (use /proc/mounts to ensure we
+                // find the file system even when not in /etc/mtab)
+                byte[] dir = path.asByteArray();
+                for (UnixMountEntry entry: fs.getMountEntries("/proc/mounts")) {
+                    if (Arrays.equals(dir, entry.dir()))
+                        return entry;
+                }
+            }
             path = parent;
             parent = parent.getParent();
         }
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/java/net/SocketInputStream.c
--- a/src/solaris/native/java/net/SocketInputStream.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/java/net/SocketInputStream.c	Mon Oct 16 23:47:52 2017 +0100
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -52,6 +52,42 @@
     IO_fd_fdID = NET_GetFileDescriptorID(env);
 }
 
+#if !defined(__solaris__)
+static int NET_ReadWithTimeout(JNIEnv *env, int fd, char *bufP, int len, long timeout) {
+    int result = 0;
+    long prevtime = NET_GetCurrentTime(), newtime;
+    while (timeout > 0) {
+        result = NET_TimeoutWithCurrentTime(fd, timeout, prevtime);
+        if (result <= 0) {
+            if (result == 0) {
+                JNU_ThrowByName(env, "java/net/SocketTimeoutException", "Read timed out");
+            } else if (result == -1) {
+                if (errno == EBADF) {
+                    JNU_ThrowByName(env, "java/net/SocketException", "Socket closed");
+                } else if (errno == ENOMEM) {
+                    JNU_ThrowOutOfMemoryError(env, "NET_Timeout native heap allocation failed");
+                } else {
+                    JNU_ThrowByNameWithMessageAndLastError
+                            (env, "java/net/SocketException", "select/poll failed");
+                }
+            }
+            return -1;
+        }
+        result = NET_NonBlockingRead(fd, bufP, len);
+        if (result == -1 && ((errno == EAGAIN) || (errno == EWOULDBLOCK))) {
+            newtime = NET_GetCurrentTime();
+            timeout -= newtime - prevtime;
+            if (timeout > 0) {
+                prevtime = newtime;
+            }
+        } else {
+            break;
+        }
+    }
+    return result;
+}
+#endif
+
 /*
  * Class:     java_net_SocketInputStream
  * Method:    socketRead0
@@ -99,6 +135,7 @@
         bufP = BUF;
     }
 
+#if defined(__solaris__)
     if (timeout) {
         nread = NET_Timeout(fd, timeout);
         if (nread <= 0) {
@@ -123,7 +160,19 @@
     }
 
     nread = NET_Read(fd, bufP, len);
-
+#else
+    if (timeout) {
+        nread = NET_ReadWithTimeout(env, fd, bufP, len, timeout);
+        if ((*env)->ExceptionCheck(env)) {
+            if (bufP != BUF) {
+                free(bufP);
+            }
+            return nread;
+        }
+    } else {
+        nread = NET_Read(fd, bufP, len);
+    }
+#endif
     if (nread <= 0) {
         if (nread < 0) {
 
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/java/net/bsd_close.c
--- a/src/solaris/native/java/net/bsd_close.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/java/net/bsd_close.c	Mon Oct 16 23:47:52 2017 +0100
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -292,6 +292,10 @@
     BLOCKING_IO_RETURN_INT( s, recv(s, buf, len, 0) );
 }
 
+int NET_NonBlockingRead(int s, void* buf, size_t len) {
+    BLOCKING_IO_RETURN_INT( s, recv(s, buf, len, MSG_DONTWAIT));
+}
+
 int NET_ReadV(int s, const struct iovec * vector, int count) {
     BLOCKING_IO_RETURN_INT( s, readv(s, vector, count) );
 }
@@ -339,8 +343,8 @@
  * Auto restarts with adjusted timeout if interrupted by
  * signal other than our wakeup signal.
  */
-int NET_Timeout(int s, long timeout) {
-    long prevtime = 0, newtime;
+int NET_Timeout0(int s, long timeout, long currentTime) {
+    long prevtime = currentTime, newtime;
     struct timeval t, *tp = &t;
     fd_set fds;
     fd_set* fdsp = NULL;
@@ -361,9 +365,6 @@
      */
     if (timeout > 0) {
         /* Timed */
-        struct timeval now;
-        gettimeofday(&now, NULL);
-        prevtime = now.tv_sec * 1000  +  now.tv_usec / 1000;
         t.tv_sec = timeout / 1000;
         t.tv_usec = (timeout % 1000) * 1000;
     } else if (timeout < 0) {
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/java/net/linux_close.c
--- a/src/solaris/native/java/net/linux_close.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/java/net/linux_close.c	Mon Oct 16 23:47:52 2017 +0100
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -273,6 +273,10 @@
     BLOCKING_IO_RETURN_INT( s, recv(s, buf, len, 0) );
 }
 
+int NET_NonBlockingRead(int s, void* buf, size_t len) {
+    BLOCKING_IO_RETURN_INT( s, recv(s, buf, len, MSG_DONTWAIT) );
+}
+
 int NET_ReadV(int s, const struct iovec * vector, int count) {
     BLOCKING_IO_RETURN_INT( s, readv(s, vector, count) );
 }
@@ -320,8 +324,8 @@
  * Auto restarts with adjusted timeout if interrupted by
  * signal other than our wakeup signal.
  */
-int NET_Timeout(int s, long timeout) {
-    long prevtime = 0, newtime;
+int NET_Timeout0(int s, long timeout, long currentTime) {
+    long prevtime = currentTime, newtime;
     struct timeval t;
     fdEntry_t *fdEntry = getFdEntry(s);
 
@@ -333,14 +337,6 @@
         return -1;
     }
 
-    /*
-     * Pick up current time as may need to adjust timeout
-     */
-    if (timeout > 0) {
-        gettimeofday(&t, NULL);
-        prevtime = t.tv_sec * 1000  +  t.tv_usec / 1000;
-    }
-
     for(;;) {
         struct pollfd pfd;
         int rv;
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/java/net/net_util_md.c
--- a/src/solaris/native/java/net/net_util_md.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/java/net/net_util_md.c	Mon Oct 16 23:47:52 2017 +0100
@@ -33,6 +33,7 @@
 #include <netdb.h>
 #include <stdlib.h>
 #include <dlfcn.h>
+#include <sys/time.h>
 
 #ifndef _ALLBSD_SOURCE
 #include <values.h>
@@ -1678,3 +1679,20 @@
 
     return timeout;
 }
+
+#if !defined(__solaris__)
+long NET_GetCurrentTime() {
+    struct timeval time;
+    gettimeofday(&time, NULL);
+    return (time.tv_sec * 1000 + time.tv_usec / 1000);
+}
+
+int NET_TimeoutWithCurrentTime(int s, long timeout, long currentTime) {
+    return NET_Timeout0(s, timeout, currentTime);
+}
+
+int NET_Timeout(int s, long timeout) {
+    long currentTime = (timeout > 0) ? NET_GetCurrentTime() : 0;
+    return NET_Timeout0(s, timeout, currentTime);
+}
+#endif
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/java/net/net_util_md.h
--- a/src/solaris/native/java/net/net_util_md.h	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/java/net/net_util_md.h	Mon Oct 16 23:47:52 2017 +0100
@@ -37,7 +37,11 @@
 #endif
 
 int NET_Timeout(int s, long timeout);
+int NET_Timeout0(int s, long timeout, long currentTime);
 int NET_Read(int s, void* buf, size_t len);
+int NET_NonBlockingRead(int s, void* buf, size_t len);
+int NET_TimeoutWithCurrentTime(int s, long timeout, long currentTime);
+long NET_GetCurrentTime();
 int NET_RecvFrom(int s, void *buf, int len, unsigned int flags,
                  struct sockaddr *from, socklen_t *fromlen);
 int NET_ReadV(int s, const struct iovec * vector, int count);
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 src/solaris/native/sun/awt/fontpath.c
--- a/src/solaris/native/sun/awt/fontpath.c	Mon Jul 31 04:13:27 2017 +0100
+++ b/src/solaris/native/sun/awt/fontpath.c	Mon Oct 16 23:47:52 2017 +0100
@@ -1233,6 +1233,7 @@
                 && (strcmp((char*)fontformat, "TrueType") != 0)
 #if defined(__linux__) || defined(_AIX)
                 && (strcmp((char*)fontformat, "Type 1") != 0)
+                && (strcmp((char*)fontformat, "CFF") != 0)
 #endif
              ) {
                 continue;
diff -r 7b1a2f967cd8 -r 5dcb55da00c1 test/javax/xml/ws/publish/WSTest.java
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/test/javax/xml/ws/publish/WSTest.java	Mon Oct 16 23:47:52 2017 +0100
@@ -0,0 +1,86 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+/*
+ * @test
+ * @bug 8146086
+ * @summary Publishing two webservices on same port fails with "java.net.BindException: Address already in use"
+ * @run main/othervm WSTest
+ */
+import javax.jws.WebMethod;
+import javax.jws.WebService;
+import javax.xml.ws.Endpoint;
+import java.net.ServerSocket;
+
+public class WSTest {
+
+    @WebService(targetNamespace = "test")
+    public static class Method1 {
+        @WebMethod
+        public String getMethod1Value() {
+            return "from Method1";
+        }
+    }
+
+    @WebService(targetNamespace = "test")
+    public static class Method2 {
+        @WebMethod
+        public String getMethod2Value() {
+            return "from Method2";
+        }
+    }
+
+    public static void main(String[] args) throws Exception {
+
+        // find a free port
+        ServerSocket ss = new ServerSocket(0);
+        int port = ss.getLocalPort();
+        ss.close();
+
+        Endpoint endPoint1 = null;
+        Endpoint endPoint2 = null;
+        try {
+            endPoint1 = Endpoint.publish("http://0.0.0.0:" + port + "/method1",
+                    new Method1());


More information about the distro-pkg-dev mailing list