// TODO(user): Add detailed information on how you would like others to contribute to this project
This project aims to follow the Kubernetes Operator pattern.
It uses Controllers which provides a reconcile function responsible for synchronizing resources until the desired state is reached on the cluster.
- kubectl. See Instaling kubectl.
- Available local or remote Kubernetes cluster with cluster admin privileges. For instance minikube. See Instaling minkube.
- A copy of the Backstage Operator sources:
git clone https://github.com/redhat-developer/rhdh-operator
To run:
- all the unit tests
- part of Integration Tests which does not require a real cluster.
make test
It only takes a few seconds to run, but covers quite a lot of functionality. For early regression detection, it is recommended to run it as often as possible during development.
For testing, you will need a Kubernetes cluster, either remote (with sufficient admin rights) or local, such as minikube or kind
- Build and push your image to the location specified by
IMG
:
make image-build image-push IMG=<your-registry>/backstage-operator:tag
- Install the Custom Resource Definitions into the local cluster (minikube is installed and running):
make install
IMPORTANT: If you are editing the CRDs, make sure you reinstall it before deploying.
- To delete the CRDs from the cluster:
make uninstall
You can run your controller standalone (this will run in the foreground, so switch to a new terminal if you want to leave it running) This way you can see controllers log just in your terminal window which is quite convenient for debugging.
make [PROFILE=<configuration-profile>] [install] run
You can use it for manual and automated (such as USE_EXISTING_CLUSTER=true make integration-test
) tests efficiently, but, note, RBAC is not working with this kind of deployment.
Since v0.3.0 Operator has a facility to support different predefined runtime configurations, we call it Configuration Profile. You can see them as a subdirectories of /config/profile:
- default (default as for v0.3.0) - OOTB supporting Red Hat Developer Hub runtime
- backstage.io - bare backstage image
- external - empty profile you can feed your configuration from outside (instructions TBD)
To deploy the Operator directly to current cluster use:
make deploy [PROFILE=<configuration-profile>] [IMG=<your-registry>/backstage-operator[:tag]]
To undeploy the controller from the cluster:
make undeploy
- To generate deployment manifest, use:
make deployment-manifest [IMG=<your-registry>/backstage-operator:tag]
it will create the file rhdh-operator-${VERSION}.yaml on the project root and you will be able to share it to make it possible to deploy operator with:
kubectl apply -f <path-or-url-to-deployment-script>
Make sure your cluster supports OLM. For instance Openshift supports it out of the box. If needed install it using:
make install-olm
There are a bunch of commands to build and push to the registry necessary images. For development purpose, most probably, you will need to specify the image you build and push with IMAGE_TAG_BASE env variable:
[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make image-build
builds operator manager image (backstage-operator)[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make image-push
pushes operator manager image to your-registry[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make bundle-build
builds operator manager image (backstage-operator-bundle)[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make bundle-push
pushes bundle image to your-registry[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make catalog-build
builds catalog image (backstage-operator-catalog)[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make catalog-push
pushes catalog image to your-registry
You can do it all together using:
[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make release-build release-push
[OLM_NAMESPACE=<olm-namespace>] [IMAGE_TAG_BASE=<your-registry>/backstage-operator] make catalog-update
You can point the namespace where OLM installed. By default, in a vanilla Kubernetes, OLM os deployed on 'olm' namespace. In Openshift you have to explicitly point it to openshift-marketplace namespace.
Default namespace to deploy the Operator is called backstage-system , this name fits one defined in kustomization.yaml. So, if you consider changing it you have to change it in this file and define OPERATOR_NAMESPACE environment variable. Following command creates OperatorGroup and Subscription on Operator namespace
[OPERATOR_NAMESPACE=<operator-namespace>] make deploy-olm
To undeploy the Operator
make undeploy-olm
NOTE: OLM has to be installed as a prerequisite
- To build and deploy the operator to vanilla Kubernetes with OLM
[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make deploy-k8s-olm
- To build and deploy the operator to Openshift with OLM
[IMAGE_TAG_BASE=<your-registry>/backstage-operator] make deploy-openshift
NOTE: Run make help
for more information on all potential make
targets
More information can be found via the Kubebuilder Documentation