From c31e1f7255cfbff30d5fa28f1362b8ca7ce35493 Mon Sep 17 00:00:00 2001 From: liuxingyu9574 <841528039@qq.com> Date: Wed, 5 Jun 2024 17:44:16 +0800 Subject: [PATCH] fix: probe type judgment in conversion from kusion probe to k8s probe (#1144) --- .../workload/service_generator_test.go | 103 ++++++++++++++++++ .../generators/workload/workload_generator.go | 10 +- .../workload/workload_generator_test.go | 10 +- 3 files changed, 113 insertions(+), 10 deletions(-) diff --git a/pkg/modules/generators/workload/service_generator_test.go b/pkg/modules/generators/workload/service_generator_test.go index 29917be4d..a60b2a01a 100644 --- a/pkg/modules/generators/workload/service_generator_test.go +++ b/pkg/modules/generators/workload/service_generator_test.go @@ -157,6 +157,54 @@ spec: name: default-dev-foo-nginx-0 name: default-dev-foo-nginx-0 status: {} +` + deployWithProbe := `apiVersion: apps/v1 +kind: Deployment +metadata: + creationTimestamp: null + labels: + app.kubernetes.io/name: foo + app.kubernetes.io/part-of: default + service-workload-type: Deployment + name: default-dev-foo + namespace: default +spec: + replicas: 4 + selector: + matchLabels: + app.kubernetes.io/name: foo + app.kubernetes.io/part-of: default + strategy: {} + template: + metadata: + creationTimestamp: null + labels: + app.kubernetes.io/name: foo + app.kubernetes.io/part-of: default + service-workload-type: Deployment + spec: + containers: + - image: nginx:v1 + lifecycle: + postStart: + exec: + command: + - /bin/true + name: nginx + readinessProbe: + tcpSocket: + host: localhost + port: 8888 + resources: {} + volumeMounts: + - mountPath: /tmp + name: default-dev-foo-nginx-0 + volumes: + - configMap: + defaultMode: 511 + name: default-dev-foo-nginx-0 + name: default-dev-foo-nginx-0 +status: {} ` r2 := new(int32) *r2 = 2 @@ -263,6 +311,61 @@ status: {} wantErr: false, want: []string{cm, deploy, deploySvc}, }, + { + name: "DeploymentWithProbe", + fields: fields{ + project: "default", + stack: "dev", + appName: "foo", + service: &v1.Service{ + Base: v1.Base{ + Containers: map[string]v1.Container{ + "nginx": { + Image: "nginx:v1", + Files: map[string]v1.FileSpec{ + "/tmp/example.txt": { + Content: "some file contents", + Mode: "0777", + }, + }, + ReadinessProbe: &v1.Probe{ProbeHandler: &v1.ProbeHandler{ + TypeWrapper: v1.TypeWrapper{Type: v1.TypeTCP}, + ExecAction: nil, + HTTPGetAction: nil, + TCPSocketAction: &v1.TCPSocketAction{URL: "localhost:8888"}, + }}, + Lifecycle: &v1.Lifecycle{ + PostStart: &v1.LifecycleHandler{ + TypeWrapper: v1.TypeWrapper{Type: v1.TypeExec}, + ExecAction: &v1.ExecAction{Command: []string{ + "/bin/true", + }}, + HTTPGetAction: nil, + }, + }, + }, + }, + }, + Ports: []v1.Port{ + { + Port: 80, + Protocol: "TCP", + }, + }, + }, + serviceConfig: v1.GenericConfig{ + "replicas": 4, + "labels": v1.GenericConfig{ + "service-workload-type": "Deployment", + }, + }, + }, + args: args{ + spec: &v1.Spec{}, + }, + wantErr: false, + want: []string{cm, deployWithProbe, deploySvc}, + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { diff --git a/pkg/modules/generators/workload/workload_generator.go b/pkg/modules/generators/workload/workload_generator.go index 1b8723834..4cf646281 100644 --- a/pkg/modules/generators/workload/workload_generator.go +++ b/pkg/modules/generators/workload/workload_generator.go @@ -253,15 +253,15 @@ func convertKusionProbeToV1Probe(p *v1.Probe) (*corev1.Probe, error) { } probeHandler := p.ProbeHandler switch probeHandler.Type { - case "Http": + case v1.TypeHTTP: action, err := httpGetAction(probeHandler.HTTPGetAction.URL, probeHandler.Headers) if err != nil { return nil, err } result.HTTPGet = action - case "Exec": + case v1.TypeExec: result.Exec = &corev1.ExecAction{Command: probeHandler.Command} - case "Tcp": + case v1.TypeTCP: action, err := tcpSocketAction(probeHandler.TCPSocketAction.URL) if err != nil { return nil, err @@ -294,13 +294,13 @@ func convertKusionLifecycleToV1Lifecycle(l *v1.Lifecycle) (*corev1.Lifecycle, er func lifecycleHandler(in *v1.LifecycleHandler) (*corev1.LifecycleHandler, error) { result := &corev1.LifecycleHandler{} switch in.Type { - case "Http": + case v1.TypeHTTP: action, err := httpGetAction(in.HTTPGetAction.URL, in.Headers) if err != nil { return nil, err } result.HTTPGet = action - case "Exec": + case v1.TypeExec: result.Exec = &corev1.ExecAction{Command: in.Command} } return result, nil diff --git a/pkg/modules/generators/workload/workload_generator_test.go b/pkg/modules/generators/workload/workload_generator_test.go index 269fec589..80cb7fbb8 100644 --- a/pkg/modules/generators/workload/workload_generator_test.go +++ b/pkg/modules/generators/workload/workload_generator_test.go @@ -275,7 +275,7 @@ func TestToOrderedContainers(t *testing.T) { LivenessProbe: &v1.Probe{ ProbeHandler: &v1.ProbeHandler{ TypeWrapper: v1.TypeWrapper{ - Type: "Exec", + Type: v1.TypeExec, }, ExecAction: &v1.ExecAction{ Command: []string{"/bin/sh", "-c", "echo live"}, @@ -285,7 +285,7 @@ func TestToOrderedContainers(t *testing.T) { ReadinessProbe: &v1.Probe{ ProbeHandler: &v1.ProbeHandler{ TypeWrapper: v1.TypeWrapper{ - Type: "Http", + Type: v1.TypeHTTP, }, HTTPGetAction: &v1.HTTPGetAction{ URL: "http://localhost:8080/readiness", @@ -299,7 +299,7 @@ func TestToOrderedContainers(t *testing.T) { StartupProbe: &v1.Probe{ ProbeHandler: &v1.ProbeHandler{ TypeWrapper: v1.TypeWrapper{ - Type: "Tcp", + Type: v1.TypeTCP, }, TCPSocketAction: &v1.TCPSocketAction{ URL: "10.0.0.1:8888", @@ -354,7 +354,7 @@ func TestToOrderedContainers(t *testing.T) { Lifecycle: &v1.Lifecycle{ PreStop: &v1.LifecycleHandler{ TypeWrapper: v1.TypeWrapper{ - Type: "Exec", + Type: v1.TypeExec, }, ExecAction: &v1.ExecAction{ Command: []string{"/bin/sh", "-c", "echo live"}, @@ -362,7 +362,7 @@ func TestToOrderedContainers(t *testing.T) { }, PostStart: &v1.LifecycleHandler{ TypeWrapper: v1.TypeWrapper{ - Type: "Http", + Type: v1.TypeHTTP, }, HTTPGetAction: &v1.HTTPGetAction{ URL: "http://localhost:8080/readiness",