Files
sablier/pkg/provider/kubernetes/statefulset_inspect_test.go
Alexis Couvreur 0588627d36 fix: bump go 1.25 (#723)
* fix: bump go 1.25

also bump deps and fix golangci lint

* golangci lint fixes
2025-11-10 22:51:07 -05:00

138 lines
3.6 KiB
Go

package kubernetes_test
import (
"context"
"fmt"
"testing"
"github.com/google/go-cmp/cmp"
"github.com/neilotoole/slogt"
"github.com/sablierapp/sablier/pkg/config"
"github.com/sablierapp/sablier/pkg/provider/kubernetes"
"github.com/sablierapp/sablier/pkg/sablier"
"gotest.tools/v3/assert"
autoscalingv1 "k8s.io/api/autoscaling/v1"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
func TestKubernetesProvider_InspectStatefulSet(t *testing.T) {
if testing.Short() {
t.Skip("skipping test in short mode.")
}
ctx := context.Background()
type args struct {
do func(dind *kindContainer) (string, error)
}
tests := []struct {
name string
args args
want sablier.InstanceInfo
wantErr error
}{
{
name: "statefulSet with 1/1 replicas",
args: args{
do: func(dind *kindContainer) (string, error) {
d, err := dind.CreateMimicStatefulSet(ctx, MimicOptions{
Cmd: []string{"/mimic"},
Healthcheck: nil,
})
if err != nil {
return "", err
}
if err = WaitForStatefulSetReady(ctx, dind.client, "default", d.Name); err != nil {
return "", fmt.Errorf("error waiting for statefulSet: %w", err)
}
return kubernetes.StatefulSetName(d, kubernetes.ParseOptions{Delimiter: "_"}).Original, nil
},
},
want: sablier.InstanceInfo{
CurrentReplicas: 1,
DesiredReplicas: 1,
Status: sablier.InstanceStatusReady,
},
wantErr: nil,
},
{
name: "statefulSet with 0/1 replicas",
args: args{
do: func(dind *kindContainer) (string, error) {
d, err := dind.CreateMimicStatefulSet(ctx, MimicOptions{
Cmd: []string{"/mimic", "-running-after=1ms", "-healthy=false", "-healthy-after=10s"},
Healthcheck: &corev1.Probe{},
})
if err != nil {
return "", err
}
return kubernetes.StatefulSetName(d, kubernetes.ParseOptions{Delimiter: "_"}).Original, nil
},
},
want: sablier.InstanceInfo{
CurrentReplicas: 0,
DesiredReplicas: 1,
Status: sablier.InstanceStatusNotReady,
},
wantErr: nil,
},
{
name: "statefulSet with 0/0 replicas",
args: args{
do: func(dind *kindContainer) (string, error) {
d, err := dind.CreateMimicStatefulSet(ctx, MimicOptions{})
if err != nil {
return "", err
}
_, err = dind.client.AppsV1().StatefulSets(d.Namespace).UpdateScale(ctx, d.Name, &autoscalingv1.Scale{
ObjectMeta: metav1.ObjectMeta{
Name: d.Name,
},
Spec: autoscalingv1.ScaleSpec{
Replicas: 0,
},
}, metav1.UpdateOptions{})
if err != nil {
return "", err
}
if err = WaitForStatefulSetScale(ctx, dind.client, "default", d.Name, 0); err != nil {
return "", fmt.Errorf("error waiting for statefulSet: %w", err)
}
return kubernetes.StatefulSetName(d, kubernetes.ParseOptions{Delimiter: "_"}).Original, nil
},
},
want: sablier.InstanceInfo{
CurrentReplicas: 0,
DesiredReplicas: 1,
Status: sablier.InstanceStatusNotReady,
},
wantErr: nil,
},
}
c := setupKinD(t, ctx)
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
p, err := kubernetes.New(ctx, c.client, slogt.New(t), config.NewProviderConfig().Kubernetes)
assert.NilError(t, err)
name, err := tt.args.do(c)
assert.NilError(t, err)
tt.want.Name = name
got, err := p.InstanceInspect(ctx, name)
if !cmp.Equal(err, tt.wantErr) {
t.Errorf("DockerSwarmProvider.InstanceInspect() error = %v, wantErr %v", err, tt.wantErr)
return
}
assert.DeepEqual(t, got, tt.want)
})
}
}