Polish "Add hints to instantiate HttpService group adapters"
See gh-35038
This commit is contained in:
parent
8142f80581
commit
8bf9e0cbff
|
@ -1,40 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2002-2025 the original author or authors.
|
|
||||||
*
|
|
||||||
* Licensed 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
|
|
||||||
*
|
|
||||||
* https://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.springframework.web.client.support;
|
|
||||||
|
|
||||||
import org.jspecify.annotations.Nullable;
|
|
||||||
|
|
||||||
import org.springframework.aot.hint.MemberCategory;
|
|
||||||
import org.springframework.aot.hint.RuntimeHints;
|
|
||||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
|
||||||
import org.springframework.aot.hint.TypeReference;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link RuntimeHintsRegistrar} implementation that adds hints for {@link RestClientHttpServiceGroupAdapter}.
|
|
||||||
*
|
|
||||||
* @author Olga Maciaszek-Sharma
|
|
||||||
* @since 7.0
|
|
||||||
*/
|
|
||||||
public class RestClientHttpServiceGroupAdapterRuntimeHints implements RuntimeHintsRegistrar {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void registerHints(RuntimeHints hints, @Nullable ClassLoader classLoader) {
|
|
||||||
hints.reflection()
|
|
||||||
.registerType(TypeReference.of(RestClientHttpServiceGroupAdapter.class),
|
|
||||||
MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -27,6 +27,10 @@ import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.jspecify.annotations.Nullable;
|
import org.jspecify.annotations.Nullable;
|
||||||
|
|
||||||
|
import org.springframework.aot.hint.MemberCategory;
|
||||||
|
import org.springframework.aot.hint.RuntimeHints;
|
||||||
|
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
||||||
|
import org.springframework.aot.hint.TypeReference;
|
||||||
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.BeanUtils;
|
||||||
import org.springframework.beans.BeansException;
|
import org.springframework.beans.BeansException;
|
||||||
import org.springframework.beans.factory.BeanClassLoaderAware;
|
import org.springframework.beans.factory.BeanClassLoaderAware;
|
||||||
|
@ -126,14 +130,15 @@ public final class HttpServiceProxyRegistryFactoryBean
|
||||||
|
|
||||||
private static class GroupAdapterInitializer {
|
private static class GroupAdapterInitializer {
|
||||||
|
|
||||||
|
private static final String REST_CLIENT_HTTP_SERVICE_GROUP_ADAPTER = "org.springframework.web.client.support.RestClientHttpServiceGroupAdapter";
|
||||||
|
|
||||||
|
private static final String WEB_CLIENT_HTTP_SERVICE_GROUP_ADAPTER = "org.springframework.web.reactive.function.client.support.WebClientHttpServiceGroupAdapter";
|
||||||
|
|
||||||
static Map<HttpServiceGroup.ClientType, HttpServiceGroupAdapter<?>> initGroupAdapters() {
|
static Map<HttpServiceGroup.ClientType, HttpServiceGroupAdapter<?>> initGroupAdapters() {
|
||||||
Map<HttpServiceGroup.ClientType, HttpServiceGroupAdapter<?>> map = new LinkedHashMap<>(2);
|
Map<HttpServiceGroup.ClientType, HttpServiceGroupAdapter<?>> map = new LinkedHashMap<>(2);
|
||||||
|
|
||||||
addGroupAdapter(map, HttpServiceGroup.ClientType.REST_CLIENT,
|
addGroupAdapter(map, HttpServiceGroup.ClientType.REST_CLIENT, REST_CLIENT_HTTP_SERVICE_GROUP_ADAPTER);
|
||||||
"org.springframework.web.client.support.RestClientHttpServiceGroupAdapter");
|
addGroupAdapter(map, HttpServiceGroup.ClientType.WEB_CLIENT, WEB_CLIENT_HTTP_SERVICE_GROUP_ADAPTER);
|
||||||
|
|
||||||
addGroupAdapter(map, HttpServiceGroup.ClientType.WEB_CLIENT,
|
|
||||||
"org.springframework.web.reactive.function.client.support.WebClientHttpServiceGroupAdapter");
|
|
||||||
|
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
@ -314,4 +319,17 @@ public final class HttpServiceProxyRegistryFactoryBean
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static class HttpServiceProxyRegistryRuntimeHints implements RuntimeHintsRegistrar {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void registerHints(RuntimeHints hints, @Nullable ClassLoader classLoader) {
|
||||||
|
hints.reflection()
|
||||||
|
.registerType(TypeReference.of(GroupAdapterInitializer.REST_CLIENT_HTTP_SERVICE_GROUP_ADAPTER),
|
||||||
|
MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS)
|
||||||
|
.registerTypeIfPresent(classLoader, GroupAdapterInitializer.WEB_CLIENT_HTTP_SERVICE_GROUP_ADAPTER,
|
||||||
|
MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,8 +3,8 @@ org.springframework.http.HttpMimeTypesRuntimeHints,\
|
||||||
org.springframework.http.codec.CodecConfigurerRuntimeHints,\
|
org.springframework.http.codec.CodecConfigurerRuntimeHints,\
|
||||||
org.springframework.http.converter.json.JacksonModulesRuntimeHints,\
|
org.springframework.http.converter.json.JacksonModulesRuntimeHints,\
|
||||||
org.springframework.http.converter.json.ProblemDetailRuntimeHints,\
|
org.springframework.http.converter.json.ProblemDetailRuntimeHints,\
|
||||||
org.springframework.web.util.WebUtilRuntimeHints,\
|
org.springframework.web.service.registry.HttpServiceProxyRegistryFactoryBean.HttpServiceProxyRegistryRuntimeHints,\
|
||||||
org.springframework.web.client.support.RestClientHttpServiceGroupAdapterRuntimeHints
|
org.springframework.web.util.WebUtilRuntimeHints
|
||||||
|
|
||||||
org.springframework.beans.factory.aot.BeanRegistrationAotProcessor=\
|
org.springframework.beans.factory.aot.BeanRegistrationAotProcessor=\
|
||||||
org.springframework.web.service.annotation.HttpExchangeBeanRegistrationAotProcessor,\
|
org.springframework.web.service.annotation.HttpExchangeBeanRegistrationAotProcessor,\
|
||||||
|
|
|
@ -16,43 +16,32 @@
|
||||||
|
|
||||||
package org.springframework.web.client.support;
|
package org.springframework.web.client.support;
|
||||||
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import org.springframework.aot.hint.MemberCategory;
|
|
||||||
import org.springframework.aot.hint.RuntimeHints;
|
import org.springframework.aot.hint.RuntimeHints;
|
||||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
||||||
import org.springframework.aot.hint.predicate.RuntimeHintsPredicates;
|
import org.springframework.aot.hint.predicate.RuntimeHintsPredicates;
|
||||||
import org.springframework.core.io.support.SpringFactoriesLoader;
|
import org.springframework.beans.factory.aot.AotServices;
|
||||||
import org.springframework.util.ClassUtils;
|
import org.springframework.util.ClassUtils;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for {@link RestClientHttpServiceGroupAdapterRuntimeHints}.
|
* Tests for {@link RestClientHttpServiceGroupAdapter}.
|
||||||
*
|
*
|
||||||
* @author Olga Maciaszek-Sharma
|
* @author Olga Maciaszek-Sharma
|
||||||
|
* @author Stephane Nicoll
|
||||||
*/
|
*/
|
||||||
class RestClientHttpServiceGroupAdapterRuntimeHintsRegistrarTests {
|
class RestClientHttpServiceGroupAdapterTests {
|
||||||
|
|
||||||
private RuntimeHints hints;
|
|
||||||
|
|
||||||
@BeforeEach
|
|
||||||
void setUp() {
|
|
||||||
this.hints = new RuntimeHints();
|
|
||||||
SpringFactoriesLoader.forResourceLocation("META-INF/spring/aot.factories")
|
|
||||||
.load(RuntimeHintsRegistrar.class)
|
|
||||||
.forEach(registrar ->
|
|
||||||
registrar.registerHints(this.hints, ClassUtils.getDefaultClassLoader()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldRegisterHintsForAdapter() {
|
void registerInstantiationHints() throws Exception {
|
||||||
|
RuntimeHints hints = new RuntimeHints();
|
||||||
|
AotServices.factories().load(RuntimeHintsRegistrar.class)
|
||||||
|
.forEach(registrar -> registrar.registerHints(hints,
|
||||||
|
ClassUtils.getDefaultClassLoader()));
|
||||||
assertThat(RuntimeHintsPredicates.reflection()
|
assertThat(RuntimeHintsPredicates.reflection()
|
||||||
.onType(RestClientHttpServiceGroupAdapter.class)
|
.onConstructorInvocation(RestClientHttpServiceGroupAdapter.class.getConstructor())).accepts(hints);
|
||||||
.withMemberCategory(MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS))
|
|
||||||
.accepts(this.hints);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,40 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2002-2025 the original author or authors.
|
|
||||||
*
|
|
||||||
* Licensed 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
|
|
||||||
*
|
|
||||||
* https://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.springframework.web.reactive.function.client.support;
|
|
||||||
|
|
||||||
import org.jspecify.annotations.Nullable;
|
|
||||||
|
|
||||||
import org.springframework.aot.hint.MemberCategory;
|
|
||||||
import org.springframework.aot.hint.RuntimeHints;
|
|
||||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
|
||||||
import org.springframework.aot.hint.TypeReference;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link RuntimeHintsRegistrar} implementation that adds hints for {@link WebClientHttpServiceGroupAdapter}.
|
|
||||||
*
|
|
||||||
* @author Olga Maciaszek-Sharma
|
|
||||||
* @since 7.0
|
|
||||||
*/
|
|
||||||
public class WebClientHttpServiceGroupAdapterRuntimeHints implements RuntimeHintsRegistrar {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void registerHints(RuntimeHints hints, @Nullable ClassLoader classLoader) {
|
|
||||||
hints.reflection()
|
|
||||||
.registerType(TypeReference.of(WebClientHttpServiceGroupAdapter.class),
|
|
||||||
MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,2 +0,0 @@
|
||||||
org.springframework.aot.hint.RuntimeHintsRegistrar= \
|
|
||||||
org.springframework.web.reactive.function.client.support.WebClientHttpServiceGroupAdapterRuntimeHints
|
|
|
@ -16,43 +16,32 @@
|
||||||
|
|
||||||
package org.springframework.web.reactive.function.client.support;
|
package org.springframework.web.reactive.function.client.support;
|
||||||
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import org.springframework.aot.hint.MemberCategory;
|
|
||||||
import org.springframework.aot.hint.RuntimeHints;
|
import org.springframework.aot.hint.RuntimeHints;
|
||||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
||||||
import org.springframework.aot.hint.predicate.RuntimeHintsPredicates;
|
import org.springframework.aot.hint.predicate.RuntimeHintsPredicates;
|
||||||
import org.springframework.core.io.support.SpringFactoriesLoader;
|
import org.springframework.beans.factory.aot.AotServices;
|
||||||
import org.springframework.util.ClassUtils;
|
import org.springframework.util.ClassUtils;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for {@link WebClientHttpServiceGroupAdapterRuntimeHints}.
|
* Tests for {@link WebClientHttpServiceGroupAdapter}.
|
||||||
*
|
*
|
||||||
* @author Olga Maciaszek-Sharma
|
* @author Olga Maciaszek-Sharma
|
||||||
|
* @author Stephane Nicoll
|
||||||
*/
|
*/
|
||||||
class WebClientHttpServiceGroupAdapterRuntimeHintsTests {
|
class WebClientHttpServiceGroupAdapterTests {
|
||||||
|
|
||||||
private RuntimeHints hints;
|
|
||||||
|
|
||||||
@BeforeEach
|
|
||||||
void setUp() {
|
|
||||||
this.hints = new RuntimeHints();
|
|
||||||
SpringFactoriesLoader.forResourceLocation("META-INF/spring/aot.factories")
|
|
||||||
.load(RuntimeHintsRegistrar.class)
|
|
||||||
.forEach(registrar ->
|
|
||||||
registrar.registerHints(this.hints, ClassUtils.getDefaultClassLoader()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldRegisterHintsForAdapter() {
|
void registerInstantiationHints() throws Exception {
|
||||||
|
RuntimeHints hints = new RuntimeHints();
|
||||||
|
AotServices.factories().load(RuntimeHintsRegistrar.class)
|
||||||
|
.forEach(registrar -> registrar.registerHints(hints,
|
||||||
|
ClassUtils.getDefaultClassLoader()));
|
||||||
assertThat(RuntimeHintsPredicates.reflection()
|
assertThat(RuntimeHintsPredicates.reflection()
|
||||||
.onType(WebClientHttpServiceGroupAdapter.class)
|
.onConstructorInvocation(WebClientHttpServiceGroupAdapter.class.getConstructor())).accepts(hints);
|
||||||
.withMemberCategory(MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS))
|
|
||||||
.accepts(this.hints);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue