Skip to content

Latest commit

 

History

History
139 lines (92 loc) · 5.07 KB

development.md

File metadata and controls

139 lines (92 loc) · 5.07 KB

Developing the Solr Operator

This page details the steps for developing the Solr Operator, and all necessary steps to follow before creating a PR to the repo.

Setup

Setup Docker for Mac with K8S with an Ingress Controller

Please follow the instructions from the local tutorial.

Install the necessary dependencies

Install the Zookeeper, which this operator depends on by default. Each is optional, as described in the Zookeeper Reference section in the CRD docs.

$ kubectl apply -f example/dependencies

Install necessary dependencies for building and deploying the operator.

$ export PATH="$PATH:$GOPATH/bin" # You likely want to add this line to your ~/.bashrc or ~/.bash_aliases
$ ./hack/install_dependencies.sh

Beware that you must be running an updated version of controller-gen. To update to a compatible version, run:

$ go get sigs.k8s.io/controller-tools/cmd/[email protected]

Build the Solr CRDs

If you have changed anything in the APIs directory, you will need to run the following command to regenerate all Solr CRDs.

$ make manifests

In order to apply these CRDs to your kube cluster, merely run the following:

$ make install

Build and Run local versions

It is very useful to build and run your local version of the operator to test functionality.

Building the Solr Operator

Building a Go binary

Building the Go binary files is quite straightforward:

$ go build

This is useful for testing that your code builds correctly, as well as using the make run command detailed below.

Building the Docker image

Building and releasing a test operator image with a custom Docker namespace.

$ NAMESPACE=your-namespace/ make docker-build docker-push

You can test the vendor docker container by running

$ NAMESPACE=your-namespace/ make docker-vendor-build docker-vendor-push

You can control the namespace and version for your solr-operator docker image via the ENV variables:

  • NAMESPACE, defaults to bloomberg/. This must end with a forward slash. This can also include the docker repository information for private repos.
  • NAME, defaults to solr-operator.
  • VERSION, defaults to the git HEAD tag. (e.g. v0.2.5-1-g06f4e2a).
    You can check what version you are using by running make version.

The image will be created under the tag $(NAMESPACE)$(NAME):$(VERSION) as well as $(NAMESPACE)$(NAME):latest.

Running the Solr Operator

There are a few options for running the Solr Operator version you are developing.

  • You can deploy the Solr Operator by using our provided Helm Chart. You will need to build a docker image for your version of the operator. Then update the values for the helm chart to use the version that you have built.
  • There are two useful make commands provided to help with running development versions of the operator:
    • make run - This command will start the solr-operator process locally (not within kubernetes). This does not require building a docker image.
    • make deploy - This command will apply the docker image with your local version to your kubernetes cluster. This requires building a docker image.

Warning: If you are running kubernetes locally and do not want to push your image to docker hub or a private repository, you will need to set the imagePullPolicy: Never on your Solr Operator Deployment. That way Kubernetes does not try to pull your image from whatever repo it is listed under (or docker hub by default).

Testing

If you are creating new functionality for the operator, please include that functionality in an existing test or a new test before creating a PR. Most tests can be found in the controller directory, with names that end in _test.go.

PRs will automatically run the unit tests, and will block merging if the tests fail.

You can run these tests locally via the following make command:

$ make test

Before you create a PR

The CRD should be updated anytime you update the API.

$ make manifests

Make sure that you have updated the go.mod file:

$ make mod-tidy

Finally, as mentioned on the Repo's README, you will need to sign all commits included in the PR. More information can be found on the organization's contibutions documentation.