Support service connections for redis-stack and redis-stack-server
See gh-41327
This commit is contained in:
parent
2216b48e64
commit
2634d0c6b1
@ -30,6 +30,7 @@ import static org.assertj.core.api.Assertions.assertThat;
|
|||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Scott Frederick
|
* @author Scott Frederick
|
||||||
|
* @author Eddú Meléndez
|
||||||
*/
|
*/
|
||||||
class RedisDockerComposeConnectionDetailsFactoryIntegrationTests {
|
class RedisDockerComposeConnectionDetailsFactoryIntegrationTests {
|
||||||
|
|
||||||
@ -43,6 +44,16 @@ class RedisDockerComposeConnectionDetailsFactoryIntegrationTests {
|
|||||||
assertConnectionDetails(connectionDetails);
|
assertConnectionDetails(connectionDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@DockerComposeTest(composeFile = "redis-compose.yaml", image = TestImage.REDIS_STACK)
|
||||||
|
void runWithRedisStackCreatesConnectionDetails(RedisConnectionDetails connectionDetails) {
|
||||||
|
assertConnectionDetails(connectionDetails);
|
||||||
|
}
|
||||||
|
|
||||||
|
@DockerComposeTest(composeFile = "redis-compose.yaml", image = TestImage.REDIS_STACK_SERVER)
|
||||||
|
void runWithRedisStackServerCreatesConnectionDetails(RedisConnectionDetails connectionDetails) {
|
||||||
|
assertConnectionDetails(connectionDetails);
|
||||||
|
}
|
||||||
|
|
||||||
private void assertConnectionDetails(RedisConnectionDetails connectionDetails) {
|
private void assertConnectionDetails(RedisConnectionDetails connectionDetails) {
|
||||||
assertThat(connectionDetails.getUsername()).isNull();
|
assertThat(connectionDetails.getUsername()).isNull();
|
||||||
assertThat(connectionDetails.getPassword()).isNull();
|
assertThat(connectionDetails.getPassword()).isNull();
|
||||||
|
@ -29,15 +29,17 @@ import org.springframework.boot.docker.compose.service.connection.DockerComposeC
|
|||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Scott Frederick
|
* @author Scott Frederick
|
||||||
|
* @author Eddú Meléndez
|
||||||
*/
|
*/
|
||||||
class RedisDockerComposeConnectionDetailsFactory extends DockerComposeConnectionDetailsFactory<RedisConnectionDetails> {
|
class RedisDockerComposeConnectionDetailsFactory extends DockerComposeConnectionDetailsFactory<RedisConnectionDetails> {
|
||||||
|
|
||||||
private static final String[] REDIS_CONTAINER_NAMES = { "redis", "bitnami/redis" };
|
private static final String[] REDIS_IMAGE_NAMES = { "redis", "bitnami/redis", "redis/redis-stack",
|
||||||
|
"redis/redis-stack-server" };
|
||||||
|
|
||||||
private static final int REDIS_PORT = 6379;
|
private static final int REDIS_PORT = 6379;
|
||||||
|
|
||||||
RedisDockerComposeConnectionDetailsFactory() {
|
RedisDockerComposeConnectionDetailsFactory() {
|
||||||
super(REDIS_CONTAINER_NAMES);
|
super(REDIS_IMAGE_NAMES);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -123,7 +123,7 @@ The following service connections are currently supported:
|
|||||||
| Containers named "rabbitmq" or "bitnami/rabbitmq"
|
| Containers named "rabbitmq" or "bitnami/rabbitmq"
|
||||||
|
|
||||||
| `RedisConnectionDetails`
|
| `RedisConnectionDetails`
|
||||||
| Containers named "redis" or "bitnami/redis"
|
| Containers named "redis", "bitnami/redis", "redis/redis-stack" or "redis/redis-stack-server"
|
||||||
|
|
||||||
| `ZipkinConnectionDetails`
|
| `ZipkinConnectionDetails`
|
||||||
| Containers named "openzipkin/zipkin".
|
| Containers named "openzipkin/zipkin".
|
||||||
|
@ -87,7 +87,7 @@ The following service connection factories are provided in the `spring-boot-test
|
|||||||
| Containers of type `RabbitMQContainer`
|
| Containers of type `RabbitMQContainer`
|
||||||
|
|
||||||
| `RedisConnectionDetails`
|
| `RedisConnectionDetails`
|
||||||
| Containers named "redis"
|
| Containers named "redis", "bitnami/redis", "redis/redis-stack" or "redis/redis-stack-server"
|
||||||
|
|
||||||
| `ZipkinConnectionDetails`
|
| `ZipkinConnectionDetails`
|
||||||
| Containers named "openzipkin/zipkin"
|
| Containers named "openzipkin/zipkin"
|
||||||
|
@ -0,0 +1,73 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-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.boot.testcontainers.service.connection.redis;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.testcontainers.containers.GenericContainer;
|
||||||
|
import org.testcontainers.junit.jupiter.Container;
|
||||||
|
import org.testcontainers.junit.jupiter.Testcontainers;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisConnectionDetails;
|
||||||
|
import org.springframework.boot.testcontainers.service.connection.ServiceConnection;
|
||||||
|
import org.springframework.boot.testsupport.container.TestImage;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnection;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnectionFactory;
|
||||||
|
import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link RedisContainerConnectionDetailsFactory}.
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
* @author Eddú Meléndez
|
||||||
|
*/
|
||||||
|
@SpringJUnitConfig
|
||||||
|
@Testcontainers(disabledWithoutDocker = true)
|
||||||
|
class BitnamiRedisContainerConnectionDetailsFactoryTests {
|
||||||
|
|
||||||
|
@Container
|
||||||
|
@ServiceConnection
|
||||||
|
static final GenericContainer<?> redis = TestImage.BITNAMI_REDIS.genericContainer()
|
||||||
|
.withExposedPorts(6379)
|
||||||
|
.withEnv("ALLOW_EMPTY_PASSWORD", "yes");
|
||||||
|
|
||||||
|
@Autowired(required = false)
|
||||||
|
private RedisConnectionDetails connectionDetails;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private RedisConnectionFactory connectionFactory;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void connectionCanBeMadeToRedisContainer() {
|
||||||
|
assertThat(this.connectionDetails).isNotNull();
|
||||||
|
try (RedisConnection connection = this.connectionFactory.getConnection()) {
|
||||||
|
assertThat(connection.commands().echo("Hello, World".getBytes())).isEqualTo("Hello, World".getBytes());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Configuration(proxyBeanMethods = false)
|
||||||
|
@ImportAutoConfiguration(RedisAutoConfiguration.class)
|
||||||
|
static class TestConfiguration {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-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.boot.testcontainers.service.connection.redis;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.testcontainers.containers.GenericContainer;
|
||||||
|
import org.testcontainers.junit.jupiter.Container;
|
||||||
|
import org.testcontainers.junit.jupiter.Testcontainers;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisConnectionDetails;
|
||||||
|
import org.springframework.boot.testcontainers.service.connection.ServiceConnection;
|
||||||
|
import org.springframework.boot.testsupport.container.TestImage;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnection;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnectionFactory;
|
||||||
|
import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link RedisContainerConnectionDetailsFactory}.
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
* @author Eddú Meléndez
|
||||||
|
*/
|
||||||
|
@SpringJUnitConfig
|
||||||
|
@Testcontainers(disabledWithoutDocker = true)
|
||||||
|
class RedisStackContainerConnectionDetailsFactoryTests {
|
||||||
|
|
||||||
|
@Container
|
||||||
|
@ServiceConnection
|
||||||
|
static final GenericContainer<?> redis = TestImage.REDIS_STACK.genericContainer().withExposedPorts(6379);
|
||||||
|
|
||||||
|
@Autowired(required = false)
|
||||||
|
private RedisConnectionDetails connectionDetails;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private RedisConnectionFactory connectionFactory;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void connectionCanBeMadeToRedisContainer() {
|
||||||
|
assertThat(this.connectionDetails).isNotNull();
|
||||||
|
try (RedisConnection connection = this.connectionFactory.getConnection()) {
|
||||||
|
assertThat(connection.commands().echo("Hello, World".getBytes())).isEqualTo("Hello, World".getBytes());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Configuration(proxyBeanMethods = false)
|
||||||
|
@ImportAutoConfiguration(RedisAutoConfiguration.class)
|
||||||
|
static class TestConfiguration {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-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.boot.testcontainers.service.connection.redis;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.testcontainers.containers.GenericContainer;
|
||||||
|
import org.testcontainers.junit.jupiter.Container;
|
||||||
|
import org.testcontainers.junit.jupiter.Testcontainers;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.data.redis.RedisConnectionDetails;
|
||||||
|
import org.springframework.boot.testcontainers.service.connection.ServiceConnection;
|
||||||
|
import org.springframework.boot.testsupport.container.TestImage;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnection;
|
||||||
|
import org.springframework.data.redis.connection.RedisConnectionFactory;
|
||||||
|
import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link RedisContainerConnectionDetailsFactory}.
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
* @author Eddú Meléndez
|
||||||
|
*/
|
||||||
|
@SpringJUnitConfig
|
||||||
|
@Testcontainers(disabledWithoutDocker = true)
|
||||||
|
class RedisStackServerContainerConnectionDetailsFactoryTests {
|
||||||
|
|
||||||
|
@Container
|
||||||
|
@ServiceConnection
|
||||||
|
static final GenericContainer<?> redis = TestImage.REDIS_STACK_SERVER.genericContainer().withExposedPorts(6379);
|
||||||
|
|
||||||
|
@Autowired(required = false)
|
||||||
|
private RedisConnectionDetails connectionDetails;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private RedisConnectionFactory connectionFactory;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void connectionCanBeMadeToRedisContainer() {
|
||||||
|
assertThat(this.connectionDetails).isNotNull();
|
||||||
|
try (RedisConnection connection = this.connectionFactory.getConnection()) {
|
||||||
|
assertThat(connection.commands().echo("Hello, World".getBytes())).isEqualTo("Hello, World".getBytes());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Configuration(proxyBeanMethods = false)
|
||||||
|
@ImportAutoConfiguration(RedisAutoConfiguration.class)
|
||||||
|
static class TestConfiguration {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2012-2023 the original author or authors.
|
* Copyright 2012-2024 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package org.springframework.boot.testcontainers.service.connection.redis;
|
package org.springframework.boot.testcontainers.service.connection.redis;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.testcontainers.containers.Container;
|
import org.testcontainers.containers.Container;
|
||||||
import org.testcontainers.containers.GenericContainer;
|
import org.testcontainers.containers.GenericContainer;
|
||||||
|
|
||||||
@ -32,12 +34,18 @@ import org.springframework.boot.testcontainers.service.connection.ServiceConnect
|
|||||||
* @author Moritz Halbritter
|
* @author Moritz Halbritter
|
||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
|
* @author Eddú Meléndez
|
||||||
*/
|
*/
|
||||||
class RedisContainerConnectionDetailsFactory
|
class RedisContainerConnectionDetailsFactory
|
||||||
extends ContainerConnectionDetailsFactory<Container<?>, RedisConnectionDetails> {
|
extends ContainerConnectionDetailsFactory<Container<?>, RedisConnectionDetails> {
|
||||||
|
|
||||||
|
private static final List<String> REDIS_IMAGE_NAMES = List.of("redis", "bitnami/redis", "redis/redis-stack",
|
||||||
|
"redis/redis-stack-server");
|
||||||
|
|
||||||
|
private static final int REDIS_PORT = 6379;
|
||||||
|
|
||||||
RedisContainerConnectionDetailsFactory() {
|
RedisContainerConnectionDetailsFactory() {
|
||||||
super("redis");
|
super(REDIS_IMAGE_NAMES);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -57,7 +65,7 @@ class RedisContainerConnectionDetailsFactory
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Standalone getStandalone() {
|
public Standalone getStandalone() {
|
||||||
return Standalone.of(getContainer().getHost(), getContainer().getFirstMappedPort());
|
return Standalone.of(getContainer().getHost(), getContainer().getMappedPort(REDIS_PORT));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -183,6 +183,16 @@ public enum TestImage {
|
|||||||
(container) -> ((RedisContainer) container).withStartupAttempts(5)
|
(container) -> ((RedisContainer) container).withStartupAttempts(5)
|
||||||
.withStartupTimeout(Duration.ofMinutes(10))),
|
.withStartupTimeout(Duration.ofMinutes(10))),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A container image suitable for testing Redis Stack.
|
||||||
|
*/
|
||||||
|
REDIS_STACK("redis/redis-stack", "7.2.0-v11"),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A container image suitable for testing Redis Stack Server.
|
||||||
|
*/
|
||||||
|
REDIS_STACK_SERVER("redis/redis-stack-server", "7.2.0-v11"),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A container image suitable for testing Redpanda.
|
* A container image suitable for testing Redpanda.
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user