Plugins extends the capabilities of the Greenhouse cloud operations platform, adding specific features or functionalities to tailor and enhance the platform for specific organizational needs. These plugins are integral to Greenhouse’ extensibility, allowing users to customize their cloud operations environment and address unique requirements while operating within the Greenhouse ecosystem.
This section provides guides for the management of plugins for Kubernetes clusters within Greenhouse.
1 - Testing a Plugin
Guidelines for testing Plugins contributed to the Greenhouse project.
Overview
Plugin Testing Requirements
All Plugins contributed to Plugin-Extensions repository should include comprehensive Helm Chart Tests using the bats/bats-detik testing framework. This ensures our Plugins are robust, deployable, and catch potential issues early in the development cycle.
What is bats/bats-detik?
The bats/bats-detik framework simplifies end-to-end (e2e) Testing in Kubernetes. It combines the Bash Automated Testing System (bats) with Kubernetes-specific assertions (detik). This allows you to write test cases using natural language-like syntax, making your tests easier to read and maintain.
Implementing Tests
Create a /tests folder inside your Plugin’s Helm Chart templates folder to store your test resources.
ConfigMap definition:
Create a test-<plugin-name>-config.yaml file in the templates/tests directory to define a ConfigMap that will hold your test script.
This ConfigMap contains the test script run.sh that will be executed by the test Pod to run your tests.
{{- if .Values.testFramework.enabled -}}apiVersion: v1kind: ConfigMapmetadata:
name: {{ .Release.Name }}-testnamespace: {{ .Release.Namespace }}labels:
type: integration-testdata:
run.sh: |-#!/usr/bin/env batsload "/usr/lib/bats/bats-detik/utils"load "/usr/lib/bats/bats-detik/detik"DETIK_CLIENT_NAME="kubectl" @test "Verify successful deployment and running status of the {{ .Release.Name }}-operator pod" {verify "there is 1 deployment named '{{ .Release.Name }}-operator'"verify "there is 1 service named '{{ .Release.Name }}-operator'"try "at most 2 times every 5s to get pods named '{{ .Release.Name }}-operator' and verify that '.status.phase' is 'running'" }
@test "Verify successful creation and bound status of {{ .Release.Name }} persistent volume claims" {try "at most 3 times every 5s to get persistentvolumeclaims named '{{ .Release.Name }}.*' and verify that '.status.phase' is 'Bound'" }
@test "Verify successful creation and available replicas of {{ .Release.Name }} Prometheus resource" {try "at most 3 times every 5s to get prometheuses named '{{ .Release.Name }}' and verify that '.status.availableReplicas' is more than '0'" }
@test "Verify creation of required custom resource definitions (CRDs) for {{ .Release.Name }}" {verify "there is 1 customresourcedefinition named 'prometheuses'"verify "there is 1 customresourcedefinition named 'podmonitors'" }
{{- end -}}
Note: You can use this guide for reference when writing your test assertions.
Test Pod Definition:
Create a test-<plugin-name>.yaml file in the templates/tests directory to define a Pod that will run your tests.
This test Pod will mount the ConfigMap created in the previous step and will execute the test script run.sh.
Create the necessary RBAC resources in the templates/tests folder with a dedicated ServiceAccount and role authorisations so that the test Pod can cover test the cases.
You can use test-permissions.yaml from the kube-monitoring as a reference to configure RBAC permissions for your test Pod.
Configure the Test Framework in Plugin’s values.yaml:
Add the following configuration to your Plugin’s values.yaml file:
Important: Once you have completed all the steps above, you are ready to run the tests. However, before running the tests, ensure that you perform a fresh Helm installation or upgrade of your Plugin’s Helm release against your test Kubernetes cluster (for example, Minikube or Kind) by executing the following command:
# For a new installationhelm install <Release name> <chart-path># For an upgradehelm upgrade <Release name> <chart-path>
After the Helm installation or upgrade is successful, run the tests against the same test Kubernetes Cluster by executing the following command.
helm test <Release name>
Plugin Testing with dependencies during Pull Requests
Overview
Some Plugins require other Plugins to be installed in the Cluster for their tests to run successfully. To support this, each Plugin can declare required dependencies using a test-dependencies.yaml file.
[!NOTE] The test-dependencies.yaml file is required if other Plugins need to be installed in the Kind Cluster created by the GitHub Actions workflow before running tests during a Pull Request for the Plugin.
How It Works
Each Plugin can optionally include a test-dependencies.yaml file in the Plugin’s root directory (e.g., Thanos/test-dependencies.yaml).
This file defines both the dependencies (other Plugins) that should be installed before testing begins and custom values for these dependencies.
Ensure your Plugin’s Helm Chart includes a /tests directory.
Verify the presence of test-<plugin-name>.yaml, test-<plugin-name>-config.yaml, and test-permissions.yaml files.
Test your Plugin thoroughly using helm test <release-name> and confirm that all tests pass against a test Kubernetes Cluster.
Include a brief description of the tests in your Pull Request.
Make sure that your Plugin’s Chart Directory and the Plugin’s Upstream Chart Repository are added to this Greenhouse-Extensions Helm Test Config File. This will ensure that your Plugin’s tests are automatically run in the GitHub Actions workflow when you submit a Pull Request for this Plugin.
Note that the dependencies of your Plugin’s Helm Chart might also have their own tests. If so, ensure that the tests of the dependencies are also passing.
If your Plugin relies on other Plugins for testing, please follow the Plugin Testing with Dependencies section for declaring those dependencies.
Important Notes
Test Coverage: Aim for comprehensive test coverage to ensure your Plugin’s reliability.
2 - Plugin deployment
Deploy a Greenhouse plugin to an existing Kubernetes cluster.
Before you begin
This guides describes how to configure and deploy a Greenhouse plugin.
apiVersion: greenhouse.sap/v1alpha1kind: Pluginmetadata:
name: kube-monitoring-martinnamespace: <organization namespace># same namespace in remote cluster for resourcesspec:
clusterName: <name of the remote cluster ># k get clusterdisabled: falsedisplayName: <any human readable name>pluginDefinition: <plugin name># k get pluginoptionValues:
- name: <from the plugin options>value: <from the plugin options> - ...
Exposed services
Plugins deploying Helm Charts into remote clusters support exposed services.
By adding the following label to a service in helm chart it will become accessible from the central greenhouse system via a service proxy:
Check with kubectl --namespace=<organization name> get plugin has been properly created. When all components of the plugin are successfully created, the plugin should show the state configured.
Check in the remote cluster that all plugin resources are created in the organization namespace.
URLs for exposed services
After deploying the plugin to a remote cluster, ExposedServices section in Plugin’s status provides an overview of the Plugins services that are centrally exposed. It maps the exposed URL to the service found in the manifest.
The URLs for exposed services are created in the following pattern: $https://$cluster--$hash.$organisation.$basedomain. The $hash is computed from service--$namespace.
When deploying a plugin to the central cluster, the exposed services won’t have their URLs defined, which will be reflected in the Plugin’s Status.
3 - Managing Plugins for multiple clusters
Deploy a Greenhouse Plugin with the same configuration into multiple clusters.
Managing Plugins for multiple clusters
This guide describes how to configure and deploy a Greenhouse Plugin with the same configuration into multiple clusters.
The PluginPreset resource is used to create and deploy Plugins with a the identical configuration into multiple clusters. The list of clusters the Plugins will be deployed to is determind by a LabelSelector.
As a result, whenever a cluster, that matches the ClusterSelector is onboarded or offboarded, the Controller for the PluginPresets will take care of the Plugin Lifecycle. This means creating or deleting the Plugin for the respective cluster.
The same validation applies to the PluginPreset as to the Plugin. This includes immutable PluginDefinition and ReleaseNamespace fields, as well as the validation of the OptionValues against the PluginDefinition.
In case the PluginPreset is updated all of the Plugin instances that are managed by the PluginPreset will be updated as well. Each Plugin instance that is created from a PluginPreset has a label greenhouse.sap/pluginpreset: <PluginPreset name>. Also the name of the Plugin follows the scheme <PluginPreset name>-<cluster name>.
Changes that are done directly on a Plugin which was created from a PluginPreset will be overwritten immediately by the PluginPreset Controller. All changes must be performed on the PluginPreset itself.
If a Plugin already existed with the same name as the PluginPreset would create, this Plugin will be ignored in following reconciliations.
A PluginPreset with the annotation greenhouse.sap/prevent-deletion may not be deleted. This is to prevent the accidental deletion of a PluginPreset including the managed Plugins and their deployed Helm releases. Only after removing the annotation it is possible to delete a PluginPreset.
Example PluginPreset
apiVersion: greenhouse.sap/v1alpha1kind: PluginPresetmetadata:
name: kube-monitoring-presetnamespace: <organization namespace>spec:
plugin: # this embeds the PluginSpecdisplayName: <any human readable name>pluginDefinition: <PluginDefinition name># k get plugindefinitionreleaseNamespace: <namespace># namespace where the plugin is deployed to on the remote cluster. Will be created if not existsoptionValues:
- name: <from the PluginDefinition options>value: <from the PluginDefinition options> - ..clusterSelector: # LabelSelector for the clusters the Plugin should be deployed tomatchLabels:
<label-key>: <label-value>clusterOptionOverrides: # allows you to override specific options in a given cluster - clusterName: <cluster name where we want to override values>overrides:
- name: <option name to override>value: <new value> - .. - ..
4 - Plugin Catalog
Explore the catalog of Greenhouse PluginDefinitions
Before you begin
This guides describes how to explore the catalog of Greenhouse PluginDefinitions.
While all members of an organization can see the Plugin catalog, enabling, disabling and configuration PluginDefinitions for an organization requires organization admin privileges.
Exploring the PluginDefinition catalog
The PluginDefinition resource describes the backend and frontend components as well as mandatory configuration options of a Greenhouse extension. While the PluginDefinition catalog is managed by the Greenhouse administrators and the respective domain experts, administrators of an organization can configure and tailor Plugins to their specific requirements.
NOTE: The UI also provides a preliminary catalog of Plugins under Organization> Plugin> Add Plugin.
Run the following command to see all available PluginDefinitions.
$ kubectl get plugindefinition
NAME VERSION DESCRIPTION AGE
cert-manager 1.1.0 Automated certificate management in Kubernetes 182d
digicert-issuer 1.2.0 Extensions to the cert-manager for DigiCert support 182d
disco 1.0.0 Automated DNS management using the Designate Ingress CNAME operator (DISCO) 179d
doop 1.0.0 Holistic overview on Gatekeeper policies and violations 177d
external-dns 1.0.0 The kubernetes-sigs/external-dns plugin. 186d
heureka 1.0.0 Plugin for Heureka, the patch management system. 177d
ingress-nginx 1.1.0 Ingress NGINX controller 187d
kube-monitoring 1.0.1 Kubernetes native deployment and management of Prometheus, Alertmanager and related monitoring components. 51d
prometheus-alertmanager 1.0.0 Prometheus alertmanager 60d
supernova 1.0.0 Supernova, the holistic alert management UI 187d
teams2slack 1.1.0 Manage Slack handles and channels based on Greenhouse teams and their members 115d