Merge branch '6.0.x'
This commit is contained in:
		
						commit
						46fe7f5bea
					
				| 
						 | 
				
			
			@ -13,6 +13,7 @@ dependencies {
 | 
			
		|||
	testImplementation(testFixtures(project(":spring-core")))
 | 
			
		||||
	testImplementation(project(":spring-core-test"))
 | 
			
		||||
	testImplementation("jakarta.annotation:jakarta.annotation-api")
 | 
			
		||||
	testImplementation(project(":spring-web"))
 | 
			
		||||
	testFixturesApi("org.junit.jupiter:junit-jupiter-api")
 | 
			
		||||
	testFixturesImplementation("org.assertj:assertj-core")
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,39 @@
 | 
			
		|||
/*
 | 
			
		||||
 * Copyright 2002-2023 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.beans;
 | 
			
		||||
 | 
			
		||||
import org.springframework.aot.hint.MemberCategory;
 | 
			
		||||
import org.springframework.aot.hint.RuntimeHints;
 | 
			
		||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
 | 
			
		||||
import org.springframework.lang.Nullable;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * {@link RuntimeHintsRegistrar} to register hints for popular conventions in
 | 
			
		||||
 * {@link BeanUtils#findEditorByConvention(Class)}.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Sebastien Deleuze
 | 
			
		||||
 * @since 6.0.10
 | 
			
		||||
 */
 | 
			
		||||
class BeanUtilsRuntimeHints implements RuntimeHintsRegistrar {
 | 
			
		||||
 | 
			
		||||
	@Override
 | 
			
		||||
	public void registerHints(RuntimeHints hints, @Nullable ClassLoader classLoader) {
 | 
			
		||||
		hints.reflection().registerTypeIfPresent(classLoader, "org.springframework.http.MediaTypeEditor",
 | 
			
		||||
				MemberCategory.INVOKE_DECLARED_CONSTRUCTORS);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -1,5 +1,6 @@
 | 
			
		|||
org.springframework.aot.hint.RuntimeHintsRegistrar=\
 | 
			
		||||
org.springframework.beans.factory.annotation.JakartaAnnotationsRuntimeHints
 | 
			
		||||
org.springframework.beans.factory.annotation.JakartaAnnotationsRuntimeHints,\
 | 
			
		||||
org.springframework.beans.BeanUtilsRuntimeHints
 | 
			
		||||
 | 
			
		||||
org.springframework.beans.factory.aot.BeanFactoryInitializationAotProcessor=\
 | 
			
		||||
org.springframework.beans.factory.aot.BeanRegistrationsAotProcessor
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,55 @@
 | 
			
		|||
/*
 | 
			
		||||
 * Copyright 2002-2023 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.beans;
 | 
			
		||||
 | 
			
		||||
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.TypeReference;
 | 
			
		||||
import org.springframework.aot.hint.predicate.RuntimeHintsPredicates;
 | 
			
		||||
import org.springframework.core.io.support.SpringFactoriesLoader;
 | 
			
		||||
import org.springframework.util.ClassUtils;
 | 
			
		||||
 | 
			
		||||
import static org.assertj.core.api.Assertions.assertThat;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Tests for {@link BeanUtilsRuntimeHints}.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Sebastien Deleuze
 | 
			
		||||
 */
 | 
			
		||||
class BeanUtilsRuntimeHintsTests {
 | 
			
		||||
 | 
			
		||||
	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
 | 
			
		||||
	void mediaTypeEditorHasHints() {
 | 
			
		||||
		assertThat(RuntimeHintsPredicates.reflection().onType(TypeReference.of("org.springframework.http.MediaTypeEditor"))
 | 
			
		||||
				.withMemberCategories(MemberCategory.INVOKE_DECLARED_CONSTRUCTORS)).accepts(this.hints);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -21,6 +21,8 @@ import java.util.Collections;
 | 
			
		|||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
import org.springframework.aot.hint.ExecutableMode;
 | 
			
		||||
import org.springframework.aot.hint.MemberCategory;
 | 
			
		||||
import org.springframework.aot.hint.ReflectionHints;
 | 
			
		||||
import org.springframework.aot.hint.RuntimeHints;
 | 
			
		||||
import org.springframework.aot.hint.RuntimeHintsRegistrar;
 | 
			
		||||
import org.springframework.aot.hint.TypeReference;
 | 
			
		||||
| 
						 | 
				
			
			@ -37,15 +39,17 @@ class ObjectToObjectConverterRuntimeHints implements RuntimeHintsRegistrar {
 | 
			
		|||
 | 
			
		||||
	@Override
 | 
			
		||||
	public void registerHints(RuntimeHints hints, @Nullable ClassLoader classLoader) {
 | 
			
		||||
		ReflectionHints reflectionHints = hints.reflection();
 | 
			
		||||
		TypeReference sqlDateTypeReference = TypeReference.of("java.sql.Date");
 | 
			
		||||
		hints.reflection().registerTypeIfPresent(classLoader, sqlDateTypeReference.getName(), hint -> hint
 | 
			
		||||
		reflectionHints.registerTypeIfPresent(classLoader, sqlDateTypeReference.getName(), hint -> hint
 | 
			
		||||
				.withMethod("toLocalDate", Collections.emptyList(), ExecutableMode.INVOKE)
 | 
			
		||||
				.onReachableType(sqlDateTypeReference)
 | 
			
		||||
				.withMethod("valueOf", List.of(TypeReference.of(LocalDate.class)), ExecutableMode.INVOKE)
 | 
			
		||||
				.onReachableType(sqlDateTypeReference));
 | 
			
		||||
 | 
			
		||||
		hints.reflection().registerTypeIfPresent(classLoader, "org.springframework.http.HttpMethod",
 | 
			
		||||
		reflectionHints.registerTypeIfPresent(classLoader, "org.springframework.http.HttpMethod",
 | 
			
		||||
				builder -> builder.withMethod("valueOf", List.of(TypeReference.of(String.class)), ExecutableMode.INVOKE));
 | 
			
		||||
		reflectionHints.registerTypeIfPresent(classLoader, "java.net.URI", MemberCategory.INVOKE_DECLARED_CONSTRUCTORS);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -16,6 +16,7 @@
 | 
			
		|||
 | 
			
		||||
package org.springframework.aot.hint.support;
 | 
			
		||||
 | 
			
		||||
import java.net.URI;
 | 
			
		||||
import java.time.LocalDate;
 | 
			
		||||
 | 
			
		||||
import org.junit.jupiter.api.BeforeEach;
 | 
			
		||||
| 
						 | 
				
			
			@ -52,4 +53,9 @@ class ObjectToObjectConverterRuntimeHintsTests {
 | 
			
		|||
		assertThat(RuntimeHintsPredicates.reflection().onMethod(java.sql.Date.class.getMethod("valueOf", LocalDate.class))).accepts(this.hints);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	@Test
 | 
			
		||||
	void uriHasHints() throws NoSuchMethodException {
 | 
			
		||||
		assertThat(RuntimeHintsPredicates.reflection().onConstructor(URI.class.getConstructor(String.class))).accepts(this.hints);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue