diff --git a/build/parents/build/pom.xml b/build/parents/build/pom.xml
index 2d750607601..91a7720dbdf 100644
--- a/build/parents/build/pom.xml
+++ b/build/parents/build/pom.xml
@@ -1018,6 +1018,10 @@
jdk-deprecated-16
jdk-deprecated-17
jdk-deprecated-18
+ jdk-deprecated-19
+ jdk-deprecated-20
+ jdk-deprecated-21
+ jdk-deprecated-22
jdk-internal-1.8
jdk-internal-9
@@ -1030,6 +1034,10 @@
jdk-internal-16
jdk-internal-17
jdk-internal-18
+ jdk-internal-19
+ jdk-internal-20
+ jdk-internal-21
+ jdk-internal-22
diff --git a/engine/src/main/java/org/hibernate/search/engine/environment/classpath/spi/DefaultResourceResolver.java b/engine/src/main/java/org/hibernate/search/engine/environment/classpath/spi/DefaultResourceResolver.java
index 2158420260e..5bf81af1ce6 100644
--- a/engine/src/main/java/org/hibernate/search/engine/environment/classpath/spi/DefaultResourceResolver.java
+++ b/engine/src/main/java/org/hibernate/search/engine/environment/classpath/spi/DefaultResourceResolver.java
@@ -9,6 +9,8 @@
import java.io.InputStream;
import java.net.URL;
+import org.hibernate.search.util.common.annotation.impl.SuppressForbiddenApis;
+
/**
* Default implementation of {@code ClassResolver} relying on an {@link AggregatedClassLoader}.
*
@@ -27,6 +29,8 @@ private DefaultResourceResolver(AggregatedClassLoader aggregatedClassLoader) {
}
@Override
+ @SuppressForbiddenApis(reason = "URL constructors are deprecated in JDK 20+ in favor of using URI.toURL(),"
+ + " but we want to preserve backward compatibility for now (see below).")
public InputStream locateResourceStream(String name) {
try {
final InputStream stream = aggregatedClassLoader.getResourceAsStream( name );
@@ -44,6 +48,8 @@ public InputStream locateResourceStream(String name) {
try {
@SuppressWarnings("deprecation")
// TODO: HSEARCH-4765 address the URL -> URI constructor change once the URLClassLoader stops using the URL constructor
+ // Main problem: would URI.create(stripped).toURL() fail, since `stripped` seems to be a relative URL?
+ // Do we even have test coverage for this line?
InputStream resourceStream = new URL( stripped ).openStream();
return resourceStream;
}
diff --git a/integrationtest/mapper/pojo-base/src/test/java/org/hibernate/search/integrationtest/mapper/pojo/testsupport/types/JavaNetURLPropertyTypeDescriptor.java b/integrationtest/mapper/pojo-base/src/test/java/org/hibernate/search/integrationtest/mapper/pojo/testsupport/types/JavaNetURLPropertyTypeDescriptor.java
index afb2332a3f6..ed07c2e1813 100644
--- a/integrationtest/mapper/pojo-base/src/test/java/org/hibernate/search/integrationtest/mapper/pojo/testsupport/types/JavaNetURLPropertyTypeDescriptor.java
+++ b/integrationtest/mapper/pojo-base/src/test/java/org/hibernate/search/integrationtest/mapper/pojo/testsupport/types/JavaNetURLPropertyTypeDescriptor.java
@@ -19,6 +19,7 @@
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.DocumentId;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.GenericField;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.Indexed;
+import org.hibernate.search.util.impl.test.annotation.SuppressForbiddenApis;
public class JavaNetURLPropertyTypeDescriptor extends PropertyTypeDescriptor {
@@ -156,11 +157,10 @@ private static URL url(String spec) {
}
}
- // TODO: HSEARCH-4765 To be removed when URL constructor is removed (JDK 20+). We keep it for now as users might still be using
- // this constructor and we want to test such scenario
+ @SuppressForbiddenApis(reason = "We want to test 'new URL(...)' even in JDK 20+ where it's deprecated")
private static URL urlAsNewUrl(String spec) {
try {
- @SuppressWarnings("deprecation")
+ @SuppressWarnings("deprecation") // We want to test 'new URL(...)' even in JDK 20+ where it's deprecated
URL url = new URL( spec );
return url;
}
diff --git a/util/common/src/main/java/org/hibernate/search/util/common/jar/impl/CodeSource.java b/util/common/src/main/java/org/hibernate/search/util/common/jar/impl/CodeSource.java
index d90d57ea102..b8a96b9bc3e 100644
--- a/util/common/src/main/java/org/hibernate/search/util/common/jar/impl/CodeSource.java
+++ b/util/common/src/main/java/org/hibernate/search/util/common/jar/impl/CodeSource.java
@@ -27,6 +27,7 @@
import java.util.Map;
import java.util.function.BiFunction;
+import org.hibernate.search.util.common.annotation.impl.SuppressForbiddenApis;
import org.hibernate.search.util.common.impl.Closer;
import org.hibernate.search.util.common.impl.SuppressingCloser;
import org.hibernate.search.util.common.impl.Throwables;
@@ -77,6 +78,8 @@ class CodeSource implements Closeable {
this.codeSourceLocation = codeSourceLocation;
}
+ @SuppressForbiddenApis(reason = "URL constructors are deprecated in JDK 20+ in favor of using URI.toURL(),"
+ + " but we need to start from URLs (not URIs) coming from java.security.CodeSource.")
public InputStream readOrNull(String resourcePathString) throws IOException {
Throwable exception = null;