Files
storage/testhelpers/redis/redis_test.go
2025-05-23 10:38:30 +02:00

232 lines
5.4 KiB
Go

package testredis
import (
"context"
"strings"
"testing"
"github.com/redis/go-redis/v9"
"github.com/stretchr/testify/require"
)
// Image is the default image used for running Redis in tests.
const testImage = "docker.io/redis:7"
func TestStart(t *testing.T) {
t.Run("panics-if-image-is-not-set", func(t *testing.T) {
require.Panics(t, func() {
Start(t, "")
})
})
t.Run("default-configuration", func(t *testing.T) {
ctr := Start(t, testImage)
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
require.Nil(t, ctr.TLSConfig)
require.Empty(t, ctr.Addrs)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
t.Run("with-custom-image", func(t *testing.T) {
customImage := "docker.io/redis:6"
ctr := Start(t, customImage)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
require.Nil(t, ctr.TLSConfig)
require.Empty(t, ctr.Addrs)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
t.Run("with-tls", func(t *testing.T) {
t.Parallel()
t.Run("secure-url", func(t *testing.T) {
t.Parallel()
t.Run("mtls-enabled", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithTLS(true, false))
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "rediss://"))
require.NotNil(t, ctr.TLSConfig)
require.Empty(t, ctr.Addrs)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
require.Contains(t, ctr.cmds, "--tls-auth-clients", "yes")
})
t.Run("mtls-disabled", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithTLS(true, true))
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "rediss://"))
require.NotNil(t, ctr.TLSConfig)
require.Contains(t, ctr.cmds, "--tls-auth-clients", "no")
})
})
t.Run("insecure-url", func(t *testing.T) {
t.Parallel()
t.Run("mtls-disabled", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithTLS(false, true))
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
require.NotNil(t, ctr.TLSConfig)
require.Empty(t, ctr.Addrs)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
t.Run("mtls-enabled", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithTLS(false, false))
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
require.NotNil(t, ctr.TLSConfig)
require.Empty(t, ctr.Addrs)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
})
})
t.Run("with-host-and-port", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithHostPort())
require.NotEmpty(t, ctr.Host)
require.NotZero(t, ctr.Port)
require.NotEmpty(t, ctr.URL)
require.Empty(t, ctr.Addrs)
})
t.Run("with-address", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithAddress())
require.NotEmpty(t, ctr.Addrs)
require.Len(t, ctr.Addrs, 1)
require.NotEmpty(t, ctr.URL)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
t.Run("with-url", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage, WithURL(true))
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
})
t.Run("with-multiple-options", func(t *testing.T) {
t.Parallel()
t.Run("address/url", func(t *testing.T) {
t.Parallel()
t.Run("no-tls", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage,
WithAddress(),
WithURL(true),
)
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "redis://"))
require.NotEmpty(t, ctr.Addrs)
require.Len(t, ctr.Addrs, 1)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
t.Run("tls", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage,
WithTLS(true, false),
WithAddress(),
WithURL(true),
)
require.NotEmpty(t, ctr.URL)
require.True(t, strings.HasPrefix(ctr.URL, "rediss://"))
require.NotEmpty(t, ctr.Addrs)
require.Len(t, ctr.Addrs, 1)
require.Empty(t, ctr.Host)
require.Zero(t, ctr.Port)
})
})
})
t.Run("can-connect", func(t *testing.T) {
t.Parallel()
ctr := Start(t, testImage)
options, err := redis.ParseURL(ctr.URL)
require.NoError(t, err)
// Use go-redis client to verify connectivity
client := redis.NewUniversalClient(&redis.UniversalOptions{
Addrs: []string{options.Addr},
TLSConfig: ctr.TLSConfig,
Username: options.Username,
Password: options.Password,
DB: options.DB,
})
defer client.Close()
// Ping should succeed and return "PONG"
resp := client.Ping(context.Background())
require.NoError(t, resp.Err())
require.Equal(t, "PONG", resp.Val())
})
}
func TestConfig(t *testing.T) {
t.Parallel()
t.Run("with-tls", func(t *testing.T) {
t.Parallel()
config := &Config{}
WithTLS(true, false)(config)
require.True(t, config.UseTLS)
require.True(t, config.SecureURL)
require.False(t, config.MTLSDisabled)
})
t.Run("with-address", func(t *testing.T) {
t.Parallel()
config := &Config{}
WithAddress()(config)
require.True(t, config.UseAddress)
})
t.Run("with-host-port", func(t *testing.T) {
t.Parallel()
config := &Config{}
WithHostPort()(config)
require.True(t, config.UseHostPort)
})
t.Run("with-url", func(t *testing.T) {
t.Parallel()
config := &Config{}
WithURL(true)(config)
require.True(t, config.UseURL)
})
}