From 35808e0e4d828abd3379e4133e84abac8576ec21 Mon Sep 17 00:00:00 2001 From: Varsha Prasad Narsing Date: Mon, 22 Jan 2024 15:17:10 -0500 Subject: [PATCH] :sparkles: Cleanups after removing BundleAPI This PR makes the follwing changes: 1. Fixes the reference to v1alpha1 APIs in the linter. 2. TypeHasValidBundle was being set to false only when the bundle load errored. Switching the condition to be TypeInstalled instead. 3. Fix documentation on provisioners. Signed-off-by: Varsha Prasad Narsing --- .golangci.yaml | 4 +- api/v1alpha2/bundledeployment_types.go | 5 +- docs/provisioners/helm.md | 151 ++++++------------ docs/provisioners/plain.md | 116 +++----------- docs/provisioners/registry.md | 128 ++++----------- .../bundledeployment/bundledeployment.go | 2 +- 6 files changed, 112 insertions(+), 294 deletions(-) diff --git a/.golangci.yaml b/.golangci.yaml index 354eb970..488e676e 100644 --- a/.golangci.yaml +++ b/.golangci.yaml @@ -42,8 +42,8 @@ linters-settings: alias: $1$2 - pkg: sigs.k8s.io/controller-runtime alias: ctrl - - pkg: github.com/operator-framework/rukpak/api/v1alpha1 - alias: rukpakv1alpha1 + - pkg: github.com/operator-framework/rukpak/api/v1alpha2 + alias: rukpakv1alpha2 goimports: local-prefixes: github.com/operator-framework/rukpak diff --git a/api/v1alpha2/bundledeployment_types.go b/api/v1alpha2/bundledeployment_types.go index 2e44be59..ab1395e8 100644 --- a/api/v1alpha2/bundledeployment_types.go +++ b/api/v1alpha2/bundledeployment_types.go @@ -27,9 +27,8 @@ var ( ) const ( - TypeHasValidBundle = "HasValidBundle" - TypeHealthy = "Healthy" - TypeInstalled = "Installed" + TypeHealthy = "Healthy" + TypeInstalled = "Installed" ReasonBundleLoadFailed = "BundleLoadFailed" ReasonCreateDynamicWatchFailed = "CreateDynamicWatchFailed" diff --git a/docs/provisioners/helm.md b/docs/provisioners/helm.md index 6ed20d00..a9787be2 100644 --- a/docs/provisioners/helm.md +++ b/docs/provisioners/helm.md @@ -3,7 +3,7 @@ ## Summary The `helm` provisioner is one of the [provisioners](https://github.com/operator-framework/rukpak/tree/main/internal/provisioner) of RukPak. -It is able to instantiate a given `helm+v3` bundle with a specified helm chart onto a cluster where it then installs the content. It does so by reconciling `Bundle` and `BundleDeployment` types that have +It is able to instantiate a given `helm+v3` bundle with a specified helm chart onto a cluster where it then installs the content. It does so by reconciling `BundleDeployment` types that have the `spec.provisionerClassName` field set to `core-rukpak-io-helm`. This field must be set to the correct provisioner name in order for the `helm` provisioner to see and interact with the bundle. @@ -25,7 +25,7 @@ all present the same content, a directory containing a helm chart, in a differen The `helm` provisioner can install and make available a specific `helm+v3` bundle in the cluster. To do this, the `helm` provisioner will retrieve the configured helm chart, instantiate a Bundle onto the cluster, and eventually install the desired helm chart on the cluster. ```yaml -apiVersion: core.rukpak.io/v1alpha1 +apiVersion: core.rukpak.io/v1alpha2 kind: BundleDeployment metadata: name: my-ahoy @@ -55,44 +55,23 @@ spec: service: type: ClusterIP port: 80 - template: - metadata: - labels: - app: my-ahoy - spec: - provisionerClassName: core-rukpak-io-helm - source: - http: - url: https://github.com/helm/examples/releases/download/hello-world-0.1.0/hello-world-0.1.0.tgz - type: http + source: + http: + url: https://github.com/helm/examples/releases/download/hello-world-0.1.0/hello-world-0.1.0.tgz + type: http ``` For the helm chart, the values file embedded in the `config` can be applied during the installation of the chart. -> Note: the generated Bundle will contain the BundleDeployment's metadata.Name as a prefix, followed by -> the hash of the provided template. - -As the bundle content is retrieved and stored onto the cluster via the defined storage mechanism, the bundle status -will be updated to Unpacked, indicating that all its contents have been stored on-cluster. - -```console -$ kubectl get bundle -l app=my-ahoy -NAME TYPE PHASE AGE -my-ahoy-5764594dc8 http Unpacked 33s -``` - -Now that the bundle has been unpacked, the provisioner is able to create the resources in the bundle on the cluster. -These resources will be owned by the corresponding BundleDeployment. Creating the BundleDeployment on-cluster results in an -InstallationSucceeded Phase if the application of resources to the cluster was successful. +As the bundle content is retrieved and stored onto the cluster via the defined storage mechanism, the bundledeployment's `Install State` moves from `UnpackSuccessful` to `InstallationSucceeded`. +The install succeeded state indicates that the provisioner has created the resources in the bundle on the cluster. These resources will be owned by the corresponding BundleDeployment. ```console $ kubectl get bundledeployment my-ahoy -NAME ACTIVE BUNDLE INSTALL STATE AGE -my-ahoy my-ahoy-5764594dc8 InstallationSucceeded 48s +NAME INSTALL STATE AGE +my-ahoy InstallationSucceeded 48s ``` -> Note: Creation of more than one BundleDeployment from the same Bundle will likely result in an error. - ## Quick Start ### Setup @@ -127,33 +106,27 @@ make run ### Installing the sample chart -From there, create some Bundles and BundleDeployment types to see the provisioner in action. For an example helm chart to +From there, create some BundleDeployment types to see the provisioner in action. For an example helm chart to use, the [helm/examples](https://github.com/helm/examples) is a good example. Create the sample BundleDeployment referencing the desired sample helm chart in Bundle configuration: ```bash kubectl apply -f -< Note: the generated Bundle will contain the BundleDeployment's metadata.Name as a prefix, followed by -> the hash of the provided template. - -First, the Bundle will be in the Pending stage as the provisioner sees it and begins unpacking the referenced content: - -```console -$ kubectl get bundle my-bundle -NAME TYPE PHASE AGE -my-bundle image Pending 3s -``` - -Then eventually, as the bundle content is unpacked onto the cluster via the defined storage mechanism, the bundle status -will be updated to Unpacked, indicating that all its contents have been stored on-cluster. - -```console -$ kubectl get bundle my-bundle -NAME TYPE PHASE AGE -my-bundle image Unpacked 10s + source: + type: image + image: + ref: my-bundle@sha256:xyz123 + provisionerClassName: core-rukpak-io-plain ``` -Now that the bundle has been unpacked, the provisioner is able to create the resources in the bundle on the cluster. -These resources will be owned by the corresponding BundleDeployment. Creating the BundleDeployment on-cluster results in an -InstallationSucceeded Phase if the application of resources to the cluster was successful. +As the bundle content is retrieved and stored onto the cluster via the defined storage mechanism, the bundledeployment's `Install State` moves from `UnpackSuccessful` to `InstallationSucceeded`. +The install succeeded state indicates that the provisioner has created the resources in the bundle on the cluster. These resources will be owned by the corresponding BundleDeployment. ```console $ kubectl get bundledeployment my-bundle-deployment -NAME ACTIVE BUNDLE INSTALL STATE AGE -my-bundle-deployment my-bundle InstallationSucceeded 11s +NAME INSTALL STATE AGE +my-bundle-deployment InstallationSucceeded 11s ``` -> Note: Creation of more than one BundleDeployment from the same Bundle will likely result in an error. - ## Running locally ### Setup @@ -106,29 +78,23 @@ make run ### Installing the Combo Operator -From there, create some Bundles and BundleDeployment types to see the provisioner in action. For an example bundle to +From there, create some BundleDeployment types to see the provisioner in action. For an example bundle to use, the [combo operator](https://github.com/operator-framework/combo) is a good candidate. Create the combo BundleDeployment referencing the desired combo Bundle configuration: ```bash kubectl apply -f -< Note: Upgrading a BundleDeployment involves updating the desired Bundle template being referenced. - Update the existing `combo` BundleDeployment resource and update the container image being referenced: ```bash kubectl apply -f -< Note: Not all `registry+v1` content is supported. This mainly applies to `registry+v1` bundles that enable `AllNamespaces` mode -or include a webhook. - ## Use cases ### Install and apply a specific version of a `registry+v1` bundle @@ -29,60 +25,31 @@ or include a webhook. The `registry` provisioner can convert and make available a specific `registry+v1` bundle as a `plain+v0` in the cluster. Simply create a `BundleDeployment` resource that contains the desired specification of a Bundle resource. -The `registry` provisioner will unpack the provided Bundle onto the cluster, and the `plain` provisioner +The `registry` provisioner will unpack the provided BundleDeployment onto the cluster, and the `plain` provisioner will eventually make the content available on the cluster. ```yaml -apiVersion: core.rukpak.io/v1alpha1 +apiVersion: core.rukpak.io/v1alpha2 kind: BundleDeployment metadata: name: my-bundle-deployment spec: - provisionerClassName: core-rukpak-io-plain - template: - metadata: - labels: - app: my-bundle - spec: - source: - type: image - image: - ref: my-bundle@sha256:xyz123 - provisionerClassName: core-rukpak-io-registry -``` - -> Note: The generated Bundle will contain the BundleDeployment's metadata.Name as a prefix, followed by -> the hash of the provided template. - -First, the Bundle will be in the Pending stage as the provisioner sees it and begins unpacking the referenced content: - -```console -$ kubectl get bundle my-bundle -NAME TYPE PHASE AGE -my-bundle image Pending 3s + source: + type: image + image: + ref: my-bundle@sha256:xyz123 + provisionerClassName: core-rukpak-io-registry ``` -Then eventually, as the bundle content is unpacked onto the cluster via the defined storage mechanism, the bundle status -will be updated to Unpacked, indicating that all its contents have been stored on-cluster. - -```console -$ kubectl get bundle my-bundle -NAME TYPE PHASE AGE -my-bundle image Unpacked 10s -``` - -Now that the bundle has been unpacked, the provisioner is able to create the resources in the bundle on the cluster. -These resources will be owned by the corresponding BundleDeployment. Creating the BundleDeployment on-cluster results in an -InstallationSucceeded Phase if the application of resources to the cluster was successful. +As the bundle content is retrieved and stored onto the cluster via the defined storage mechanism, the bundledeployment's `Install State` moves from `UnpackSuccessful` to `InstallationSucceeded`. +The install succeeded state indicates that the provisioner has created the resources in the bundle on the cluster. These resources will be owned by the corresponding BundleDeployment. ```console $ kubectl get bundledeployment my-bundle-deployment -NAME ACTIVE BUNDLE INSTALL STATE AGE -my-bundle-deployment my-bundle InstallationSucceeded 11s +NAME INSTALL STATE AGE +my-bundle-deployment InstallationSucceeded 11s ``` -> Note: Creation of more than one BundleDeployment from the same Bundle will likely result in an error. - ## Running locally ### Setup @@ -110,22 +77,16 @@ Create the `prometheus` BundleDeployment referencing the desired `prometheus` Bu ```bash kubectl apply -f -< Note: Upgrading a BundleDeployment involves updating the desired Bundle template being referenced. - Update the existing `prometheus` BundleDeployment resource and update the container image being referenced: ```bash kubectl apply -f -< Note: There's no need to manually clean up the Bundles that were generated from a BundleDeployment resource. The plain provisioner places owner references on any Bundle that's generated from an individual BundleDeployment resource. +> Note: There's no need to manually clean up the resources that were generated from a BundleDeployment. The provisioner places owner references on any Bundle that's generated from an individual BundleDeployment resource. ```bash # Delete the prometheus BundleDeployment diff --git a/internal/controllers/bundledeployment/bundledeployment.go b/internal/controllers/bundledeployment/bundledeployment.go index 99668466..e3c9ab12 100644 --- a/internal/controllers/bundledeployment/bundledeployment.go +++ b/internal/controllers/bundledeployment/bundledeployment.go @@ -287,7 +287,7 @@ func (c *controller) reconcile(ctx context.Context, bd *rukpakv1alpha2.BundleDep bundleFS, err := c.storage.Load(ctx, bd) if err != nil { meta.SetStatusCondition(&bd.Status.Conditions, metav1.Condition{ - Type: rukpakv1alpha2.TypeHasValidBundle, + Type: rukpakv1alpha2.TypeInstalled, Status: metav1.ConditionFalse, Reason: rukpakv1alpha2.ReasonBundleLoadFailed, Message: err.Error(),