mirror of
https://github.com/gofiber/storage.git
synced 2025-10-05 16:48:25 +08:00
232 lines
5.4 KiB
Go
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)
|
|
})
|
|
}
|