All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.test.context.DynamicPropertySource Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2002-2024 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.test.context;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * {@code @DynamicPropertySource} is an annotation that can be applied to static
 * methods in integration test classes in order to add properties with dynamic
 * values to the {@code Environment}'s set of {@code PropertySources}.
 *
 * 

Alternatively, dynamic properties can be added to the {@code Environment} * by special beans in the test's {@code ApplicationContext}. See * {@link DynamicPropertyRegistrar} for details. * *

This annotation and its supporting infrastructure were originally designed * to allow properties from * Testcontainers based tests to be * exposed easily to Spring integration tests. However, this feature may be used * with any form of external resource whose lifecycle is managed outside the * test's {@code ApplicationContext}. * *

{@code @DynamicPropertySource} methods use a {@link DynamicPropertyRegistry} * to add name-value pairs to the {@code Environment}'s set of * {@code PropertySources}. Values are dynamic and provided via a * {@link java.util.function.Supplier} which is only invoked when the property is * resolved. Typically, method references are used to supply values, as in the * example below. * *

Methods in integration test classes that are annotated with * {@code @DynamicPropertySource} must be {@code static} and must accept a single * {@code DynamicPropertyRegistry} argument. * *

Dynamic properties from methods annotated with {@code @DynamicPropertySource} * will be inherited from enclosing test classes, analogous to inheritance * from superclasses and interfaces. See * {@link NestedTestConfiguration @NestedTestConfiguration} for details. * *

NOTE: if you use {@code @DynamicPropertySource} in a base * class and discover that tests in subclasses fail because the dynamic properties * change between subclasses, you may need to annotate your base class with * {@link org.springframework.test.annotation.DirtiesContext @DirtiesContext} to * ensure that each subclass gets its own {@code ApplicationContext} with the * correct dynamic properties. * *

Precedence

* *

Dynamic properties have higher precedence than those loaded from * {@link TestPropertySource @TestPropertySource}, the operating system's * environment, Java system properties, or property sources added by the * application declaratively by using * {@link org.springframework.context.annotation.PropertySource @PropertySource} * or programmatically. Thus, dynamic properties can be used to selectively * override properties loaded via {@code @TestPropertySource}, system property * sources, and application property sources. * *

Examples

* *

The following example demonstrates how to use {@code @DynamicPropertySource} * in an integration test class. Beans in the {@code ApplicationContext} can * access the {@code redis.host} and {@code redis.port} properties which are * dynamically retrieved from the Redis container. * *

 * @SpringJUnitConfig(...)
 * @Testcontainers
 * class ExampleIntegrationTests {
 *
 *     @Container
 *     static GenericContainer redis =
 *         new GenericContainer("redis:5.0.3-alpine").withExposedPorts(6379);
 *
 *     // ...
 *
 *     @DynamicPropertySource
 *     static void redisProperties(DynamicPropertyRegistry registry) {
 *         registry.add("redis.host", redis::getHost);
 *         registry.add("redis.port", redis::getFirstMappedPort);
 *     }
 * }
* * @author Phillip Webb * @author Sam Brannen * @since 5.2.5 * @see DynamicPropertyRegistry * @see DynamicPropertyRegistrar * @see ContextConfiguration * @see TestPropertySource * @see org.springframework.core.env.PropertySource * @see org.springframework.test.annotation.DirtiesContext */ @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface DynamicPropertySource { }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy