diff --git a/Makefile b/Makefile index 88b3cd2d..6f4af259 100644 --- a/Makefile +++ b/Makefile @@ -72,18 +72,20 @@ docker-build-local: build-local-linux kind-load-local: docker-build-local kind load docker-image controller:latest --name testkube -run: manifests generate fmt vet ## Run a controller from your host. - go run ./cmd/main.go - -run-no-webhook: manifests generate fmt vet ## Run a controller from your host. - ENABLE_WEBHOOKS=false go run ./cmd/main.go - docker-build: test ## Build docker image with the manager. docker build -t ${IMG} . docker-push: ## Push docker image with the manager. docker push ${IMG} +##@ Build + +run: manifests generate fmt vet ## Run a controller from your host. + go run ./cmd/main.go + +run-no-webhook: manifests generate fmt vet ## Run a controller from your host. + ENABLE_WEBHOOKS=false go run ./cmd/main.go + ##@ Deployment install: manifests kustomize ## Install CRDs into the K8s cluster specified in ~/.kube/config. @@ -99,10 +101,11 @@ deploy: manifests kustomize ## Deploy controller to the K8s cluster specified in undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/config. $(KUSTOMIZE) build config/default | kubectl delete -f - +##@ Setup CONTROLLER_GEN = $(shell pwd)/bin/controller-gen controller-gen: ## Download controller-gen locally if necessary. - $(call go-get-tool,$(CONTROLLER_GEN),sigs.k8s.io/controller-tools/cmd/controller-gen@v0.4.1) + $(call go-get-tool,$(CONTROLLER_GEN),sigs.k8s.io/controller-tools/cmd/controller-gen@v0.8.0) KUSTOMIZE = $(shell pwd)/bin/kustomize kustomize: ## Download kustomize locally if necessary. diff --git a/PROJECT b/PROJECT index 982365cd..3a859925 100644 --- a/PROJECT +++ b/PROJECT @@ -135,144 +135,4 @@ resources: kind: Template path: github.com/kubeshop/testkube-operator/api/template/v1 version: v1 -- api: - crdVersion: v1 - namespaced: true - domain: testkube.io - group: tests - kind: Test - path: github.com/kubeshop/testkube-operator/api/tests/v2 - version: v2 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuite - path: github.com/kubeshop/testkube-operator/api/testsuite/v3 - version: v3 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestExecution - path: github.com/kubeshop/testkube-operator/api/testexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuiteExecution - path: github.com/kubeshop/testkube-operator/api/testsuiteexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: Template - path: github.com/kubeshop/testkube-operator/api/template/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - domain: testkube.io - group: tests - kind: Test - path: github.com/kubeshop/testkube-operator/api/tests/v2 - version: v2 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuite - path: github.com/kubeshop/testkube-operator/api/testsuite/v3 - version: v3 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestExecution - path: github.com/kubeshop/testkube-operator/api/testexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuiteExecution - path: github.com/kubeshop/testkube-operator/api/testsuiteexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: Template - path: github.com/kubeshop/testkube-operator/api/template/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - domain: testkube.io - group: tests - kind: Test - path: github.com/kubeshop/testkube-operator/apis/tests/v2 - version: v2 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuite - path: github.com/kubeshop/testkube-operator/apis/testsuite/v3 - version: v3 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestExecution - path: github.com/kubeshop/testkube-operator/apis/testexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuiteExecution - path: github.com/kubeshop/testkube-operator/apis/testsuiteexecution/v1 - version: v1 -- api: - crdVersion: v1 - namespaced: true - domain: testkube.io - group: tests - kind: Test - path: github.com/kubeshop/testkube-operator/apis/tests/v2 - version: v2 -- api: - crdVersion: v1 - namespaced: true - controller: true - domain: testkube.io - group: tests - kind: TestSuite - path: github.com/kubeshop/testkube-operator/apis/testsuite/v3 - version: v3 version: "3" diff --git a/api/executor/v1/zz_generated.deepcopy.go b/api/executor/v1/zz_generated.deepcopy.go index c292408b..89fa978e 100644 --- a/api/executor/v1/zz_generated.deepcopy.go +++ b/api/executor/v1/zz_generated.deepcopy.go @@ -1,3 +1,4 @@ +//go:build !ignore_autogenerated // +build !ignore_autogenerated /* diff --git a/api/template/v1/template_types.go b/api/template/v1/template_types.go index 2b41d864..47b8578e 100644 --- a/api/template/v1/template_types.go +++ b/api/template/v1/template_types.go @@ -24,7 +24,7 @@ import ( // NOTE: json tags are required. Any new fields you add must have json tags for the fields to be serialized. // TemplateType defines template type by purpose -// +kubebuilder:validation:Enum=job;container;cronjob;scraper;pvc;webhook +// +kubebuilder:validation:Enum=job;container;cronjob;scraper;pvc;webhook;pod type TemplateType string const ( @@ -34,6 +34,7 @@ const ( SCRAPER_TemplateType TemplateType = "scraper" PVC_TemplateType TemplateType = "pvc" WEBHOOK_TemplateType TemplateType = "webhook" + POD_TemplateType TemplateType = "pod" ) // TemplateSpec defines the desired state of Template diff --git a/api/testexecution/v1/testexecution_types.go b/api/testexecution/v1/testexecution_types.go index cc16b6ca..0a7df57b 100644 --- a/api/testexecution/v1/testexecution_types.go +++ b/api/testexecution/v1/testexecution_types.go @@ -129,8 +129,9 @@ type ExecutionRequest struct { // config map references EnvConfigMaps []EnvReference `json:"envConfigMaps,omitempty"` // secret references - EnvSecrets []EnvReference `json:"envSecrets,omitempty"` - RunningContext *RunningContext `json:"runningContext,omitempty"` + EnvSecrets []EnvReference `json:"envSecrets,omitempty"` + RunningContext *RunningContext `json:"runningContext,omitempty"` + SlavePodRequest *PodRequest `json:"slavePodRequest,omitempty"` } // ArgsModeType defines args mode type @@ -171,6 +172,29 @@ type TestExecutionSpec struct { ExecutionRequest *ExecutionRequest `json:"executionRequest,omitempty"` } +// pod request body +type PodRequest struct { + Resources *PodResourcesRequest `json:"resources,omitempty"` + // pod template extensions + PodTemplate string `json:"podTemplate,omitempty"` + // name of the template resource + PodTemplateReference string `json:"podTemplateReference,omitempty"` +} + +// pod resources request specification +type PodResourcesRequest struct { + Requests *ResourceRequest `json:"requests,omitempty"` + Limits *ResourceRequest `json:"limits,omitempty"` +} + +// resource request specification +type ResourceRequest struct { + // requested cpu units + Cpu string `json:"cpu,omitempty"` + // requested memory units + Memory string `json:"memory,omitempty"` +} + // test execution type Execution struct { // execution id @@ -230,7 +254,8 @@ type Execution struct { ExecutePostRunScriptBeforeScraping bool `json:"executePostRunScriptBeforeScraping,omitempty"` RunningContext *RunningContext `json:"runningContext,omitempty"` // shell used in container executor - ContainerShell string `json:"containerShell,omitempty"` + ContainerShell string `json:"containerShell,omitempty"` + SlavePodRequest *PodRequest `json:"slavePodRequest,omitempty"` } // TestContent defines test content diff --git a/api/testexecution/v1/zz_generated.deepcopy.go b/api/testexecution/v1/zz_generated.deepcopy.go index 91370918..737425e0 100644 --- a/api/testexecution/v1/zz_generated.deepcopy.go +++ b/api/testexecution/v1/zz_generated.deepcopy.go @@ -138,6 +138,11 @@ func (in *Execution) DeepCopyInto(out *Execution) { *out = new(RunningContext) **out = **in } + if in.SlavePodRequest != nil { + in, out := &in.SlavePodRequest, &out.SlavePodRequest + *out = new(PodRequest) + (*in).DeepCopyInto(*out) + } } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Execution. @@ -216,6 +221,11 @@ func (in *ExecutionRequest) DeepCopyInto(out *ExecutionRequest) { *out = new(RunningContext) **out = **in } + if in.SlavePodRequest != nil { + in, out := &in.SlavePodRequest, &out.SlavePodRequest + *out = new(PodRequest) + (*in).DeepCopyInto(*out) + } } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExecutionRequest. @@ -310,6 +320,51 @@ func (in *ObjectRef) DeepCopy() *ObjectRef { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodRequest) DeepCopyInto(out *PodRequest) { + *out = *in + if in.Resources != nil { + in, out := &in.Resources, &out.Resources + *out = new(PodResourcesRequest) + (*in).DeepCopyInto(*out) + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodRequest. +func (in *PodRequest) DeepCopy() *PodRequest { + if in == nil { + return nil + } + out := new(PodRequest) + in.DeepCopyInto(out) + return out +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodResourcesRequest) DeepCopyInto(out *PodResourcesRequest) { + *out = *in + if in.Requests != nil { + in, out := &in.Requests, &out.Requests + *out = new(ResourceRequest) + **out = **in + } + if in.Limits != nil { + in, out := &in.Limits, &out.Limits + *out = new(ResourceRequest) + **out = **in + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodResourcesRequest. +func (in *PodResourcesRequest) DeepCopy() *PodResourcesRequest { + if in == nil { + return nil + } + out := new(PodResourcesRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *Repository) DeepCopyInto(out *Repository) { *out = *in @@ -335,6 +390,21 @@ func (in *Repository) DeepCopy() *Repository { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *ResourceRequest) DeepCopyInto(out *ResourceRequest) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceRequest. +func (in *ResourceRequest) DeepCopy() *ResourceRequest { + if in == nil { + return nil + } + out := new(ResourceRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *RunningContext) DeepCopyInto(out *RunningContext) { *out = *in diff --git a/api/tests/v3/test_types.go b/api/tests/v3/test_types.go index 632debfc..3cca982b 100644 --- a/api/tests/v3/test_types.go +++ b/api/tests/v3/test_types.go @@ -151,6 +151,29 @@ const ( RunningContextTypeEmpty RunningContextType = "" ) +// pod request body +type PodRequest struct { + Resources *PodResourcesRequest `json:"resources,omitempty"` + // pod template extensions + PodTemplate string `json:"podTemplate,omitempty"` + // name of the template resource + PodTemplateReference string `json:"podTemplateReference,omitempty"` +} + +// pod resources request specification +type PodResourcesRequest struct { + Requests *ResourceRequest `json:"requests,omitempty"` + Limits *ResourceRequest `json:"limits,omitempty"` +} + +// resource request specification +type ResourceRequest struct { + // requested cpu units + Cpu string `json:"cpu,omitempty"` + // requested memory units + Memory string `json:"memory,omitempty"` +} + // test execution request body type ExecutionRequest struct { // test execution custom name @@ -225,8 +248,9 @@ type ExecutionRequest struct { // config map references EnvConfigMaps []EnvReference `json:"envConfigMaps,omitempty"` // secret references - EnvSecrets []EnvReference `json:"envSecrets,omitempty"` - RunningContext *RunningContext `json:"-"` + EnvSecrets []EnvReference `json:"envSecrets,omitempty"` + RunningContext *RunningContext `json:"-"` + SlavePodRequest *PodRequest `json:"slavePodRequest,omitempty"` } // ArgsModeType defines args mode type diff --git a/api/tests/v3/zz_generated.deepcopy.go b/api/tests/v3/zz_generated.deepcopy.go index 744838aa..bf9950b0 100644 --- a/api/tests/v3/zz_generated.deepcopy.go +++ b/api/tests/v3/zz_generated.deepcopy.go @@ -150,6 +150,11 @@ func (in *ExecutionRequest) DeepCopyInto(out *ExecutionRequest) { *out = new(RunningContext) **out = **in } + if in.SlavePodRequest != nil { + in, out := &in.SlavePodRequest, &out.SlavePodRequest + *out = new(PodRequest) + (*in).DeepCopyInto(*out) + } } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExecutionRequest. @@ -162,6 +167,51 @@ func (in *ExecutionRequest) DeepCopy() *ExecutionRequest { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodRequest) DeepCopyInto(out *PodRequest) { + *out = *in + if in.Resources != nil { + in, out := &in.Resources, &out.Resources + *out = new(PodResourcesRequest) + (*in).DeepCopyInto(*out) + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodRequest. +func (in *PodRequest) DeepCopy() *PodRequest { + if in == nil { + return nil + } + out := new(PodRequest) + in.DeepCopyInto(out) + return out +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodResourcesRequest) DeepCopyInto(out *PodResourcesRequest) { + *out = *in + if in.Requests != nil { + in, out := &in.Requests, &out.Requests + *out = new(ResourceRequest) + **out = **in + } + if in.Limits != nil { + in, out := &in.Limits, &out.Limits + *out = new(ResourceRequest) + **out = **in + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodResourcesRequest. +func (in *PodResourcesRequest) DeepCopy() *PodResourcesRequest { + if in == nil { + return nil + } + out := new(PodResourcesRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *Repository) DeepCopyInto(out *Repository) { *out = *in @@ -187,6 +237,21 @@ func (in *Repository) DeepCopy() *Repository { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *ResourceRequest) DeepCopyInto(out *ResourceRequest) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceRequest. +func (in *ResourceRequest) DeepCopy() *ResourceRequest { + if in == nil { + return nil + } + out := new(ResourceRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *RunningContext) DeepCopyInto(out *RunningContext) { *out = *in diff --git a/api/testsuite/v3/zz_generated.deepcopy.go b/api/testsuite/v3/zz_generated.deepcopy.go index 6b5bdd83..d39c0360 100644 --- a/api/testsuite/v3/zz_generated.deepcopy.go +++ b/api/testsuite/v3/zz_generated.deepcopy.go @@ -98,9 +98,7 @@ func (in *TestSuiteBatchStep) DeepCopyInto(out *TestSuiteBatchStep) { if in.Execute != nil { in, out := &in.Execute, &out.Execute *out = make([]TestSuiteStepSpec, len(*in)) - for i := range *in { - (*in)[i].DeepCopyInto(&(*out)[i]) - } + copy(*out, *in) } } @@ -273,7 +271,7 @@ func (in *TestSuiteStatus) DeepCopy() *TestSuiteStatus { // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *TestSuiteStepSpec) DeepCopyInto(out *TestSuiteStepSpec) { *out = *in - in.Delay.DeepCopyInto(&out.Delay) + out.Delay = in.Delay } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TestSuiteStepSpec. diff --git a/api/testsuiteexecution/v1/testsuiteexecution_types.go b/api/testsuiteexecution/v1/testsuiteexecution_types.go index 72dcf148..f8d623ff 100644 --- a/api/testsuiteexecution/v1/testsuiteexecution_types.go +++ b/api/testsuiteexecution/v1/testsuiteexecution_types.go @@ -194,6 +194,29 @@ const ( ArgsModeTypeOverride ArgsModeType = "override" ) +// pod request body +type PodRequest struct { + Resources *PodResourcesRequest `json:"resources,omitempty"` + // pod template extensions + PodTemplate string `json:"podTemplate,omitempty"` + // name of the template resource + PodTemplateReference string `json:"podTemplateReference,omitempty"` +} + +// pod resources request specification +type PodResourcesRequest struct { + Requests *ResourceRequest `json:"requests,omitempty"` + Limits *ResourceRequest `json:"limits,omitempty"` +} + +// resource request specification +type ResourceRequest struct { + // requested cpu units + Cpu string `json:"cpu,omitempty"` + // requested memory units + Memory string `json:"memory,omitempty"` +} + // test execution type Execution struct { // execution id @@ -255,7 +278,8 @@ type Execution struct { // shell used in container executor ContainerShell string `json:"containerShell,omitempty"` // test execution name started the test execution - TestExecutionName string `json:"testExecutionName,omitempty"` + TestExecutionName string `json:"testExecutionName,omitempty"` + SlavePodRequest *PodRequest `json:"slavePodRequest,omitempty"` } // artifact request body with test artifacts diff --git a/api/testsuiteexecution/v1/zz_generated.deepcopy.go b/api/testsuiteexecution/v1/zz_generated.deepcopy.go index 5e2c1176..027a52f4 100644 --- a/api/testsuiteexecution/v1/zz_generated.deepcopy.go +++ b/api/testsuiteexecution/v1/zz_generated.deepcopy.go @@ -121,6 +121,11 @@ func (in *Execution) DeepCopyInto(out *Execution) { *out = new(RunningContext) **out = **in } + if in.SlavePodRequest != nil { + in, out := &in.SlavePodRequest, &out.SlavePodRequest + *out = new(PodRequest) + (*in).DeepCopyInto(*out) + } } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Execution. @@ -215,6 +220,51 @@ func (in *ObjectRef) DeepCopy() *ObjectRef { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodRequest) DeepCopyInto(out *PodRequest) { + *out = *in + if in.Resources != nil { + in, out := &in.Resources, &out.Resources + *out = new(PodResourcesRequest) + (*in).DeepCopyInto(*out) + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodRequest. +func (in *PodRequest) DeepCopy() *PodRequest { + if in == nil { + return nil + } + out := new(PodRequest) + in.DeepCopyInto(out) + return out +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PodResourcesRequest) DeepCopyInto(out *PodResourcesRequest) { + *out = *in + if in.Requests != nil { + in, out := &in.Requests, &out.Requests + *out = new(ResourceRequest) + **out = **in + } + if in.Limits != nil { + in, out := &in.Limits, &out.Limits + *out = new(ResourceRequest) + **out = **in + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodResourcesRequest. +func (in *PodResourcesRequest) DeepCopy() *PodResourcesRequest { + if in == nil { + return nil + } + out := new(PodResourcesRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *Repository) DeepCopyInto(out *Repository) { *out = *in @@ -255,6 +305,21 @@ func (in *RepositoryParameters) DeepCopy() *RepositoryParameters { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *ResourceRequest) DeepCopyInto(out *ResourceRequest) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceRequest. +func (in *ResourceRequest) DeepCopy() *ResourceRequest { + if in == nil { + return nil + } + out := new(ResourceRequest) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *RunningContext) DeepCopyInto(out *RunningContext) { *out = *in diff --git a/api/testtriggers/v1/zz_generated.deepcopy.go b/api/testtriggers/v1/zz_generated.deepcopy.go index ac2c588b..de6b839b 100644 --- a/api/testtriggers/v1/zz_generated.deepcopy.go +++ b/api/testtriggers/v1/zz_generated.deepcopy.go @@ -209,7 +209,7 @@ func (in *TestTriggerSpec) DeepCopyInto(out *TestTriggerSpec) { if in.Delay != nil { in, out := &in.Delay, &out.Delay *out = new(metav1.Duration) - (*in).DeepCopyInto(*out) + **out = **in } } diff --git a/config/crd/bases/tests.testkube.io_templates.yaml b/config/crd/bases/tests.testkube.io_templates.yaml index e951fd4b..4572d684 100644 --- a/config/crd/bases/tests.testkube.io_templates.yaml +++ b/config/crd/bases/tests.testkube.io_templates.yaml @@ -47,6 +47,7 @@ spec: - scraper - pvc - webhook + - pod type: string required: - body diff --git a/config/crd/bases/tests.testkube.io_testexecutions.yaml b/config/crd/bases/tests.testkube.io_testexecutions.yaml index 80082323..e69c6e54 100644 --- a/config/crd/bases/tests.testkube.io_testexecutions.yaml +++ b/config/crd/bases/tests.testkube.io_testexecutions.yaml @@ -235,6 +235,40 @@ spec: description: 'Execution variables passed to executor from secrets. Deprecated: use Secret Variables instead' type: object + slavePodRequest: + description: pod request body + properties: + podTemplate: + description: pod template extensions + type: string + podTemplateReference: + description: name of the template resource + type: string + resources: + description: pod resources request specification + properties: + limits: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + requests: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + type: object + type: object sync: description: whether to start execution sync or async type: boolean @@ -630,6 +664,40 @@ spec: required: - type type: object + slavePodRequest: + description: pod request body + properties: + podTemplate: + description: pod template extensions + type: string + podTemplateReference: + description: name of the template resource + type: string + resources: + description: pod resources request specification + properties: + limits: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + requests: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + type: object + type: object startTime: description: test start time format: date-time diff --git a/config/crd/bases/tests.testkube.io_tests.yaml b/config/crd/bases/tests.testkube.io_tests.yaml index 62a47d6d..2995e13b 100644 --- a/config/crd/bases/tests.testkube.io_tests.yaml +++ b/config/crd/bases/tests.testkube.io_tests.yaml @@ -625,6 +625,40 @@ spec: description: 'Execution variables passed to executor from secrets. Deprecated: use Secret Variables instead' type: object + slavePodRequest: + description: pod request body + properties: + podTemplate: + description: pod template extensions + type: string + podTemplateReference: + description: name of the template resource + type: string + resources: + description: pod resources request specification + properties: + limits: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + requests: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + type: object + type: object sync: description: whether to start execution sync or async type: boolean diff --git a/config/crd/bases/tests.testkube.io_testsuiteexecutions.yaml b/config/crd/bases/tests.testkube.io_testsuiteexecutions.yaml index 1017e0f2..205a0f18 100644 --- a/config/crd/bases/tests.testkube.io_testsuiteexecutions.yaml +++ b/config/crd/bases/tests.testkube.io_testsuiteexecutions.yaml @@ -549,6 +549,40 @@ spec: required: - type type: object + slavePodRequest: + description: pod request body + properties: + podTemplate: + description: pod template extensions + type: string + podTemplateReference: + description: name of the template resource + type: string + resources: + description: pod resources request specification + properties: + limits: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + requests: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + type: object + type: object startTime: description: test start time format: date-time @@ -1055,6 +1089,40 @@ spec: required: - type type: object + slavePodRequest: + description: pod request body + properties: + podTemplate: + description: pod template extensions + type: string + podTemplateReference: + description: name of the template resource + type: string + resources: + description: pod resources request specification + properties: + limits: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + requests: + description: resource request specification + properties: + cpu: + description: requested cpu units + type: string + memory: + description: requested memory units + type: string + type: object + type: object + type: object startTime: description: test start time format: date-time diff --git a/go.mod b/go.mod index 8cc2d928..17dfec7a 100644 --- a/go.mod +++ b/go.mod @@ -4,19 +4,19 @@ go 1.21 require ( github.com/golang/mock v1.6.0 - github.com/google/uuid v1.3.1 + github.com/google/uuid v1.4.0 github.com/kelseyhightower/envconfig v1.4.0 github.com/onsi/ginkgo v1.16.5 - github.com/onsi/ginkgo/v2 v2.12.0 - github.com/onsi/gomega v1.27.10 + github.com/onsi/ginkgo/v2 v2.13.2 + github.com/onsi/gomega v1.30.0 github.com/pkg/errors v0.9.1 github.com/stretchr/testify v1.8.4 - go.uber.org/zap v1.25.0 - k8s.io/api v0.28.2 - k8s.io/apimachinery v0.28.2 - k8s.io/client-go v0.28.2 - sigs.k8s.io/controller-runtime v0.16.2 - sigs.k8s.io/kustomize/kyaml v0.14.3 + go.uber.org/zap v1.26.0 + k8s.io/api v0.28.4 + k8s.io/apimachinery v0.28.4 + k8s.io/client-go v0.28.4 + sigs.k8s.io/controller-runtime v0.16.3 + sigs.k8s.io/kustomize/kyaml v0.15.0 ) require ( @@ -28,7 +28,7 @@ require ( github.com/evanphx/json-patch/v5 v5.7.0 // indirect github.com/fsnotify/fsnotify v1.6.0 // indirect github.com/go-errors/errors v1.5.1 // indirect - github.com/go-logr/logr v1.2.4 // indirect + github.com/go-logr/logr v1.3.0 // indirect github.com/go-logr/zapr v1.2.4 // indirect github.com/go-openapi/jsonpointer v0.20.0 // indirect github.com/go-openapi/jsonreference v0.20.2 // indirect @@ -38,7 +38,7 @@ require ( github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect github.com/golang/protobuf v1.5.3 // indirect github.com/google/gnostic-models v0.6.8 // indirect - github.com/google/go-cmp v0.5.9 // indirect + github.com/google/go-cmp v0.6.0 // indirect github.com/google/gofuzz v1.2.0 // indirect github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1 // indirect github.com/imdario/mergo v0.3.16 // indirect @@ -58,13 +58,13 @@ require ( github.com/spf13/pflag v1.0.5 // indirect go.uber.org/multierr v1.11.0 // indirect golang.org/x/exp v0.0.0-20230905200255-921286631fa9 // indirect - golang.org/x/net v0.15.0 // indirect + golang.org/x/net v0.17.0 // indirect golang.org/x/oauth2 v0.12.0 // indirect - golang.org/x/sys v0.12.0 // indirect - golang.org/x/term v0.12.0 // indirect + golang.org/x/sys v0.14.0 // indirect + golang.org/x/term v0.13.0 // indirect golang.org/x/text v0.13.0 // indirect golang.org/x/time v0.3.0 // indirect - golang.org/x/tools v0.13.0 // indirect + golang.org/x/tools v0.14.0 // indirect gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect google.golang.org/appengine v1.6.8 // indirect google.golang.org/protobuf v1.31.0 // indirect @@ -72,8 +72,8 @@ require ( gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 // indirect gopkg.in/yaml.v2 v2.4.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect - k8s.io/apiextensions-apiserver v0.28.2 // indirect - k8s.io/component-base v0.28.2 // indirect + k8s.io/apiextensions-apiserver v0.28.3 // indirect + k8s.io/component-base v0.28.3 // indirect k8s.io/klog/v2 v2.100.1 // indirect k8s.io/kube-openapi v0.0.0-20230918164632-68afd615200d // indirect k8s.io/utils v0.0.0-20230726121419-3b25d923346b // indirect diff --git a/go.sum b/go.sum index fbe0b46c..56132a55 100644 --- a/go.sum +++ b/go.sum @@ -1,6 +1,4 @@ github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= -github.com/benbjohnson/clock v1.3.0 h1:ip6w0uFQkncKQ979AypyG0ER7mqUSBdKLOgAle/AT8A= -github.com/benbjohnson/clock v1.3.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44= @@ -25,8 +23,9 @@ github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbS github.com/go-errors/errors v1.5.1 h1:ZwEMSLRCapFLflTpT7NKaAc7ukJ8ZPEjzlxt8rPN8bk= github.com/go-errors/errors v1.5.1/go.mod h1:sIVyrIiJhuEF+Pj9Ebtd6P/rEYROXFi3BopGUQ5a5Og= github.com/go-logr/logr v1.2.0/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= -github.com/go-logr/logr v1.2.4 h1:g01GSCwiDw2xSZfjJ2/T9M+S6pFdcNtFYsp+Y43HYDQ= github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.3.0 h1:2y3SDp0ZXuc6/cjLSZ+Q3ir+QB9T/iG5yYRXqsagWSY= +github.com/go-logr/logr v1.3.0/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= github.com/go-logr/zapr v1.2.4 h1:QHVo+6stLbfJmYGkQ7uGHUCu5hnAFAj6mDe6Ea0SeOo= github.com/go-logr/zapr v1.2.4/go.mod h1:FyHWQIzQORZ0QVE1BtVHv3cKtNLuXsbNLtpuhNapBOA= github.com/go-openapi/jsonpointer v0.19.6/go.mod h1:osyAmYz/mB/C3I+WsTTSgw1ONzaLJoLCyoi6/zppojs= @@ -63,15 +62,16 @@ github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMyw github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= +github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1 h1:K6RDEckDVWvDI9JAJYCmNdQXq6neHJOYx3V6jnqNEec= github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= -github.com/google/uuid v1.3.1 h1:KjJaJ9iWZ3jOFZIf1Lqf4laDRCasjl0BCmnEGxkdLb4= -github.com/google/uuid v1.3.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/google/uuid v1.4.0 h1:MtMxsa51/r9yyhkyLsVeVt0B+BGQZzpQiTQ4eHZ8bc4= +github.com/google/uuid v1.4.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= github.com/imdario/mergo v0.3.16 h1:wwQJbIsHYGMUyLSPrEq1CT16AhnhNJQ51+4fdHUnCl4= @@ -112,12 +112,12 @@ github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+W github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE= github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU= -github.com/onsi/ginkgo/v2 v2.12.0 h1:UIVDowFPwpg6yMUpPjGkYvf06K3RAiJXUhCxEwQVHRI= -github.com/onsi/ginkgo/v2 v2.12.0/go.mod h1:ZNEzXISYlqpb8S36iN71ifqLi3vVD1rVJGvWRCJOUpQ= +github.com/onsi/ginkgo/v2 v2.13.2 h1:Bi2gGVkfn6gQcjNjZJVO8Gf0FHzMPf2phUei9tejVMs= +github.com/onsi/ginkgo/v2 v2.13.2/go.mod h1:XStQ8QcGwLyF4HdfcZB8SFOS/MWCgDuXMSBe6zrvLgM= github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= -github.com/onsi/gomega v1.27.10 h1:naR28SdDFlqrG6kScpT8VWpu1xWY5nJRCF3XaYyBjhI= -github.com/onsi/gomega v1.27.10/go.mod h1:RsS8tutOdbdgzbPtzzATp12yT7kM5I5aElG3evPbQ0M= +github.com/onsi/gomega v1.30.0 h1:hvMK7xYz4D3HapigLTeGdId/NcfQx1VHMJc60ew99+8= +github.com/onsi/gomega v1.30.0/go.mod h1:9sxs+SwGrKI0+PWe4Fxa9tFQQBG5xSsSbMXOI8PPpoQ= github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= @@ -161,8 +161,8 @@ go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9i go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= go.uber.org/zap v1.24.0/go.mod h1:2kMP+WWQ8aoFoedH3T2sq6iJ2yDWpHbP0f6MQbS9Gkg= -go.uber.org/zap v1.25.0 h1:4Hvk6GtkucQ790dqmj7l1eEnRdKm3k3ZUrUMS2d5+5c= -go.uber.org/zap v1.25.0/go.mod h1:JIAUzQIH94IC4fOJQm7gMmBJP5k7wQfdcnYdPoEXJYk= +go.uber.org/zap v1.26.0 h1:sI7k6L95XOKS281NhVKOFCUNIvv9e0w4BF8N3u+tCRo= +go.uber.org/zap v1.26.0/go.mod h1:dtElttAiwGvoJ/vj4IwHBS/gXsEu/pZ50mUIRWuG0so= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= @@ -174,8 +174,8 @@ golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= -golang.org/x/mod v0.12.0 h1:rmsUpXtvNzj340zd98LZ4KntptpfRHwpFOHG188oHXc= -golang.org/x/mod v0.12.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.13.0 h1:I/DsJXRlw/8l/0c24sM9yb0T4z9liZTduXvdAWYiysY= +golang.org/x/mod v0.13.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= @@ -186,8 +186,8 @@ golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwY golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= -golang.org/x/net v0.15.0 h1:ugBLEUaxABaB5AJqW9enI0ACdci2RUd4eP51NTBvuJ8= -golang.org/x/net v0.15.0/go.mod h1:idbUs1IY1+zTqbi8yxTbhexhEEk5ur9LInksu6HrEpk= +golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM= +golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= golang.org/x/oauth2 v0.12.0 h1:smVPGxink+n1ZI5pkQa8y6fZT0RW0MgCO5bFpepy4B4= golang.org/x/oauth2 v0.12.0/go.mod h1:A74bZ3aGXgCY0qaIC9Ahg6Lglin4AMAco8cIv9baba4= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -214,12 +214,12 @@ golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBc golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.12.0 h1:CM0HF96J0hcLAwsHPJZjfdNzs0gftsLfgKt57wWHJ0o= -golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q= +golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= -golang.org/x/term v0.12.0 h1:/ZfYdc3zq+q02Rv9vGqTeSItdzZTSNDmfTi0mBAuidU= -golang.org/x/term v0.12.0/go.mod h1:owVbMEjm3cBLCHdkQu9b1opXd4ETQWc3BhuQGKgXgvU= +golang.org/x/term v0.13.0 h1:bb+I9cTfFazGW51MZqBVmZy7+JEJMouUHTUSKVQLBek= +golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= @@ -237,8 +237,8 @@ golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4f golang.org/x/tools v0.1.1/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= -golang.org/x/tools v0.13.0 h1:Iey4qkscZuv0VvIt8E0neZjtPVQFSc870HQ448QgEmQ= -golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= +golang.org/x/tools v0.14.0 h1:jvNa2pY0M4r62jkRQ6RwEZZyPcymeL9XZMLBbV7U2nc= +golang.org/x/tools v0.14.0/go.mod h1:uYBEerGOWcJyEORxN+Ek8+TT266gXkNlHdJBwexUsBg= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= @@ -275,28 +275,28 @@ gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -k8s.io/api v0.28.2 h1:9mpl5mOb6vXZvqbQmankOfPIGiudghwCoLl1EYfUZbw= -k8s.io/api v0.28.2/go.mod h1:RVnJBsjU8tcMq7C3iaRSGMeaKt2TWEUXcpIt/90fjEg= -k8s.io/apiextensions-apiserver v0.28.2 h1:J6/QRWIKV2/HwBhHRVITMLYoypCoPY1ftigDM0Kn+QU= -k8s.io/apiextensions-apiserver v0.28.2/go.mod h1:5tnkxLGa9nefefYzWuAlWZ7RZYuN/765Au8cWLA6SRg= -k8s.io/apimachinery v0.28.2 h1:KCOJLrc6gu+wV1BYgwik4AF4vXOlVJPdiqn0yAWWwXQ= -k8s.io/apimachinery v0.28.2/go.mod h1:RdzF87y/ngqk9H4z3EL2Rppv5jj95vGS/HaFXrLDApU= -k8s.io/client-go v0.28.2 h1:DNoYI1vGq0slMBN/SWKMZMw0Rq+0EQW6/AK4v9+3VeY= -k8s.io/client-go v0.28.2/go.mod h1:sMkApowspLuc7omj1FOSUxSoqjr+d5Q0Yc0LOFnYFJY= -k8s.io/component-base v0.28.2 h1:Yc1yU+6AQSlpJZyvehm/NkJBII72rzlEsd6MkBQ+G0E= -k8s.io/component-base v0.28.2/go.mod h1:4IuQPQviQCg3du4si8GpMrhAIegxpsgPngPRR/zWpzc= +k8s.io/api v0.28.4 h1:8ZBrLjwosLl/NYgv1P7EQLqoO8MGQApnbgH8tu3BMzY= +k8s.io/api v0.28.4/go.mod h1:axWTGrY88s/5YE+JSt4uUi6NMM+gur1en2REMR7IRj0= +k8s.io/apiextensions-apiserver v0.28.3 h1:Od7DEnhXHnHPZG+W9I97/fSQkVpVPQx2diy+2EtmY08= +k8s.io/apiextensions-apiserver v0.28.3/go.mod h1:NE1XJZ4On0hS11aWWJUTNkmVB03j9LM7gJSisbRt8Lc= +k8s.io/apimachinery v0.28.4 h1:zOSJe1mc+GxuMnFzD4Z/U1wst50X28ZNsn5bhgIIao8= +k8s.io/apimachinery v0.28.4/go.mod h1:wI37ncBvfAoswfq626yPTe6Bz1c22L7uaJ8dho83mgg= +k8s.io/client-go v0.28.4 h1:Np5ocjlZcTrkyRJ3+T3PkXDpe4UpatQxj85+xjaD2wY= +k8s.io/client-go v0.28.4/go.mod h1:0VDZFpgoZfelyP5Wqu0/r/TRYcLYuJ2U1KEeoaPa1N4= +k8s.io/component-base v0.28.3 h1:rDy68eHKxq/80RiMb2Ld/tbH8uAE75JdCqJyi6lXMzI= +k8s.io/component-base v0.28.3/go.mod h1:fDJ6vpVNSk6cRo5wmDa6eKIG7UlIQkaFmZN2fYgIUD8= k8s.io/klog/v2 v2.100.1 h1:7WCHKK6K8fNhTqfBhISHQ97KrnJNFZMcQvKp7gP/tmg= k8s.io/klog/v2 v2.100.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0= k8s.io/kube-openapi v0.0.0-20230918164632-68afd615200d h1:/CFeJBjBrZvHX09rObS2+2iEEDevMWYc1v3aIYAjIYI= k8s.io/kube-openapi v0.0.0-20230918164632-68afd615200d/go.mod h1:AsvuZPBlUDVuCdzJ87iajxtXuR9oktsTctW/R9wwouA= k8s.io/utils v0.0.0-20230726121419-3b25d923346b h1:sgn3ZU783SCgtaSJjpcVVlRqd6GSnlTLKgpAAttJvpI= k8s.io/utils v0.0.0-20230726121419-3b25d923346b/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= -sigs.k8s.io/controller-runtime v0.16.2 h1:mwXAVuEk3EQf478PQwQ48zGOXvW27UJc8NHktQVuIPU= -sigs.k8s.io/controller-runtime v0.16.2/go.mod h1:vpMu3LpI5sYWtujJOa2uPK61nB5rbwlN7BAB8aSLvGU= +sigs.k8s.io/controller-runtime v0.16.3 h1:2TuvuokmfXvDUamSx1SuAOO3eTyye+47mJCigwG62c4= +sigs.k8s.io/controller-runtime v0.16.3/go.mod h1:j7bialYoSn142nv9sCOJmQgDXQXxnroFU4VnX/brVJ0= sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd h1:EDPBXCAspyGV4jQlpZSudPeMmr1bNJefnuqLsRAsHZo= sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd/go.mod h1:B8JuhiUyNFVKdsE8h686QcCxMaH6HrOAZj4vswFpcB0= -sigs.k8s.io/kustomize/kyaml v0.14.3 h1:WpabVAKZe2YEp/irTSHwD6bfjwZnTtSDewd2BVJGMZs= -sigs.k8s.io/kustomize/kyaml v0.14.3/go.mod h1:npvh9epWysfQ689Rtt/U+dpOJDTBn8kUnF1O6VzvmZA= +sigs.k8s.io/kustomize/kyaml v0.15.0 h1:ynlLMAxDhrY9otSg5GYE2TcIz31XkGZ2Pkj7SdolD84= +sigs.k8s.io/kustomize/kyaml v0.15.0/go.mod h1:+uMkBahdU1KNOj78Uta4rrXH+iH7wvg+nW7+GULvREA= sigs.k8s.io/structured-merge-diff/v4 v4.3.0 h1:UZbZAZfX0wV2zr7YZorDz6GXROfDFj6LvqCRm4VUVKk= sigs.k8s.io/structured-merge-diff/v4 v4.3.0/go.mod h1:N8hJocpFajUSSeSJ9bOZ77VzejKZaXsTtZo4/u7Io08= sigs.k8s.io/yaml v1.3.0 h1:a2VclLzOGrwOHDiV8EfBGhvjHvP46CtW5j6POvhYGGo=