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.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.BeansException;
|
||||
import org.springframework.beans.factory.BeanClassLoaderAware;
|
||||
|
@ -126,14 +130,15 @@ public final class HttpServiceProxyRegistryFactoryBean
|
|||
|
||||
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() {
|
||||
Map<HttpServiceGroup.ClientType, HttpServiceGroupAdapter<?>> map = new LinkedHashMap<>(2);
|
||||
|
||||
addGroupAdapter(map, HttpServiceGroup.ClientType.REST_CLIENT,
|
||||
"org.springframework.web.client.support.RestClientHttpServiceGroupAdapter");
|
||||
|
||||
addGroupAdapter(map, HttpServiceGroup.ClientType.WEB_CLIENT,
|
||||
"org.springframework.web.reactive.function.client.support.WebClientHttpServiceGroupAdapter");
|
||||
addGroupAdapter(map, HttpServiceGroup.ClientType.REST_CLIENT, REST_CLIENT_HTTP_SERVICE_GROUP_ADAPTER);
|
||||
addGroupAdapter(map, HttpServiceGroup.ClientType.WEB_CLIENT, WEB_CLIENT_HTTP_SERVICE_GROUP_ADAPTER);
|
||||
|
||||
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.converter.json.JacksonModulesRuntimeHints,\
|
||||
org.springframework.http.converter.json.ProblemDetailRuntimeHints,\
|
||||
org.springframework.web.util.WebUtilRuntimeHints,\
|
||||
org.springframework.web.client.support.RestClientHttpServiceGroupAdapterRuntimeHints
|
||||
org.springframework.web.service.registry.HttpServiceProxyRegistryFactoryBean.HttpServiceProxyRegistryRuntimeHints,\
|
||||
org.springframework.web.util.WebUtilRuntimeHints
|
||||
|
||||
org.springframework.beans.factory.aot.BeanRegistrationAotProcessor=\
|
||||
org.springframework.web.service.annotation.HttpExchangeBeanRegistrationAotProcessor,\
|
||||
|
|
|
@ -16,43 +16,32 @@
|
|||
|
||||
package org.springframework.web.client.support;
|
||||
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import org.springframework.aot.hint.MemberCategory;
|
||||
import org.springframework.aot.hint.RuntimeHints;
|
||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
||||
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 static org.assertj.core.api.Assertions.assertThat;
|
||||
|
||||
/**
|
||||
* Tests for {@link RestClientHttpServiceGroupAdapterRuntimeHints}.
|
||||
* Tests for {@link RestClientHttpServiceGroupAdapter}.
|
||||
*
|
||||
* @author Olga Maciaszek-Sharma
|
||||
* @author Stephane Nicoll
|
||||
*/
|
||||
class RestClientHttpServiceGroupAdapterRuntimeHintsRegistrarTests {
|
||||
|
||||
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()));
|
||||
}
|
||||
class RestClientHttpServiceGroupAdapterTests {
|
||||
|
||||
@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()
|
||||
.onType(RestClientHttpServiceGroupAdapter.class)
|
||||
.withMemberCategory(MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS))
|
||||
.accepts(this.hints);
|
||||
|
||||
.onConstructorInvocation(RestClientHttpServiceGroupAdapter.class.getConstructor())).accepts(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;
|
||||
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import org.springframework.aot.hint.MemberCategory;
|
||||
import org.springframework.aot.hint.RuntimeHints;
|
||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
|
||||
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 static org.assertj.core.api.Assertions.assertThat;
|
||||
|
||||
/**
|
||||
* Tests for {@link WebClientHttpServiceGroupAdapterRuntimeHints}.
|
||||
* Tests for {@link WebClientHttpServiceGroupAdapter}.
|
||||
*
|
||||
* @author Olga Maciaszek-Sharma
|
||||
* @author Stephane Nicoll
|
||||
*/
|
||||
class WebClientHttpServiceGroupAdapterRuntimeHintsTests {
|
||||
|
||||
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()));
|
||||
}
|
||||
class WebClientHttpServiceGroupAdapterTests {
|
||||
|
||||
@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()
|
||||
.onType(WebClientHttpServiceGroupAdapter.class)
|
||||
.withMemberCategory(MemberCategory.INVOKE_PUBLIC_CONSTRUCTORS))
|
||||
.accepts(this.hints);
|
||||
|
||||
.onConstructorInvocation(WebClientHttpServiceGroupAdapter.class.getConstructor())).accepts(hints);
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue