Testcontainers Spring Config Server

Configuration

Add the dependency for Testcontainers Spring Config Server in your spring boot application:

testImplementation 'com.frog-development.testcontainers:testcontainers-config-server:Hoxton.SR6'

N.B.: The tag will use the Spring Cloud Release tag, to easily understand what version of spring is used.

The auto-configuration will automatically launch 1 container testcontainers-config-server to be used during your integration tests.

Customization

Here are the default values embedded by default with the dependency :

testcontainers:
  config-server:
    enabled: true                                             # Enable/Disable configuration of config server on startup.
    docker:
      image: frogdevelopment/testcontainers-config-server     # Docker image to use.
      tag: Hoxton.SR6                                         # Docker tag to use.
    git:
      uri: your_own_git_uri                                   # Remote Git repository to use.
      branch: the_branch_or_tag_I_want_to_use                 # Branch or tag of the repository to use.
      clone-on-start: true                                    # Flag to indicate that the repository should be cloned on startup (not on demand). Generally leads to slower startup but faster first query.
      refresh-rate: 30                                        # Time (in seconds) between refresh of the git repository, defaults to 30 seconds.
      timeout: 15                                             # Timeout (in seconds) for obtaining HTTP or SSH connection (if applicable), defaults to 5 seconds.
    server:
      port: 8888                                # Server HTTP port.
      wait-timeout: 60                          # Duration (in seconds) of waiting time until container treated as started, defaults to 60 seconds
      health-path: /actuator/health             # Path to the actuator health's endpoint, default to "/actuator/health".

You can override any properties by updating or adding bootstrap-test.yml file in src/test/resources spring project path.

It is also possible to locally enable/disable the run of the testcontainers by setting the property testcontainers.config-server.enabled to false:

@SpringBootTest(properties = {
        "testcontainers.config-server.enabled=false",
        "spring.cloud.config.enabled=false"
})

or

@TestPropertySource(properties = {
        "testcontainers.config-server.enabled=false",
        "spring.cloud.config.enabled=false"
})

Running with local spring-config-server instead of Testcontainers

As it can take a little more time at the beginning when testing locally, you can disable test containers and use a running locally spring cloud config server.

bootstrap-test.yml

spring:
  cloud:
    config:
      uri: http://localhost:8888
      label: the_branch_or_tag_I_want_to_use

testcontainers:
  config-server:
    enabled: false

Here is a docker-compose config file to launch a local config server

docker-compose.yml

  spring-config-server:
    container_name: spring-config-server
    image: frogdevelopment/testcontainers-config-server:Hoxton.SR6
    ports:
      - 8888:8080
    environment:
      SPRING_CLOUD_CONFIG_SERVER_GIT_URI: your_own_git_uri
      SPRING_CLOUD_CONFIG_SERVER_GIT_DEFAULT_LABEL: develop
      SPRING_CLOUD_CONFIG_SERVER_GIT_CLONE_ON_START: 'false'
TODO