From a601409aa05df1bc401c9c16f6f5888ee1b7e513 Mon Sep 17 00:00:00 2001 From: Vibhu Prashar Date: Fri, 14 Jun 2024 17:08:38 +0530 Subject: [PATCH] feat: migrate operator code base to support new operator-sdk version This PR updates the code base for compatibility with the latest operator-sdk version(v1.35.0) Key Changes: * Moved API files from `pkg/api` to `api` folder * Relocated `main.go` from `cmd/manager/main.go` to `cmd/main.go` * Shifted controllers from `pkg/controllers` to `internal/controller` folder * Made minor updates to components, utils and tests to use correct import paths * Updated scaffolding config to align with the latest operator-sdk version * Revised Operator, bundle and e2e Dockerfiles * Upgraded operator-sdk to v1.35.0 and controller-gen to v0.13.0 * Updated bundle manifests accordingly Signed-off-by: Vibhu Prashar --- Dockerfile | 23 +-- Makefile | 8 +- PROJECT | 6 +- .../api => api}/v1alpha1/groupversion_info.go | 2 +- .../v1alpha1/kepler_internal_types.go | 2 +- {pkg/api => api}/v1alpha1/kepler_types.go | 2 +- {pkg/api => api}/v1alpha1/kepler_webhook.go | 2 +- .../v1alpha1/zz_generated.deepcopy.go | 3 +- bundle.Dockerfile | 4 +- ...kepler-operator.clusterserviceversion.yaml | 8 +- ...tainable.computing.io_keplerinternals.yaml | 2 +- ...stem.sustainable.computing.io_keplers.yaml | 2 +- bundle/metadata/annotations.yaml | 4 +- bundle/tests/scorecard/config.yaml | 12 +- cmd/{manager => }/main.go | 20 +-- config/certmanager/certificate.yaml | 10 +- config/certmanager/kustomizeconfig.yaml | 10 +- ...tainable.computing.io_keplerinternals.yaml | 2 +- ...stem.sustainable.computing.io_keplers.yaml | 2 +- config/crd/kustomization.yaml | 8 +- .../crd/patches/cainjection_in_keplers.yaml | 2 +- config/default/kustomization.yaml | 144 +++++++++++++----- config/default/manager_auth_proxy_patch.yaml | 4 +- config/default/manager_webhook_patch.yaml | 12 +- config/default/webhookcainjection_patch.yaml | 6 +- config/manager/kustomization.yaml | 6 - config/manifests/kustomization.yaml | 10 +- config/prometheus/monitor.yaml | 13 +- config/rbac/auth_proxy_service.yaml | 9 ++ config/rbac/service_account.yaml | 2 +- config/scorecard/patches/basic.config.yaml | 2 +- config/scorecard/patches/olm.config.yaml | 10 +- config/webhook/kustomizeconfig.yaml | 5 +- hack/boilerplate.go.txt | 4 +- hack/bundle.sh | 2 +- hack/tools.sh | 4 +- .../controller}/config.go | 2 +- .../controller}/kepler.go | 12 +- .../controller}/kepler_internal.go | 15 +- .../controller}/reconcilers.go | 2 +- pkg/components/estimator/estimator.go | 2 +- pkg/components/estimator/estimator_test.go | 2 +- pkg/components/exporter/exporter.go | 2 +- pkg/components/exporter/exporter_test.go | 2 +- pkg/components/modelserver/modelserver.go | 2 +- .../modelserver/modelserver_test.go | 2 +- pkg/reconciler/kepler.go | 2 +- pkg/utils/k8s/k8s.go | 2 +- pkg/utils/test/assertions.go | 2 +- pkg/utils/test/framework.go | 2 +- pkg/utils/test/kepler_internal_builder.go | 2 +- tests/Dockerfile | 8 +- tests/e2e/kepler_internal_test.go | 18 +-- tests/e2e/kepler_test.go | 39 +++-- tests/e2e/main_test.go | 8 +- 55 files changed, 274 insertions(+), 219 deletions(-) rename {pkg/api => api}/v1alpha1/groupversion_info.go (98%) rename {pkg/api => api}/v1alpha1/kepler_internal_types.go (99%) rename {pkg/api => api}/v1alpha1/kepler_types.go (99%) rename {pkg/api => api}/v1alpha1/kepler_webhook.go (99%) rename {pkg/api => api}/v1alpha1/zz_generated.deepcopy.go (99%) rename cmd/{manager => }/main.go (89%) rename {pkg/controllers => internal/controller}/config.go (97%) rename {pkg/controllers => internal/controller}/kepler.go (98%) rename {pkg/controllers => internal/controller}/kepler_internal.go (99%) rename {pkg/controllers => internal/controller}/reconcilers.go (98%) diff --git a/Dockerfile b/Dockerfile index ec44c8e2..e1b15135 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,5 +1,5 @@ # Build the manager binary -FROM golang:1.21 as builder +FROM golang:1.21 AS builder ARG TARGETOS ARG TARGETARCH @@ -11,11 +11,14 @@ COPY go.sum go.sum # and so that source changes don't invalidate our downloaded layer RUN go mod download -# Copy the go source +# Copy must-gather scripts COPY must-gather/ must-gather/ -COPY cmd/ cmd/ -COPY pkg/ pkg/ +# Copy the go source +COPY cmd/main.go cmd/main.go +COPY api/ api/ +COPY pkg/ pkg/ +COPY internal/ internal/ # Build # the GOARCH has not a default value to allow the binary be built according to the host where the command @@ -23,17 +26,17 @@ COPY pkg/ pkg/ # the docker BUILDPLATFORM arg will be linux/arm64 when for Apple x86 it will be linux/amd64. Therefore, # by leaving it empty we can ensure that the container and binary shipped on it will have the same platform. RUN CGO_ENABLED=0 GOOS=${TARGETOS:-linux} GOARCH=${TARGETARCH} \ - go build -a -o manager ./cmd/manager/... + go build -a -o manager cmd/main.go FROM quay.io/openshift/origin-cli:4.13 AS origincli FROM registry.access.redhat.com/ubi9-minimal:9.2 RUN INSTALL_PKGS=" \ - rsync \ - tar \ - " && \ - microdnf install -y $INSTALL_PKGS && \ - microdnf clean all + rsync \ + tar \ + " && \ + microdnf install -y $INSTALL_PKGS && \ + microdnf clean all WORKDIR / COPY --from=builder /workspace/manager . COPY --from=builder /workspace/must-gather/* /usr/bin/ diff --git a/Makefile b/Makefile index c321ecb8..006fc800 100644 --- a/Makefile +++ b/Makefile @@ -89,11 +89,11 @@ help: ## Display this help. .PHONY: manifests manifests: controller-gen ## Generate WebhookConfiguration, ClusterRole and CustomResourceDefinition objects. - $(CONTROLLER_GEN) rbac:roleName=manager-role crd webhook paths="./pkg/..." output:crd:artifacts:config=config/crd/bases + $(CONTROLLER_GEN) rbac:roleName=manager-role crd webhook paths="./..." output:crd:artifacts:config=config/crd/bases .PHONY: generate generate: controller-gen ## Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations. - $(CONTROLLER_GEN) object:headerFile="hack/boilerplate.go.txt" paths="./pkg/..." + $(CONTROLLER_GEN) object:headerFile="hack/boilerplate.go.txt" paths="./..." .PHONY: fmt fmt: shfmt ## Run go fmt against code. @@ -153,14 +153,14 @@ cluster-down: ## delete the local development cluster .PHONY: build build: manifests generate fmt vet ## Build manager binary. - go build -o bin/manager ./cmd/manager/... + go build -o bin/manager ./cmd/... OPENSHIFT ?= true RUN_ARGS ?= .PHONY: run run: install fmt vet ## Run a controller from your host against openshift cluster - go run ./cmd/manager/... \ + go run ./cmd/... \ --kepler.image=$(KEPLER_IMG) \ --zap-devel --zap-log-level=8 \ --openshift=$(OPENSHIFT) \ diff --git a/PROJECT b/PROJECT index 8625b9a3..2326040e 100644 --- a/PROJECT +++ b/PROJECT @@ -1,6 +1,10 @@ +# Code generated by tool. DO NOT EDIT. +# This file is used to track the info used to scaffold your project +# and allow the plugins properly work. +# More info: https://book.kubebuilder.io/reference/project-config.html domain: sustainable.computing.io layout: -- go.kubebuilder.io/v3 +- go.kubebuilder.io/v4 plugins: manifests.sdk.operatorframework.io/v2: {} scorecard.sdk.operatorframework.io/v2: {} diff --git a/pkg/api/v1alpha1/groupversion_info.go b/api/v1alpha1/groupversion_info.go similarity index 98% rename from pkg/api/v1alpha1/groupversion_info.go rename to api/v1alpha1/groupversion_info.go index fb0ebeca..667763b2 100644 --- a/pkg/api/v1alpha1/groupversion_info.go +++ b/api/v1alpha1/groupversion_info.go @@ -1,5 +1,5 @@ /* -Copyright 2022. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/pkg/api/v1alpha1/kepler_internal_types.go b/api/v1alpha1/kepler_internal_types.go similarity index 99% rename from pkg/api/v1alpha1/kepler_internal_types.go rename to api/v1alpha1/kepler_internal_types.go index 771f598b..12fab21d 100644 --- a/pkg/api/v1alpha1/kepler_internal_types.go +++ b/api/v1alpha1/kepler_internal_types.go @@ -1,5 +1,5 @@ /* -Copyright 2023. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/pkg/api/v1alpha1/kepler_types.go b/api/v1alpha1/kepler_types.go similarity index 99% rename from pkg/api/v1alpha1/kepler_types.go rename to api/v1alpha1/kepler_types.go index 21d5a274..dfd5b040 100644 --- a/pkg/api/v1alpha1/kepler_types.go +++ b/api/v1alpha1/kepler_types.go @@ -1,5 +1,5 @@ /* -Copyright 2022. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/pkg/api/v1alpha1/kepler_webhook.go b/api/v1alpha1/kepler_webhook.go similarity index 99% rename from pkg/api/v1alpha1/kepler_webhook.go rename to api/v1alpha1/kepler_webhook.go index e5dd6bdb..73932024 100644 --- a/pkg/api/v1alpha1/kepler_webhook.go +++ b/api/v1alpha1/kepler_webhook.go @@ -1,5 +1,5 @@ /* -Copyright 2023. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/pkg/api/v1alpha1/zz_generated.deepcopy.go b/api/v1alpha1/zz_generated.deepcopy.go similarity index 99% rename from pkg/api/v1alpha1/zz_generated.deepcopy.go rename to api/v1alpha1/zz_generated.deepcopy.go index 621fce09..a6b05cf4 100644 --- a/pkg/api/v1alpha1/zz_generated.deepcopy.go +++ b/api/v1alpha1/zz_generated.deepcopy.go @@ -1,8 +1,7 @@ //go:build !ignore_autogenerated -// +build !ignore_autogenerated /* -Copyright 2023. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/bundle.Dockerfile b/bundle.Dockerfile index 57eda2d3..0797a508 100644 --- a/bundle.Dockerfile +++ b/bundle.Dockerfile @@ -7,9 +7,9 @@ LABEL operators.operatorframework.io.bundle.metadata.v1=metadata/ LABEL operators.operatorframework.io.bundle.package.v1=kepler-operator LABEL operators.operatorframework.io.bundle.channels.v1=alpha LABEL operators.operatorframework.io.bundle.channel.default.v1=alpha -LABEL operators.operatorframework.io.metrics.builder=operator-sdk-v1.27.0 +LABEL operators.operatorframework.io.metrics.builder=operator-sdk-v1.35.0 LABEL operators.operatorframework.io.metrics.mediatype.v1=metrics+v1 -LABEL operators.operatorframework.io.metrics.project_layout=go.kubebuilder.io/v3 +LABEL operators.operatorframework.io.metrics.project_layout=go.kubebuilder.io/v4 # Labels for testing. LABEL operators.operatorframework.io.test.mediatype.v1=scorecard+v1 diff --git a/bundle/manifests/kepler-operator.clusterserviceversion.yaml b/bundle/manifests/kepler-operator.clusterserviceversion.yaml index c87f8ee0..6102de6d 100644 --- a/bundle/manifests/kepler-operator.clusterserviceversion.yaml +++ b/bundle/manifests/kepler-operator.clusterserviceversion.yaml @@ -30,12 +30,12 @@ metadata: containerImage: quay.io/sustainable_computing_io/kepler-operator:0.13.0 createdAt: "2024-07-11T07:04:57Z" description: 'Deploys and Manages Kepler on Kubernetes ' - operators.operatorframework.io/builder: operator-sdk-v1.27.0 + operators.operatorframework.io/builder: operator-sdk-v1.35.0 operators.operatorframework.io/internal-objects: |- [ "keplerinternals.kepler.system.sustainable.computing.io" ] - operators.operatorframework.io/project_layout: go.kubebuilder.io/v3 + operators.operatorframework.io/project_layout: go.kubebuilder.io/v4 repository: https://github.com/sustainable-computing-io/kepler-operator support: https://github.com/sustainable-computing-io/kepler-operator/issues name: kepler-operator.v0.13.0 @@ -302,10 +302,6 @@ spec: capabilities: drop: - ALL - volumeMounts: - - mountPath: /tmp/k8s-webhook-server/serving-certs - name: cert - readOnly: true securityContext: runAsNonRoot: true serviceAccountName: kepler-operator-controller-manager diff --git a/bundle/manifests/kepler.system.sustainable.computing.io_keplerinternals.yaml b/bundle/manifests/kepler.system.sustainable.computing.io_keplerinternals.yaml index cb3685db..b860052b 100644 --- a/bundle/manifests/kepler.system.sustainable.computing.io_keplerinternals.yaml +++ b/bundle/manifests/kepler.system.sustainable.computing.io_keplerinternals.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.12.1 + controller-gen.kubebuilder.io/version: v0.13.0 creationTimestamp: null name: keplerinternals.kepler.system.sustainable.computing.io spec: diff --git a/bundle/manifests/kepler.system.sustainable.computing.io_keplers.yaml b/bundle/manifests/kepler.system.sustainable.computing.io_keplers.yaml index dbe4039e..464ce774 100644 --- a/bundle/manifests/kepler.system.sustainable.computing.io_keplers.yaml +++ b/bundle/manifests/kepler.system.sustainable.computing.io_keplers.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.12.1 + controller-gen.kubebuilder.io/version: v0.13.0 creationTimestamp: null name: keplers.kepler.system.sustainable.computing.io spec: diff --git a/bundle/metadata/annotations.yaml b/bundle/metadata/annotations.yaml index 6c3ba580..463c9587 100644 --- a/bundle/metadata/annotations.yaml +++ b/bundle/metadata/annotations.yaml @@ -6,9 +6,9 @@ annotations: operators.operatorframework.io.bundle.package.v1: kepler-operator operators.operatorframework.io.bundle.channels.v1: alpha operators.operatorframework.io.bundle.channel.default.v1: alpha - operators.operatorframework.io.metrics.builder: operator-sdk-v1.27.0 + operators.operatorframework.io.metrics.builder: operator-sdk-v1.35.0 operators.operatorframework.io.metrics.mediatype.v1: metrics+v1 - operators.operatorframework.io.metrics.project_layout: go.kubebuilder.io/v3 + operators.operatorframework.io.metrics.project_layout: go.kubebuilder.io/v4 # Annotations for testing. operators.operatorframework.io.test.mediatype.v1: scorecard+v1 diff --git a/bundle/tests/scorecard/config.yaml b/bundle/tests/scorecard/config.yaml index 8b5e5cff..4e32de13 100644 --- a/bundle/tests/scorecard/config.yaml +++ b/bundle/tests/scorecard/config.yaml @@ -8,7 +8,7 @@ stages: - entrypoint: - scorecard-test - basic-check-spec - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: basic test: basic-check-spec-test @@ -18,7 +18,7 @@ stages: - entrypoint: - scorecard-test - olm-bundle-validation - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-bundle-validation-test @@ -28,7 +28,7 @@ stages: - entrypoint: - scorecard-test - olm-crds-have-validation - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-crds-have-validation-test @@ -38,7 +38,7 @@ stages: - entrypoint: - scorecard-test - olm-crds-have-resources - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-crds-have-resources-test @@ -48,7 +48,7 @@ stages: - entrypoint: - scorecard-test - olm-spec-descriptors - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-spec-descriptors-test @@ -58,7 +58,7 @@ stages: - entrypoint: - scorecard-test - olm-status-descriptors - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-status-descriptors-test diff --git a/cmd/manager/main.go b/cmd/main.go similarity index 89% rename from cmd/manager/main.go rename to cmd/main.go index 7206982f..828a3faf 100644 --- a/cmd/manager/main.go +++ b/cmd/main.go @@ -39,11 +39,11 @@ import ( securityv1 "github.com/openshift/api/security/v1" - keplersystemv1alpha1 "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + keplersystemv1alpha1 "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/internal/controller" "github.com/sustainable.computing.io/kepler-operator/pkg/components/estimator" "github.com/sustainable.computing.io/kepler-operator/pkg/components/exporter" "github.com/sustainable.computing.io/kepler-operator/pkg/components/modelserver" - "github.com/sustainable.computing.io/kepler-operator/pkg/controllers" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" //+kubebuilder:scaffold:imports ) @@ -87,7 +87,7 @@ func main() { "Enable leader election for controller manager. "+ "Enabling this will ensure there is only one active controller manager.") - flag.StringVar(&controllers.KeplerDeploymentNS, "deployment-namespace", controllers.KeplerDeploymentNS, + flag.StringVar(&controller.KeplerDeploymentNS, "deployment-namespace", controller.KeplerDeploymentNS, "Namespace where kepler and its components are deployed.") flag.CommandLine.Var(flag.Value(&additionalNamespaces), "watch-namespaces", @@ -98,10 +98,10 @@ func main() { // NOTE: RELATED_IMAGE_KEPLER can be set as env or flag, flag takes precedence over env keplerImage := os.Getenv("RELATED_IMAGE_KEPLER") - flag.StringVar(&controllers.Config.Image, "kepler.image", keplerImage, "kepler image") + flag.StringVar(&controller.Config.Image, "kepler.image", keplerImage, "kepler image") - flag.StringVar(&controllers.InternalConfig.ModelServerImage, "estimator.image", estimator.StableImage, "kepler estimator image") - flag.StringVar(&controllers.InternalConfig.EstimatorImage, "model-server.image", modelserver.StableImage, "kepler model server image") + flag.StringVar(&controller.InternalConfig.ModelServerImage, "estimator.image", estimator.StableImage, "kepler estimator image") + flag.StringVar(&controller.InternalConfig.EstimatorImage, "model-server.image", modelserver.StableImage, "kepler model server image") opts := zap.Options{ Development: true, @@ -112,7 +112,7 @@ func main() { ctrl.SetLogger(zap.New(zap.UseFlagOptions(&opts))) if openshift { - controllers.Config.Cluster = k8s.OpenShift + controller.Config.Cluster = k8s.OpenShift } mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{ @@ -123,7 +123,7 @@ func main() { // TODO: add new introduced namespace from KeplerInternal.Spec.Deployment.Namespace NewCache: func(config *rest.Config, opts cache.Options) (cache.Cache, error) { cacheNs := map[string]cache.Config{ - controllers.KeplerDeploymentNS: {}, + controller.KeplerDeploymentNS: {}, } if openshift { cacheNs[exporter.DashboardNs] = cache.Config{} @@ -156,14 +156,14 @@ func main() { os.Exit(1) } - if err = (&controllers.KeplerReconciler{ + if err = (&controller.KeplerReconciler{ Client: mgr.GetClient(), Scheme: mgr.GetScheme(), }).SetupWithManager(mgr); err != nil { setupLog.Error(err, "unable to create controller", "controller", "kepler") os.Exit(1) } - if err = (&controllers.KeplerInternalReconciler{ + if err = (&controller.KeplerInternalReconciler{ Client: mgr.GetClient(), Scheme: mgr.GetScheme(), }).SetupWithManager(mgr); err != nil { diff --git a/config/certmanager/certificate.yaml b/config/certmanager/certificate.yaml index 92b36798..97189b7d 100644 --- a/config/certmanager/certificate.yaml +++ b/config/certmanager/certificate.yaml @@ -5,8 +5,8 @@ apiVersion: cert-manager.io/v1 kind: Issuer metadata: labels: - app.kubernetes.io/name: issuer - app.kubernetes.io/instance: selfsigned-issuer + app.kubernetes.io/name: certificate + app.kubernetes.io/instance: serving-cert app.kubernetes.io/component: certificate app.kubernetes.io/created-by: kepler-operator app.kubernetes.io/part-of: kepler-operator @@ -29,10 +29,10 @@ metadata: name: serving-cert # this name should match the one appeared in kustomizeconfig.yaml namespace: system spec: - # $(SERVICE_NAME) and $(SERVICE_NAMESPACE) will be substituted by kustomize + # SERVICE_NAME and SERVICE_NAMESPACE will be substituted by kustomize dnsNames: - - $(SERVICE_NAME).$(SERVICE_NAMESPACE).svc - - $(SERVICE_NAME).$(SERVICE_NAMESPACE).svc.cluster.local + - SERVICE_NAME.SERVICE_NAMESPACE.svc + - SERVICE_NAME.SERVICE_NAMESPACE.svc.cluster.local issuerRef: kind: Issuer name: selfsigned-issuer diff --git a/config/certmanager/kustomizeconfig.yaml b/config/certmanager/kustomizeconfig.yaml index 90d7c313..cf6f89e8 100644 --- a/config/certmanager/kustomizeconfig.yaml +++ b/config/certmanager/kustomizeconfig.yaml @@ -1,4 +1,4 @@ -# This configuration is for teaching kustomize how to update name ref and var substitution +# This configuration is for teaching kustomize how to update name ref substitution nameReference: - kind: Issuer group: cert-manager.io @@ -6,11 +6,3 @@ nameReference: - kind: Certificate group: cert-manager.io path: spec/issuerRef/name - -varReference: -- kind: Certificate - group: cert-manager.io - path: spec/commonName -- kind: Certificate - group: cert-manager.io - path: spec/dnsNames diff --git a/config/crd/bases/kepler.system.sustainable.computing.io_keplerinternals.yaml b/config/crd/bases/kepler.system.sustainable.computing.io_keplerinternals.yaml index 91d7cca5..6c20ccd7 100644 --- a/config/crd/bases/kepler.system.sustainable.computing.io_keplerinternals.yaml +++ b/config/crd/bases/kepler.system.sustainable.computing.io_keplerinternals.yaml @@ -3,7 +3,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.12.1 + controller-gen.kubebuilder.io/version: v0.13.0 name: keplerinternals.kepler.system.sustainable.computing.io spec: group: kepler.system.sustainable.computing.io diff --git a/config/crd/bases/kepler.system.sustainable.computing.io_keplers.yaml b/config/crd/bases/kepler.system.sustainable.computing.io_keplers.yaml index e48146b0..cf468d7f 100644 --- a/config/crd/bases/kepler.system.sustainable.computing.io_keplers.yaml +++ b/config/crd/bases/kepler.system.sustainable.computing.io_keplers.yaml @@ -3,7 +3,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.12.1 + controller-gen.kubebuilder.io/version: v0.13.0 name: keplers.kepler.system.sustainable.computing.io spec: group: kepler.system.sustainable.computing.io diff --git a/config/crd/kustomization.yaml b/config/crd/kustomization.yaml index 4d4f6536..3ebf9edd 100644 --- a/config/crd/kustomization.yaml +++ b/config/crd/kustomization.yaml @@ -6,17 +6,19 @@ resources: - bases/kepler.system.sustainable.computing.io_keplerinternals.yaml #+kubebuilder:scaffold:crdkustomizeresource -patchesStrategicMerge: +patches: # [WEBHOOK] To enable webhook, uncomment all the sections with [WEBHOOK] prefix. # patches here are for enabling the conversion webhook for each CRD -- patches/webhook_in_keplers.yaml +- path: patches/webhook_in_keplers.yaml #+kubebuilder:scaffold:crdkustomizewebhookpatch # [CERTMANAGER] To enable cert-manager, uncomment all the sections with [CERTMANAGER] prefix. # patches here are for enabling the CA injection for each CRD -#- patches/cainjection_in_keplers.yaml +#- path: patches/cainjection_in_keplers.yaml #+kubebuilder:scaffold:crdkustomizecainjectionpatch +# [WEBHOOK] To enable webhook, uncomment the following section # the following config is for teaching kustomize how to do kustomization for CRDs. + configurations: - kustomizeconfig.yaml diff --git a/config/crd/patches/cainjection_in_keplers.yaml b/config/crd/patches/cainjection_in_keplers.yaml index 43a013b5..cec037e1 100644 --- a/config/crd/patches/cainjection_in_keplers.yaml +++ b/config/crd/patches/cainjection_in_keplers.yaml @@ -3,5 +3,5 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - cert-manager.io/inject-ca-from: $(CERTIFICATE_NAMESPACE)/$(CERTIFICATE_NAME) + cert-manager.io/inject-ca-from: CERTIFICATE_NAMESPACE/CERTIFICATE_NAME name: keplers.kepler.system.sustainable.computing.io diff --git a/config/default/kustomization.yaml b/config/default/kustomization.yaml index fa298e61..886a355e 100644 --- a/config/default/kustomization.yaml +++ b/config/default/kustomization.yaml @@ -9,10 +9,12 @@ namespace: kepler-operator-system namePrefix: kepler-operator- # Labels to add to all resources and selectors. -#commonLabels: -# someName: someValue +#labels: +#- includeSelectors: true +# pairs: +# someName: someValue -bases: +resources: - ../crd - ../rbac - ../manager @@ -24,49 +26,117 @@ bases: # [PROMETHEUS] To enable prometheus monitor, uncomment all sections with 'PROMETHEUS'. - ../prometheus -patchesStrategicMerge: +patches: # Protect the /metrics endpoint by putting it behind auth. # If you want your controller-manager to expose the /metrics # endpoint w/o any authn/z, please comment the following line. -# - manager_auth_proxy_patch.yaml - - +# - path: manager_auth_proxy_patch.yaml # [WEBHOOK] To enable webhook, uncomment all the sections with [WEBHOOK] prefix including the one in # crd/kustomization.yaml -- manager_webhook_patch.yaml +- path: manager_webhook_patch.yaml # [CERTMANAGER] To enable cert-manager, uncomment all sections with 'CERTMANAGER'. # Uncomment 'CERTMANAGER' sections in crd/kustomization.yaml to enable the CA injection in the admission webhooks. # 'CERTMANAGER' needs to be enabled to use ca injection -#- webhookcainjection_patch.yaml +#- path: webhookcainjection_patch.yaml -# the following config is for teaching kustomize how to do var substitution -vars: # [CERTMANAGER] To enable cert-manager, uncomment all sections with 'CERTMANAGER' prefix. -#- name: CERTIFICATE_NAMESPACE # namespace of the certificate CR -# objref: -# kind: Certificate -# group: cert-manager.io -# version: v1 -# name: serving-cert # this name should match the one in certificate.yaml -# fieldref: -# fieldpath: metadata.namespace -#- name: CERTIFICATE_NAME -# objref: -# kind: Certificate -# group: cert-manager.io -# version: v1 -# name: serving-cert # this name should match the one in certificate.yaml -#- name: SERVICE_NAMESPACE # namespace of the service -# objref: -# kind: Service -# version: v1 -# name: webhook-service -# fieldref: -# fieldpath: metadata.namespace -#- name: SERVICE_NAME -# objref: -# kind: Service -# version: v1 -# name: webhook-service +# Uncomment the following replacements to add the cert-manager CA injection annotations +#replacements: +# - source: # Add cert-manager annotation to ValidatingWebhookConfiguration, MutatingWebhookConfiguration and CRDs +# kind: Certificate +# group: cert-manager.io +# version: v1 +# name: serving-cert # this name should match the one in certificate.yaml +# fieldPath: .metadata.namespace # namespace of the certificate CR +# targets: +# - select: +# kind: ValidatingWebhookConfiguration +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 0 +# create: true +# - select: +# kind: MutatingWebhookConfiguration +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 0 +# create: true +# - select: +# kind: CustomResourceDefinition +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 0 +# create: true +# - source: +# kind: Certificate +# group: cert-manager.io +# version: v1 +# name: serving-cert # this name should match the one in certificate.yaml +# fieldPath: .metadata.name +# targets: +# - select: +# kind: ValidatingWebhookConfiguration +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 1 +# create: true +# - select: +# kind: MutatingWebhookConfiguration +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 1 +# create: true +# - select: +# kind: CustomResourceDefinition +# fieldPaths: +# - .metadata.annotations.[cert-manager.io/inject-ca-from] +# options: +# delimiter: '/' +# index: 1 +# create: true +# - source: # Add cert-manager annotation to the webhook Service +# kind: Service +# version: v1 +# name: webhook-service +# fieldPath: .metadata.name # namespace of the service +# targets: +# - select: +# kind: Certificate +# group: cert-manager.io +# version: v1 +# fieldPaths: +# - .spec.dnsNames.0 +# - .spec.dnsNames.1 +# options: +# delimiter: '.' +# index: 0 +# create: true +# - source: +# kind: Service +# version: v1 +# name: webhook-service +# fieldPath: .metadata.namespace # namespace of the service +# targets: +# - select: +# kind: Certificate +# group: cert-manager.io +# version: v1 +# fieldPaths: +# - .spec.dnsNames.0 +# - .spec.dnsNames.1 +# options: +# delimiter: '.' +# index: 1 +# create: true diff --git a/config/default/manager_auth_proxy_patch.yaml b/config/default/manager_auth_proxy_patch.yaml index f07d69d9..a74efc72 100644 --- a/config/default/manager_auth_proxy_patch.yaml +++ b/config/default/manager_auth_proxy_patch.yaml @@ -30,8 +30,8 @@ spec: allowPrivilegeEscalation: false capabilities: drop: - - "ALL" - image: gcr.io/kubebuilder/kube-rbac-proxy:v0.13.0 + - "ALL" + image: gcr.io/kubebuilder/kube-rbac-proxy:v0.15.0 args: - "--secure-listen-address=0.0.0.0:8443" - "--upstream=http://127.0.0.1:8080/" diff --git a/config/default/manager_webhook_patch.yaml b/config/default/manager_webhook_patch.yaml index 1c378047..349289c3 100644 --- a/config/default/manager_webhook_patch.yaml +++ b/config/default/manager_webhook_patch.yaml @@ -16,10 +16,8 @@ spec: - mountPath: /tmp/k8s-webhook-server/serving-certs name: cert readOnly: true - # NOTE: this will be removed by the manager kustomization.yaml - # since OLM will add the volume - volumes: - - name: cert - secret: - defaultMode: 420 - secretName: webhook-server-cert + volumes: + - name: cert + secret: + defaultMode: 420 + secretName: webhook-server-cert diff --git a/config/default/webhookcainjection_patch.yaml b/config/default/webhookcainjection_patch.yaml index f992f958..6b105181 100644 --- a/config/default/webhookcainjection_patch.yaml +++ b/config/default/webhookcainjection_patch.yaml @@ -1,5 +1,5 @@ # This patch add annotation to admission webhook config and -# the variables $(CERTIFICATE_NAMESPACE) and $(CERTIFICATE_NAME) will be substituted by kustomize. +# CERTIFICATE_NAMESPACE and CERTIFICATE_NAME will be substituted by kustomize apiVersion: admissionregistration.k8s.io/v1 kind: MutatingWebhookConfiguration metadata: @@ -12,7 +12,7 @@ metadata: app.kubernetes.io/managed-by: kustomize name: mutating-webhook-configuration annotations: - cert-manager.io/inject-ca-from: $(CERTIFICATE_NAMESPACE)/$(CERTIFICATE_NAME) + cert-manager.io/inject-ca-from: CERTIFICATE_NAMESPACE/CERTIFICATE_NAME --- apiVersion: admissionregistration.k8s.io/v1 kind: ValidatingWebhookConfiguration @@ -26,4 +26,4 @@ metadata: app.kubernetes.io/managed-by: kustomize name: validating-webhook-configuration annotations: - cert-manager.io/inject-ca-from: $(CERTIFICATE_NAMESPACE)/$(CERTIFICATE_NAME) + cert-manager.io/inject-ca-from: CERTIFICATE_NAMESPACE/CERTIFICATE_NAME diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index 866f427e..5c5f0b84 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -1,8 +1,2 @@ resources: - manager.yaml -apiVersion: kustomize.config.k8s.io/v1beta1 -kind: Kustomization -images: -- name: controller - newName: quay.io/sustainable_computing_io/kepler-operator - newTag: "0.5.0" diff --git a/config/manifests/kustomization.yaml b/config/manifests/kustomization.yaml index 596609d1..ebd941b1 100644 --- a/config/manifests/kustomization.yaml +++ b/config/manifests/kustomization.yaml @@ -11,11 +11,11 @@ resources: # These patches remove the unnecessary "cert" volume and its manager container volumeMount. patchesJson6902: - target: - group: apps - version: v1 - kind: Deployment - name: controller-manager - namespace: system + group: apps + version: v1 + kind: Deployment + name: controller + namespace: system patch: |- # Remove the manager container's "cert" volumeMount, since OLM will create and mount a set of certs. # Update the indices in this path if adding or removing containers/volumeMounts in the manager's Deployment. diff --git a/config/prometheus/monitor.yaml b/config/prometheus/monitor.yaml index bdc624c5..56c1174f 100644 --- a/config/prometheus/monitor.yaml +++ b/config/prometheus/monitor.yaml @@ -1,4 +1,3 @@ - # Prometheus Monitor Service (Metrics) apiVersion: monitoring.coreos.com/v1 kind: ServiceMonitor @@ -19,3 +18,15 @@ spec: matchLabels: app.kubernetes.io/name: service app.kubernetes.io/part-of: kepler-operator + +# spec: +# endpoints: +# - path: /metrics +# port: https +# scheme: https +# bearerTokenFile: /var/run/secrets/kubernetes.io/serviceaccount/token +# tlsConfig: +# insecureSkipVerify: true +# selector: +# matchLabels: +# control-plane: controller-manager diff --git a/config/rbac/auth_proxy_service.yaml b/config/rbac/auth_proxy_service.yaml index ab7f7dc1..2ac0e256 100644 --- a/config/rbac/auth_proxy_service.yaml +++ b/config/rbac/auth_proxy_service.yaml @@ -19,3 +19,12 @@ spec: selector: app.kubernetes.io/instance: controller-manager app.kubernetes.io/component: manager + +# spec: +# ports: +# - name: https +# port: 8443 +# protocol: TCP +# targetPort: https +# selector: +# control-plane: controller-manager diff --git a/config/rbac/service_account.yaml b/config/rbac/service_account.yaml index 2a83c2ca..4a26793e 100644 --- a/config/rbac/service_account.yaml +++ b/config/rbac/service_account.yaml @@ -3,7 +3,7 @@ kind: ServiceAccount metadata: labels: app.kubernetes.io/name: serviceaccount - app.kubernetes.io/instance: controller-manager + app.kubernetes.io/instance: controller-manager-sa app.kubernetes.io/component: rbac app.kubernetes.io/created-by: kepler-operator app.kubernetes.io/part-of: kepler-operator diff --git a/config/scorecard/patches/basic.config.yaml b/config/scorecard/patches/basic.config.yaml index 35a0bc5a..893ebd2d 100644 --- a/config/scorecard/patches/basic.config.yaml +++ b/config/scorecard/patches/basic.config.yaml @@ -4,7 +4,7 @@ entrypoint: - scorecard-test - basic-check-spec - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: basic test: basic-check-spec-test diff --git a/config/scorecard/patches/olm.config.yaml b/config/scorecard/patches/olm.config.yaml index b1161bd8..6cf777b8 100644 --- a/config/scorecard/patches/olm.config.yaml +++ b/config/scorecard/patches/olm.config.yaml @@ -4,7 +4,7 @@ entrypoint: - scorecard-test - olm-bundle-validation - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-bundle-validation-test @@ -14,7 +14,7 @@ entrypoint: - scorecard-test - olm-crds-have-validation - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-crds-have-validation-test @@ -24,7 +24,7 @@ entrypoint: - scorecard-test - olm-crds-have-resources - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-crds-have-resources-test @@ -34,7 +34,7 @@ entrypoint: - scorecard-test - olm-spec-descriptors - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-spec-descriptors-test @@ -44,7 +44,7 @@ entrypoint: - scorecard-test - olm-status-descriptors - image: quay.io/operator-framework/scorecard-test:v1.25.1 + image: quay.io/operator-framework/scorecard-test:v1.35.0 labels: suite: olm test: olm-status-descriptors-test diff --git a/config/webhook/kustomizeconfig.yaml b/config/webhook/kustomizeconfig.yaml index 25e21e3c..206316e5 100644 --- a/config/webhook/kustomizeconfig.yaml +++ b/config/webhook/kustomizeconfig.yaml @@ -1,4 +1,4 @@ -# the following config is for teaching kustomize where to look at when substituting vars. +# the following config is for teaching kustomize where to look at when substituting nameReference. # It requires kustomize v2.1.0 or newer to work properly. nameReference: - kind: Service @@ -20,6 +20,3 @@ namespace: group: admissionregistration.k8s.io path: webhooks/clientConfig/service/namespace create: true - -varReference: -- path: metadata/annotations diff --git a/hack/boilerplate.go.txt b/hack/boilerplate.go.txt index 6975adbe..ff72ff2a 100644 --- a/hack/boilerplate.go.txt +++ b/hack/boilerplate.go.txt @@ -1,5 +1,5 @@ /* -Copyright 2023. +Copyright 2024. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. @@ -12,4 +12,4 @@ distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. -*/ +*/ \ No newline at end of file diff --git a/hack/bundle.sh b/hack/bundle.sh index 829ea390..41a7a3c1 100755 --- a/hack/bundle.sh +++ b/hack/bundle.sh @@ -58,7 +58,7 @@ main() { info "Found old version: $old_bundle_version" info "Building bundle version $VERSION" - run operator-sdk generate kustomize manifests --apis-dir=./pkg/api --verbose + run operator-sdk generate kustomize manifests --verbose local gen_opts=() read -r -a gen_opts <<<"$BUNDLE_GEN_FLAGS" diff --git a/hack/tools.sh b/hack/tools.sh index 5b5ccbc8..bfcaffd8 100755 --- a/hack/tools.sh +++ b/hack/tools.sh @@ -29,8 +29,8 @@ declare -r LOCAL_BIN="$PROJECT_ROOT/tmp/bin" # versions declare -r KUSTOMIZE_VERSION=${KUSTOMIZE_VERSION:-v3.8.7} -declare -r CONTROLLER_TOOLS_VERSION=${CONTROLLER_TOOLS_VERSION:-v0.12.1} -declare -r OPERATOR_SDK_VERSION=${OPERATOR_SDK_VERSION:-v1.27.0} +declare -r CONTROLLER_TOOLS_VERSION=${CONTROLLER_TOOLS_VERSION:-v0.13.0} +declare -r OPERATOR_SDK_VERSION=${OPERATOR_SDK_VERSION:-v1.35.0} declare -r YQ_VERSION=${YQ_VERSION:-v4.34.2} declare -r CRDOC_VERSION=${CRDOC_VERSION:-v0.6.2} declare -r OC_VERSION=${OC_VERSION:-4.13.0} diff --git a/pkg/controllers/config.go b/internal/controller/config.go similarity index 97% rename from pkg/controllers/config.go rename to internal/controller/config.go index 04c1d20f..3f52de02 100644 --- a/pkg/controllers/config.go +++ b/internal/controller/config.go @@ -13,7 +13,7 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ -package controllers +package controller import "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" diff --git a/pkg/controllers/kepler.go b/internal/controller/kepler.go similarity index 98% rename from pkg/controllers/kepler.go rename to internal/controller/kepler.go index ee2a46a2..2884b7da 100644 --- a/pkg/controllers/kepler.go +++ b/internal/controller/kepler.go @@ -1,4 +1,4 @@ -package controllers +package controller import ( "context" @@ -9,7 +9,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" "github.com/sustainable.computing.io/kepler-operator/pkg/reconciler" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" @@ -27,9 +27,7 @@ const ( Finalizer = "kepler.system.sustainable.computing.io/finalizer" ) -var ( - KeplerDeploymentNS = "kepler-operator" -) +var KeplerDeploymentNS = "kepler-operator" // KeplerReconciler reconciles a Kepler object type KeplerReconciler struct { @@ -102,7 +100,6 @@ func (r *KeplerReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctr } func (r KeplerReconciler) runKeplerReconcilers(ctx context.Context, kepler *v1alpha1.Kepler) (ctrl.Result, error) { - reconcilers := r.reconcilersForKepler(kepler) r.logger.V(6).Info("renconcilers ...", "count", len(reconcilers)) @@ -116,7 +113,6 @@ func (r KeplerReconciler) runKeplerReconcilers(ctx context.Context, kepler *v1al func (r KeplerReconciler) updateStatus(ctx context.Context, req ctrl.Request, recErr error) error { return retry.RetryOnConflict(retry.DefaultBackoff, func() error { - k, _ := r.getKepler(ctx, req) // may be deleted if k == nil || !k.GetDeletionTimestamp().IsZero() { @@ -212,7 +208,6 @@ func (r KeplerReconciler) reconcilersForKepler(k *v1alpha1.Kepler) []reconciler. } func (r KeplerReconciler) setInvalidStatus(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - err := retry.RetryOnConflict(retry.DefaultBackoff, func() error { invalidKepler, _ := r.getKepler(ctx, req) // may be deleted @@ -244,7 +239,6 @@ func (r KeplerReconciler) setInvalidStatus(ctx context.Context, req ctrl.Request } func newKeplerInternal(d components.Detail, k *v1alpha1.Kepler) *v1alpha1.KeplerInternal { - if d == components.Metadata { return &v1alpha1.KeplerInternal{ TypeMeta: metav1.TypeMeta{ diff --git a/pkg/controllers/kepler_internal.go b/internal/controller/kepler_internal.go similarity index 99% rename from pkg/controllers/kepler_internal.go rename to internal/controller/kepler_internal.go index 75810858..0942bd55 100644 --- a/pkg/controllers/kepler_internal.go +++ b/internal/controller/kepler_internal.go @@ -1,4 +1,4 @@ -package controllers +package controller import ( "context" @@ -13,7 +13,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/predicate" "sigs.k8s.io/controller-runtime/pkg/reconcile" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" "github.com/sustainable.computing.io/kepler-operator/pkg/components/exporter" "github.com/sustainable.computing.io/kepler-operator/pkg/components/modelserver" @@ -58,7 +58,6 @@ type KeplerInternalReconciler struct { // SetupWithManager sets up the controller with the Manager. func (r *KeplerInternalReconciler) SetupWithManager(mgr ctrl.Manager) error { - // We only want to trigger a reconciliation when the generation // of a child changes. Until we need to update our the status for our own objects, // we can save CPU cycles by avoiding reconciliations triggered by @@ -90,7 +89,6 @@ func (r *KeplerInternalReconciler) SetupWithManager(mgr ctrl.Manager) error { // mapSecretToRequests returns the reconcile requests for kepler-internal objects for which an associated redfish secret has been changed. func (r *KeplerInternalReconciler) mapSecretToRequests(ctx context.Context, object client.Object) []reconcile.Request { - secret, ok := object.(*corev1.Secret) if !ok { return nil @@ -160,7 +158,6 @@ func (r *KeplerInternalReconciler) Reconcile(ctx context.Context, req ctrl.Reque } func (r KeplerInternalReconciler) runReconcilers(ctx context.Context, ki *v1alpha1.KeplerInternal) (ctrl.Result, error) { - reconcilers := r.reconcilersForInternal(ki) r.logger.V(6).Info("reconcilers ...", "count", len(reconcilers)) @@ -194,7 +191,6 @@ func (r KeplerInternalReconciler) updateStatus(ctx context.Context, req ctrl.Req defer logger.V(3).Info("End of status update") return retry.RetryOnConflict(retry.DefaultBackoff, func() error { - ki, _ := r.getInternal(ctx, req) // may be deleted if ki == nil || !ki.GetDeletionTimestamp().IsZero() { @@ -219,7 +215,6 @@ func (r KeplerInternalReconciler) updateStatus(ctx context.Context, req ctrl.Req } return r.Client.Status().Update(ctx, ki) - }) } @@ -259,7 +254,6 @@ func sanitizeConditions(conditions []v1alpha1.Condition) []v1alpha1.Condition { } func (r KeplerInternalReconciler) updateReconciledStatus(ctx context.Context, ki *v1alpha1.KeplerInternal, recErr error, time metav1.Time) bool { - reconciled := v1alpha1.Condition{ Type: v1alpha1.Reconciled, Status: v1alpha1.ConditionTrue, @@ -288,7 +282,6 @@ func findCondition(conditions []v1alpha1.Condition, t v1alpha1.ConditionType) *v // returns true if the condition has been updated func updateCondition(conditions []v1alpha1.Condition, latest v1alpha1.Condition, time metav1.Time) bool { - old := findCondition(conditions, latest.Type) if old == nil { panic("old condition not found; this should never happen after sanitizeConditions") @@ -386,7 +379,6 @@ func availableConditionForGetError(err error) v1alpha1.Condition { Reason: v1alpha1.DaemonSetError, Message: err.Error(), } - } func availableCondition(dset *appsv1.DaemonSet) v1alpha1.Condition { @@ -514,7 +506,6 @@ func (r KeplerInternalReconciler) reconcilersForInternal(ki *v1alpha1.KeplerInte } func exporterReconcilers(ki *v1alpha1.KeplerInternal, cluster k8s.Cluster) []reconciler.Reconciler { - if cleanup := !ki.DeletionTimestamp.IsZero(); cleanup { rs := resourceReconcilers( deleteResource, @@ -564,7 +555,6 @@ func exporterReconcilers(ki *v1alpha1.KeplerInternal, cluster k8s.Cluster) []rec } func openshiftClusterResources(ki *v1alpha1.KeplerInternal, cluster k8s.Cluster) []client.Object { - oshift := ki.Spec.OpenShift if cluster != k8s.OpenShift || !oshift.Enabled { return nil @@ -618,5 +608,4 @@ func updatersForInternalResources(ki *v1alpha1.KeplerInternal, resources ...clie rs = append(rs, resourceUpdater(res)) } return rs - } diff --git a/pkg/controllers/reconcilers.go b/internal/controller/reconcilers.go similarity index 98% rename from pkg/controllers/reconcilers.go rename to internal/controller/reconcilers.go index 6ab02336..73a46feb 100644 --- a/pkg/controllers/reconcilers.go +++ b/internal/controller/reconcilers.go @@ -13,7 +13,7 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ -package controllers +package controller import ( metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" diff --git a/pkg/components/estimator/estimator.go b/pkg/components/estimator/estimator.go index 737fd7de..a03e084b 100644 --- a/pkg/components/estimator/estimator.go +++ b/pkg/components/estimator/estimator.go @@ -20,7 +20,7 @@ import ( "fmt" "strings" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" corev1 "k8s.io/api/core/v1" diff --git a/pkg/components/estimator/estimator_test.go b/pkg/components/estimator/estimator_test.go index bb95c3b0..0dbb1c7b 100644 --- a/pkg/components/estimator/estimator_test.go +++ b/pkg/components/estimator/estimator_test.go @@ -20,7 +20,7 @@ import ( "testing" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" corev1 "k8s.io/api/core/v1" ) diff --git a/pkg/components/exporter/exporter.go b/pkg/components/exporter/exporter.go index 628cb219..df458987 100644 --- a/pkg/components/exporter/exporter.go +++ b/pkg/components/exporter/exporter.go @@ -22,7 +22,7 @@ import ( "regexp" "strconv" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" "github.com/sustainable.computing.io/kepler-operator/pkg/components/estimator" "github.com/sustainable.computing.io/kepler-operator/pkg/components/modelserver" diff --git a/pkg/components/exporter/exporter_test.go b/pkg/components/exporter/exporter_test.go index ed7fae2d..51427b60 100644 --- a/pkg/components/exporter/exporter_test.go +++ b/pkg/components/exporter/exporter_test.go @@ -4,7 +4,7 @@ import ( "testing" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" corev1 "k8s.io/api/core/v1" diff --git a/pkg/components/modelserver/modelserver.go b/pkg/components/modelserver/modelserver.go index a8086fe2..07cecb5f 100644 --- a/pkg/components/modelserver/modelserver.go +++ b/pkg/components/modelserver/modelserver.go @@ -19,7 +19,7 @@ package modelserver import ( "fmt" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" diff --git a/pkg/components/modelserver/modelserver_test.go b/pkg/components/modelserver/modelserver_test.go index b276a499..eb0b3993 100644 --- a/pkg/components/modelserver/modelserver_test.go +++ b/pkg/components/modelserver/modelserver_test.go @@ -20,7 +20,7 @@ import ( "testing" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components" ) diff --git a/pkg/reconciler/kepler.go b/pkg/reconciler/kepler.go index 99430d72..7e012809 100644 --- a/pkg/reconciler/kepler.go +++ b/pkg/reconciler/kepler.go @@ -23,7 +23,7 @@ import ( "strconv" "github.com/cespare/xxhash/v2" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/components/exporter" appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" diff --git a/pkg/utils/k8s/k8s.go b/pkg/utils/k8s/k8s.go index 96e7d5d1..e93fb85f 100644 --- a/pkg/utils/k8s/k8s.go +++ b/pkg/utils/k8s/k8s.go @@ -20,7 +20,7 @@ import ( "fmt" secv1 "github.com/openshift/api/security/v1" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" "k8s.io/utils/pointer" diff --git a/pkg/utils/test/assertions.go b/pkg/utils/test/assertions.go index cabbd748..61604a8c 100644 --- a/pkg/utils/test/assertions.go +++ b/pkg/utils/test/assertions.go @@ -21,7 +21,7 @@ import ( "time" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" "sigs.k8s.io/controller-runtime/pkg/client" diff --git a/pkg/utils/test/framework.go b/pkg/utils/test/framework.go index 6c5aa3cf..44918631 100644 --- a/pkg/utils/test/framework.go +++ b/pkg/utils/test/framework.go @@ -27,7 +27,7 @@ import ( "golang.org/x/exp/slices" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/test/oc" ctrl "sigs.k8s.io/controller-runtime" diff --git a/pkg/utils/test/kepler_internal_builder.go b/pkg/utils/test/kepler_internal_builder.go index c1883568..6c72ffbf 100644 --- a/pkg/utils/test/kepler_internal_builder.go +++ b/pkg/utils/test/kepler_internal_builder.go @@ -17,7 +17,7 @@ limitations under the License. package test import ( - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" ) diff --git a/tests/Dockerfile b/tests/Dockerfile index d4de77b5..d7346f6f 100644 --- a/tests/Dockerfile +++ b/tests/Dockerfile @@ -11,12 +11,14 @@ RUN go mod download # Install kubectl and oc RUN curl -L -o oc.tar.gz https://mirror.openshift.com/pub/openshift-v4/x86_64/clients/ocp/latest/openshift-client-linux.tar.gz \ - && tar -xvzf oc.tar.gz \ - && chmod +x kubectl oc \ - && mv oc kubectl /usr/local/bin/ + && tar -xvzf oc.tar.gz \ + && chmod +x kubectl oc \ + && mv oc kubectl /usr/local/bin/ # Copy the go source COPY pkg/ pkg/ +COPY api/ api/ +COPY internal/ internal/ COPY tests/ tests/ # Compile test into e2e.test binary diff --git a/tests/e2e/kepler_internal_test.go b/tests/e2e/kepler_internal_test.go index c8cad968..e13ced3c 100644 --- a/tests/e2e/kepler_internal_test.go +++ b/tests/e2e/kepler_internal_test.go @@ -22,9 +22,9 @@ import ( "time" "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/internal/controller" "github.com/sustainable.computing.io/kepler-operator/pkg/components/exporter" - "github.com/sustainable.computing.io/kepler-operator/pkg/controllers" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/test" appsv1 "k8s.io/api/apps/v1" @@ -43,7 +43,7 @@ func TestKeplerInternal_Reconciliation(t *testing.T) { name := "e2e-ki" // test namespace must be the deployment namespace for controller // to watch the deployments / daemonsets etc - testNs := controllers.KeplerDeploymentNS + testNs := controller.KeplerDeploymentNS // pre-condition f.AssertNoResourceExists(name, "", &v1alpha1.KeplerInternal{}, test.NoWait()) @@ -76,7 +76,7 @@ func TestKeplerInternal_ReconciliationWithRedfish(t *testing.T) { secretName := "my-redfish-secret" // test namespace must be the deployment namespace for controller // to watch the deployments / daemonsets etc - testNs := controllers.KeplerDeploymentNS + testNs := controller.KeplerDeploymentNS // pre-condition f.AssertNoResourceExists(name, "", &v1alpha1.KeplerInternal{}, test.NoWait()) @@ -107,7 +107,7 @@ func TestKeplerInternal_ReconciliationWithRedfish(t *testing.T) { redfishSecret := corev1.Secret{ ObjectMeta: metav1.ObjectMeta{ Name: secretName, - Namespace: controllers.KeplerDeploymentNS, + Namespace: controller.KeplerDeploymentNS, }, Data: map[string][]byte{ "redfish.csv": []byte("dummy"), @@ -143,7 +143,7 @@ func TestKeplerInternal_ReconciliationWithRedfish(t *testing.T) { ds = appsv1.DaemonSet{} f.WaitUntil("Daemonset to restart", func() (bool, error) { err := f.Client().Get(context.TODO(), - client.ObjectKey{Namespace: controllers.KeplerDeploymentNS, Name: ki.Name}, &ds) + client.ObjectKey{Namespace: controller.KeplerDeploymentNS, Name: ki.Name}, &ds) if errors.IsNotFound(err) { return false, nil } else if err != nil { @@ -164,7 +164,7 @@ func TestKeplerInternal_WithEstimator(t *testing.T) { // test namespace must be the deployment namespace for controller // to watch the deployments / daemonsets etc - testNs := controllers.KeplerDeploymentNS + testNs := controller.KeplerDeploymentNS // pre-condition f.AssertNoResourceExists(name, "", &v1alpha1.KeplerInternal{}, test.NoWait()) @@ -197,7 +197,7 @@ func TestKeplerInternal_WithModelServer(t *testing.T) { // test namespace must be the deployment namespace for controller // to watch the deployments / daemonsets etc - testNs := controllers.KeplerDeploymentNS + testNs := controller.KeplerDeploymentNS // pre-condition f.AssertNoResourceExists(name, "", &v1alpha1.KeplerInternal{}, test.NoWait()) @@ -235,7 +235,7 @@ func TestKeplerInternal_WithEstimatorAndModelServer(t *testing.T) { // test namespace must be the deployment namespace for controller // to watch the deployments / daemonsets etc - testNs := controllers.KeplerDeploymentNS + testNs := controller.KeplerDeploymentNS // pre-condition f.AssertNoResourceExists(name, "", &v1alpha1.KeplerInternal{}, test.NoWait()) diff --git a/tests/e2e/kepler_test.go b/tests/e2e/kepler_test.go index 168647cc..561c9e13 100644 --- a/tests/e2e/kepler_test.go +++ b/tests/e2e/kepler_test.go @@ -6,9 +6,9 @@ import ( "github.com/stretchr/testify/assert" - "github.com/sustainable.computing.io/kepler-operator/pkg/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/api/v1alpha1" + "github.com/sustainable.computing.io/kepler-operator/internal/controller" "github.com/sustainable.computing.io/kepler-operator/pkg/components" - "github.com/sustainable.computing.io/kepler-operator/pkg/controllers" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/test" appsv1 "k8s.io/api/apps/v1" @@ -26,14 +26,14 @@ func TestKepler_Deletion(t *testing.T) { ds := appsv1.DaemonSet{} f.AssertResourceExists( k.Name, - controllers.KeplerDeploymentNS, + controller.KeplerDeploymentNS, &ds, test.Timeout(10*time.Second), ) f.DeleteKepler("kepler") - ns := components.NewNamespace(controllers.KeplerDeploymentNS) + ns := components.NewNamespace(controller.KeplerDeploymentNS) f.AssertNoResourceExists(ns.Name, "", ns) f.AssertNoResourceExists(ds.Name, ds.Namespace, &ds) } @@ -48,9 +48,9 @@ func TestKepler_Reconciliation(t *testing.T) { k := f.CreateKepler("kepler") // then - f.AssertResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) ds := appsv1.DaemonSet{} - f.AssertResourceExists(k.Name, controllers.KeplerDeploymentNS, &ds) + f.AssertResourceExists(k.Name, controller.KeplerDeploymentNS, &ds) kepler := f.WaitUntilKeplerCondition("kepler", v1alpha1.Reconciled, v1alpha1.ConditionTrue) // ensure the default toleration is set @@ -93,16 +93,16 @@ func TestNodeSelector(t *testing.T) { k := f.CreateKepler("kepler", f.WithNodeSelector(labels)) - f.AssertResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) ds := appsv1.DaemonSet{} - f.AssertResourceExists(k.Name, controllers.KeplerDeploymentNS, &ds) + f.AssertResourceExists(k.Name, controller.KeplerDeploymentNS, &ds) kepler := f.WaitUntilKeplerCondition("kepler", v1alpha1.Available, v1alpha1.ConditionTrue) assert.EqualValues(t, 1, kepler.Status.Exporter.NumberAvailable) f.DeleteKepler("kepler") - f.AssertNoResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertNoResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) f.AssertNoResourceExists(ds.Name, ds.Namespace, &ds) } @@ -118,21 +118,20 @@ func TestNodeSelectorUnavailableLabel(t *testing.T) { k := f.CreateKepler("kepler", f.WithNodeSelector(unavailableLabels)) - f.AssertResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) ds := appsv1.DaemonSet{} - f.AssertResourceExists(k.Name, controllers.KeplerDeploymentNS, &ds) + f.AssertResourceExists(k.Name, controller.KeplerDeploymentNS, &ds) kepler := f.WaitUntilKeplerCondition("kepler", v1alpha1.Available, v1alpha1.ConditionFalse) assert.EqualValues(t, 0, kepler.Status.Exporter.NumberAvailable) f.DeleteKepler("kepler") - f.AssertNoResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertNoResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) f.AssertNoResourceExists(ds.Name, ds.Namespace, &ds) } func TestTaint_WithToleration(t *testing.T) { - f := test.NewFramework(t) // Ensure Kepler is not deployed (by any chance) f.AssertNoResourceExists("kepler", "", &v1alpha1.Kepler{}, test.Timeout(10*time.Second)) @@ -152,21 +151,20 @@ func TestTaint_WithToleration(t *testing.T) { assert.NoError(t, err, "failed to taint node %s", node) k := f.CreateKepler("kepler", f.WithTolerations(append(node.Spec.Taints, e2eTestTaint))) - f.AssertResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) ds := appsv1.DaemonSet{} - f.AssertResourceExists(k.Name, controllers.KeplerDeploymentNS, &ds) + f.AssertResourceExists(k.Name, controller.KeplerDeploymentNS, &ds) kepler := f.WaitUntilKeplerCondition("kepler", v1alpha1.Available, v1alpha1.ConditionTrue) assert.EqualValues(t, len(nodes), kepler.Status.Exporter.NumberAvailable) f.DeleteKepler("kepler") - f.AssertNoResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertNoResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) f.AssertNoResourceExists(ds.Name, ds.Namespace, &ds) } func TestBadTaint_WithToleration(t *testing.T) { - f := test.NewFramework(t) // Ensure Kepler is not deployed (by any chance) f.AssertNoResourceExists("kepler", "", &v1alpha1.Kepler{}, test.Timeout(10*time.Second)) @@ -190,16 +188,15 @@ func TestBadTaint_WithToleration(t *testing.T) { k := f.CreateKepler("kepler", f.WithTolerations(append(node.Spec.Taints, badTestTaint))) - f.AssertResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) ds := appsv1.DaemonSet{} - f.AssertResourceExists(k.Name, controllers.KeplerDeploymentNS, &ds) + f.AssertResourceExists(k.Name, controller.KeplerDeploymentNS, &ds) kepler := f.WaitUntilKeplerCondition("kepler", v1alpha1.Available, v1alpha1.ConditionTrue) assert.EqualValues(t, len(nodes)-1, kepler.Status.Exporter.NumberAvailable) f.DeleteKepler("kepler") - f.AssertNoResourceExists(controllers.KeplerDeploymentNS, "", &corev1.Namespace{}) + f.AssertNoResourceExists(controller.KeplerDeploymentNS, "", &corev1.Namespace{}) f.AssertNoResourceExists(ds.Name, ds.Namespace, &ds) - } diff --git a/tests/e2e/main_test.go b/tests/e2e/main_test.go index 1ace9490..bc277b24 100644 --- a/tests/e2e/main_test.go +++ b/tests/e2e/main_test.go @@ -21,17 +21,15 @@ import ( "os" "testing" - "github.com/sustainable.computing.io/kepler-operator/pkg/controllers" + "github.com/sustainable.computing.io/kepler-operator/internal/controller" "github.com/sustainable.computing.io/kepler-operator/pkg/utils/k8s" ) -var ( - Cluster k8s.Cluster = k8s.Kubernetes -) +var Cluster k8s.Cluster = k8s.Kubernetes func TestMain(m *testing.M) { openshift := flag.Bool("openshift", true, "Indicate if tests are run aginast an OpenShift cluster.") - flag.StringVar(&controllers.KeplerDeploymentNS, "deployment-namespace", controllers.KeplerDeploymentNS, + flag.StringVar(&controller.KeplerDeploymentNS, "deployment-namespace", controller.KeplerDeploymentNS, "Namespace where kepler and its components are deployed.") flag.Parse()