2022-05-08 09:00:22 +00:00
|
|
|
package config_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/maxatome/go-testdeep/td"
|
|
|
|
|
|
|
|
"github.com/baez90/nurse/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
//nolint:paralleltest // not possible with env setup
|
|
|
|
func TestServersFromEnv(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
env map[string]string
|
|
|
|
want any
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Empty env",
|
|
|
|
want: td.NotNil(),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Single server",
|
|
|
|
env: map[string]string{
|
|
|
|
fmt.Sprintf("%s_REDIS_1", config.ServerKeyPrefix): "redis://localhost:6379",
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[string]config.Server), td.MapEntries{
|
|
|
|
"redis_1": config.Server{
|
|
|
|
Type: config.ServerTypeRedis,
|
|
|
|
Hosts: []string{"localhost:6379"},
|
|
|
|
Args: make(map[string]any),
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Multiple servers",
|
|
|
|
env: map[string]string{
|
|
|
|
fmt.Sprintf("%s_REDIS_1", config.ServerKeyPrefix): "redis://localhost:6379",
|
|
|
|
fmt.Sprintf("%s_REDIS_2", config.ServerKeyPrefix): "redis://redis:6379",
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[string]config.Server), td.MapEntries{
|
|
|
|
"redis_1": config.Server{
|
|
|
|
Type: config.ServerTypeRedis,
|
|
|
|
Hosts: []string{"localhost:6379"},
|
|
|
|
Args: make(map[string]any),
|
|
|
|
},
|
|
|
|
"redis_2": config.Server{
|
|
|
|
Type: config.ServerTypeRedis,
|
|
|
|
Hosts: []string{"redis:6379"},
|
|
|
|
Args: make(map[string]any),
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
tt := tt
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
if tt.env != nil {
|
|
|
|
for k, v := range tt.env {
|
|
|
|
t.Setenv(k, v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
got, err := config.ServersFromEnv()
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
t.Errorf("ServersFromEnv() error = %v, wantErr %v", err, tt.wantErr)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
td.Cmp(t, got, tt.want)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//nolint:paralleltest // not possible with env setup
|
|
|
|
func TestEndpointsFromEnv(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
env map[string]string
|
|
|
|
want any
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Empty env",
|
|
|
|
want: td.NotNil(),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Single endpoint",
|
|
|
|
env: map[string]string{
|
|
|
|
fmt.Sprintf("%s_readiness", config.EndpointKeyPrefix): `redis.PING("local_redis")`,
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[config.Route]config.EndpointSpec), td.MapEntries{
|
|
|
|
config.Route("readiness"): td.Struct(config.EndpointSpec{}, td.StructFields{
|
2022-06-02 17:31:28 +00:00
|
|
|
"Checks": td.Len(1),
|
2022-05-08 09:00:22 +00:00
|
|
|
}),
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Single endpoint - multiple checks",
|
|
|
|
env: map[string]string{
|
|
|
|
fmt.Sprintf("%s_readiness", config.EndpointKeyPrefix): `redis.PING("local_redis");redis.GET("local_redis", "serving") => String("ok")`,
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[config.Route]config.EndpointSpec), td.MapEntries{
|
|
|
|
config.Route("readiness"): td.Struct(config.EndpointSpec{}, td.StructFields{
|
2022-06-02 17:31:28 +00:00
|
|
|
"Checks": td.Len(2),
|
2022-05-08 09:00:22 +00:00
|
|
|
}),
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Single endpoint - sub-route",
|
|
|
|
env: map[string]string{
|
2022-06-09 20:40:32 +00:00
|
|
|
//nolint:lll // checks might become rather long lines
|
2022-05-08 09:00:22 +00:00
|
|
|
fmt.Sprintf("%s_READINESS_REDIS", config.EndpointKeyPrefix): `redis.PING("local_redis");redis.GET("local_redis", "serving") => String("ok")`,
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[config.Route]config.EndpointSpec), td.MapEntries{
|
|
|
|
config.Route("readiness/redis"): td.Struct(config.EndpointSpec{}, td.StructFields{
|
2022-06-02 17:31:28 +00:00
|
|
|
"Checks": td.Len(2),
|
2022-05-08 09:00:22 +00:00
|
|
|
}),
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Multiple endpoints",
|
|
|
|
env: map[string]string{
|
|
|
|
fmt.Sprintf("%s_readiness", config.EndpointKeyPrefix): `redis.PING("local_redis")`,
|
|
|
|
fmt.Sprintf("%s_liveness", config.EndpointKeyPrefix): `redis.GET("local_redis", "serving") => String("ok")`,
|
|
|
|
},
|
|
|
|
want: td.Map(make(map[config.Route]config.EndpointSpec), td.MapEntries{
|
|
|
|
config.Route("readiness"): td.Struct(config.EndpointSpec{}, td.StructFields{
|
2022-06-02 17:31:28 +00:00
|
|
|
"Checks": td.Len(1),
|
2022-05-08 09:00:22 +00:00
|
|
|
}),
|
|
|
|
config.Route("liveness"): td.Struct(config.EndpointSpec{}, td.StructFields{
|
2022-06-02 17:31:28 +00:00
|
|
|
"Checks": td.Len(1),
|
2022-05-08 09:00:22 +00:00
|
|
|
}),
|
|
|
|
}),
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
tt := tt
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
if tt.env != nil {
|
|
|
|
for k, v := range tt.env {
|
|
|
|
t.Setenv(k, v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
got, err := config.EndpointsFromEnv()
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
t.Errorf("EndpointsFromEnv() error = %v, wantErr %v", err, tt.wantErr)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
td.Cmp(t, got, tt.want)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|