-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Create Decision Record on the ussage of Sonobuoy
Also add 'kaas-sonobuoy-go-example-e2e-framework' As an example usage of the e2e framework provided by kubernetes-sigs/ Signed-off-by: Toni Finger <toni.finger@cloudandheat.com>
- Loading branch information
1 parent
2ed731b
commit 4ad5192
Showing
13 changed files
with
1,716 additions
and
2 deletions.
There are no files selected for viewing
169 changes: 169 additions & 0 deletions
169
Standards/scs-0200-v1-sonobuoy-kaas-conformance-tests.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,169 @@ | ||
--- | ||
title: Sonobuoy kaas conformance tests framework | ||
type: Decision Record | ||
status: Draft | ||
track: KaaS | ||
--- | ||
|
||
## Introduction - Motivation | ||
|
||
With the [k8s-cluster-api-provider][k8s-api] the SCS provides a tooling to generate and manage k8s cluster on top of it's OpenStack IAAS infrastructure. | ||
Part of this tool is the usage of [Sonobuoy][sonobuoy] as a test suit tool to execute the official [kubernetes e2e tests][k8s-e2e-tests]. | ||
Future conformance tests derived from standards could already be part of the Kubernetes e2e tests and could be provided by running the integrated Sonobuoy [e2e test plugin][e2e test plugin]. | ||
|
||
But apart from running the Kubernetes e2e tests Sonobuoy also allows to write your own tests and apply it as a self created [plugin][sonobuoy-plugin-docu]. | ||
So for all tests not already provided by the [e2e test plugin][e2e test plugin] we should first write our own tests and second make them executable with Sonobuoy. | ||
Hence it would be useful to also use Sonobuoy as a test suit combined with a framework for writing SCS conformance tests. | ||
|
||
### Short Sonobuoy Introduction | ||
|
||
The main objective of [Sonobuoy plugins][sonobuoy-plugin-docu] is to present test results and their status in a consolidated way. | ||
This is essentially done by applying the test to a pod that is applied to the k8s cluster under test. | ||
A Sonobuoy worker then supervises this pod and forwards all test results to the aggregator. | ||
It does this by waiting for a "done file" to be created. Once this file is created, it forwards the results to the aggregator, using a predefined location of the results file within the done folder, as seen in following image: | ||
![image search api](https://sonobuoy.io/img/plugin-contract.png) | ||
|
||
Therefore, in order to apply the conformance tests as a plugin, we need a tooling/wrapper/framework around the individual test scripts that: | ||
|
||
* Gathers all test results and provides them in the results file. | ||
* Run tests in sequence and signal the worker when it is finished by writing the "done file". | ||
|
||
Apart from providing the test results, a plugin container must also pass on the status of each test by setting the status flag in the results file. | ||
In addition, to run the tests as a Sonobuoy plugin, we need to create an image that can be run inside the k8s cluster under test. | ||
|
||
## Design Considerations | ||
|
||
Among the different ways to create a Sonobuoy plugin, there are three potential approaches that might work best for us. | ||
These are described in more detail below, where we discuss the pros and cons of each approach. | ||
One of these three approaches must be chosen for implementation. | ||
For the purposes of the investigation and the preparation of this decision record, there are examples(proof of work) for each different approach. | ||
|
||
#### _Option 1_ go approach [1]: Pick framework from the Sonobuoy plugin examples | ||
|
||
Sonobuoy provides plugin examples in the following repository: [https://github.com/vmware-tanzu/sonobuoy-plugins][sonobuoy-plugins-repo]. | ||
The most suitable plugin for us is the [e2e-skeleton][e2e-skel], which uses the [kubernetes-sigs/e2e-framework][e2e-frame]. | ||
The [kubernetes-sigs/e2e-framework][e2e-frame] is a stand-alone project that is separate from the official [kubernetes e2e tests][k8s-e2e-tests]. | ||
It is suitable for us to make us of it, as it provides a properly documented framework. | ||
In addition, it contains helper functions that abstract client go functions similar to those in the kubernetes/kubernetes/test/e2e/framework repository | ||
As mentioned in the [motivation][e2e-frame-motivation] of the [e2e-framework][e2e-frame], it was created to circumvent the disadvantages of | ||
[kubernetes' own e2e-tests][k8s-e2e-tests], which are described in more detail in the [goals][e2e-frame-goals]. | ||
|
||
PROS: | ||
- Arguments in favor of this framework can also be found under the [goals description][e2e-frame-goals] of the documentation | ||
- [e2e-framework][e2e-frame] is a well defined framework who allows the handling of resources creation and deletion | ||
- official framework provided by Kubernetes-sigs | ||
|
||
CONS: | ||
- compared to Python, Go is a less common programming language | ||
- arguments not in favor of this framework can also be derived from the [Non-Goals][e2e-frame-nongoals] description of the documentation: | ||
- However, the point "No responsibility for bootstrapping or the execution of the tests themselves" can be ignored, as this is partly taken over by Sonobuoy. | ||
- Also the point "no mock or fake cluster components" can be ignored as we want to use the e2e tests to test the Kubernetes cluster environment itself and not the functionality of the Kubernetes source code. | ||
- For this test procedure we should run the Sonobuoy e2e plugin in addition to the SCS kaas conformance tests. | ||
|
||
|
||
> proof of work: [kaas-sonobuoy-go-example-e2e-framework](../Tests/kaas/kaas-sonobuoy-go-example-e2e-framework/) | ||
|
||
#### _Option 2_ go approach [2]: Reuse the kubernetes own e2e test infrastructure and framework | ||
|
||
As mentioned above, Sonobuoy already provides [Kubernetes own e2e tests][k8s-e2e-tests] as a plugin. | ||
These tests contain a vast number of examples that we could reuse and adapt to our needs. | ||
For the implementation, we could reuse the e2e tests and the framework in an adapted structure. | ||
More precisely this would lead us to make use of the test framework [ginkgo][ginkgo]. | ||
The entry point for the implementation would be the build process of the Dockerimage which contains | ||
the e2e tests. Therefore we could copy the setup of the build process from | ||
[kubernetes/test/conformance/image][conformance-image] and adapt it to our requirements. | ||
The build process requires some files from the kubernetes repository. | ||
More precisely from: | ||
- [kubernetes/cluster](https://github.com/kubernetes/kubernetes/tree/master/cluster) | ||
- [kubernetes/test/e2e/framework](https://github.com/kubernetes/kubernetes/tree/master/test/e2e) | ||
- [kubernetes/test/conformance/image/go-runner](https://github.com/kubernetes/kubernetes/tree/master/test/conformance/image/go-runner) | ||
|
||
|
||
PROS: | ||
- The [Kubernetes' own e2e tests][k8s-e2e-tests] already provide a vast amount of examples from which we can develop our own tests | ||
- Compared to _option 1_, the [non-goals][e2e-frame-nongoals] of the [e2e-framework][e2e-frame] can be seen as the advantages of using [Kubernetes' own e2e-tests][k8s-e2e-tests]. | ||
|
||
|
||
CONS: | ||
- not easy to implement, as we would have to copy part of the Kubernetes repository and track the changes there as well. | ||
- According to [README.md](https://github.com/kubernetes/kubernetes/tree/master/cluster#readme), part of it seems to be outdated and might change in the future. | ||
- Compared to _option 1_, the [goals][e2e-frame-goals] of the [e2e-framework][e2e-frame] can be seen as the disadvantages of using [Kubernetes' own e2e-tests][k8s-e2e-tests]. | ||
|
||
|
||
> TODO: proof of work: [kaas-sonobuoy-go-example-k8s-e2e](../Tests/kaas/kaas-sonobuoy-go-example-k8s-e2e/) | ||
|
||
#### _Option 3_ Write Python scripts for tests | ||
|
||
Apply the already implemented conformance test python scripts and also continue | ||
writing future tests in python. Therefore, we would need to write a wrapper | ||
around the conformance tests scripts in order to make them executable as a | ||
Sonobuoy plug in. This includes the collection of the test results and the | ||
Generation of the "done" file at the end. Furthermore, we could do this with a | ||
simple handler that executes each test script in a sequential order. All of | ||
this can then be stored in a container image and uploaded to a container | ||
registry that Sonobuoy can use within the k8s-cluster-api-provider. | ||
|
||
This approach also leaves the decision open as to which test framework should be | ||
used for Python. Hence, if we follow this approach, we need to create a | ||
framework of our own. | ||
|
||
> TODO: link to "default storage class" test after [PR 360](https://github.com/SovereignCloudStack/standards/pull/360) got merged | ||
> proof of work: [kaas-sonobuoy-python-example](../Tests/kaas/) | ||
|
||
PROS: | ||
- We can continue to use the current Python scripts | ||
- However, only 2 scripts have been implemented so far. Rewriting them in Go should be a feasible task. | ||
|
||
CONS: | ||
- We would need to write our own test framework | ||
|
||
|
||
## Pros and Cons of Different Approaches | ||
|
||
|
||
### Provide Sonobuoy plug in image | ||
|
||
There are two potential approaches for building the Sonobuoy images. | ||
They are completely independent of which of the above-mentioned frameworks is selected. | ||
Here we discuss the pros and cons of these two approaches. | ||
|
||
#### _Option 1_ GitHub container registry | ||
|
||
Make the image available via the container registry on GitHub. | ||
Hence we would need to apply a CI/CD job to build the images. | ||
|
||
|
||
PROS | ||
- The tests do not have to be created each time before usage. | ||
|
||
CONS | ||
- _None_ | ||
|
||
#### _Option 2_ local image upload | ||
|
||
Create the image locally on the "clusterctl admin control node" and then upload it manually to the Kubernetes cluster under test. | ||
|
||
PROS | ||
- _None_ | ||
|
||
CONS | ||
- To be able to use the tests, you always have to build them first | ||
|
||
|
||
[k8s-e2e-tests]: https://github.com/kubernetes/kubernetes/tree/master/test/e2e | ||
[sonobuoy]: https://sonobuoy.io/ | ||
[sonobuoy-plugins-repo]: https://github.com/vmware-tanzu/sonobuoy-plugins | ||
[sonobuoy-plugin-docu]: https://sonobuoy.io/docs/v0.57.0/plugins/) | ||
[e2e test plugin]: https://sonobuoy.io/docs/main/e2eplugin/ | ||
[k8s-api]: https://github.com/SovereignCloudStack/k8s-cluster-api-provider | ||
[e2e-skel]: https://github.com/vmware-tanzu/sonobuoy-plugins/tree/main/examples/e2e-skeleton | ||
[e2e-frame]: https://github.com/kubernetes-sigs/e2e-framework | ||
[e2e-frame-motivation]: https://github.com/kubernetes-sigs/e2e-framework/blob/main/docs/design/README.md#motivations | ||
[e2e-frame-goals]: https://github.com/kubernetes-sigs/e2e-framework/blob/main/docs/design/README.md#goals | ||
[e2e-frame-nongoals]: https://github.com/kubernetes-sigs/e2e-framework/blob/main/docs/design/README.md#non-goals | ||
[ginkgo]:https://onsi.github.io/ginkgo/ | ||
[conformance-image]:https://github.com/kubernetes/kubernetes/tree/master/test/conformance/image | ||
|
23 changes: 23 additions & 0 deletions
23
Tests/kaas/kaas-sonobuoy-go-example-e2e-framework/Dockerfile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
FROM golang:1.17-buster as build | ||
|
||
# Install kubectl | ||
# Note: Latest version may be found on: | ||
# https://aur.archlinux.org/packages/kubectl-bin/ | ||
RUN wget https://storage.googleapis.com/kubernetes-release/release/v1.21.3/bin/linux/amd64/kubectl -O /usr/bin/kubectl && \ | ||
chmod +x /usr/bin/kubectl && \ | ||
apt-get update && \ | ||
apt-get install -y jq | ||
|
||
COPY ./scs_k8s_tests /src/scs_k8s_tests | ||
WORKDIR /src | ||
COPY go.* /src | ||
ENV CGO_ENABLED=0 | ||
RUN go mod download | ||
|
||
#see: https://docs.docker.com/build/guide/mounts/ | ||
RUN --mount=type=cache,target=/root/.cache/go-build \ | ||
go test -c -o custom.test ./... | ||
|
||
CMD ["bash", "-c", "go tool test2json ./custom.test -test.v"] | ||
|
||
|
112 changes: 112 additions & 0 deletions
112
Tests/kaas/kaas-sonobuoy-go-example-e2e-framework/Makefile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
# Makefile | ||
# This makefile is for development purpose | ||
|
||
SHELL = /bin/bash | ||
#SED ?= sed | ||
|
||
DOCKERFILE="Dockerfile" | ||
IMAGE_REGISTRY="ghcr.io/sovereigncloudstack/standards" | ||
IMAGE_NAME="scsconformance" | ||
#IMAGE_VERSION_TAG ="v0.1.2" | ||
|
||
KIND_CLUSTER ="testcluster" | ||
|
||
#PLUGIN_NAME="k8s-default-storage-class-plugin-go" | ||
PLUGIN_NAME="plugin" | ||
PLUGIN_FILE="${PLUGIN_NAME}.yaml" | ||
|
||
SONO_WAIT = 2 | ||
SONO_TIMEOUT = 10 | ||
|
||
KUBERNETES_SERVICE_HOST=127.0.0.1 | ||
KUBERNETES_SERVICE_PORT=34743 | ||
|
||
|
||
############################################################################### | ||
## Helpers: ## | ||
############################################################################### | ||
|
||
ifeq ($(IMAGE_VERSION_TAG),) | ||
export TAG=dev | ||
else | ||
export TAG=${IMAGE_VERSION_TAG} | ||
endif | ||
|
||
SONOBUOY_IMAGE = "${IMAGE_REGISTRY}/${IMAGE_NAME}:${TAG}" | ||
|
||
container-init: | ||
@echo "" | ||
@echo "[ContainerImageName] ${SONOBUOY_IMAGE}" | ||
@echo "[SonobuoyPluginFile] ${PLUGIN_FILE}" | ||
@echo "" | ||
|
||
|
||
kind-init: | ||
@echo "" | ||
@echo "[KindCluster] ${KIND_CLUSTER}" | ||
@echo "" | ||
|
||
|
||
############################################################################### | ||
## For develpoment usage: ## | ||
############################################################################### | ||
|
||
dev-prerequests: | ||
@echo "[check-test-setup]" | ||
@kind version | ||
@docker version | ||
@sonobuoy version --short | ||
@go version | ||
|
||
|
||
dev-setup: kind-init | ||
kind create cluster --name ${KIND_CLUSTER} | ||
|
||
|
||
dev-build: container-init | ||
@echo "[build]" | ||
docker build . -f ${DOCKERFILE} -t ${SONOBUOY_IMAGE} | ||
kind load docker-image --name ${KIND_CLUSTER} ${SONOBUOY_IMAGE} | ||
|
||
|
||
dev-go: | ||
@echo "[go]" | ||
@echo "[KubernetesService] ${KUBERNETES_SERVICE_HOST}:${KUBERNETES_SERVICE_PORT}" | ||
mkdir ./build | ||
go test -c -o ./build ./... | ||
#go test -c -o ./build ./... --args --skip-labels="type=pod-list" | ||
go tool test2json ./build -test.v | ||
|
||
|
||
dev-run: | ||
@echo "[run-test]" | ||
@echo "sonobuoy run --plugin ${PLUGIN_FILE} --wait=${SONO_WAIT} --timeout=${SONO_TIMEOUT}" | ||
@sonobuoy run --plugin ${PLUGIN_FILE} --wait=${SONO_WAIT} --timeout=${SONO_TIMEOUT} | ||
@sonobuoy status | ||
|
||
|
||
dev-result: | ||
@echo "[result]" | ||
#outfile=$(sonobuoy retrieve) && mkdir results && tar -xf ${outfile} -C results | ||
sonobuoy retrieve | ||
sonobuoy results *.tar.gz | ||
mkdir results | ||
tar -xf *.tar.gz -C results | ||
|
||
|
||
dev-clean: | ||
@echo "[clean]" | ||
@sonobuoy delete --all --wait || true | ||
@sonobuoy status || true | ||
@rm -rf *.tar.gz || true | ||
@rm -rf results || true | ||
|
||
|
||
|
||
dev-purge: kind-init dev-clean | ||
@echo "[purge]" | ||
kind delete cluster --name ${KIND_CLUSTER} || true | ||
docker rmi ${SONOBUOY_IMAGE} || true | ||
|
||
|
||
PHONY: dev-prerequests dev-build dev-run dev-result dev-clean dev-clean dev-purge |
92 changes: 92 additions & 0 deletions
92
Tests/kaas/kaas-sonobuoy-go-example-e2e-framework/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
# SCS kaas sonobuoy testsuie and k8s e2e-test-framework framework | ||
|
||
This directory holds all conformance tests that aim to validate the scs kaas infrastructure | ||
|
||
|
||
## From Sonobuoy: Plug description | ||
|
||
> NOTE: There was a Sonobuoy blog post walking through this plugin, its benefits, and how to use it. See: https://sonobuoy.io/plugin-starter/ | ||
### Custom End-To-End (E2E) Tests | ||
|
||
This plugin is meant as a skeleton for you to grab and run with to implement your | ||
own custom tests in Kubernetes. | ||
|
||
The benefits of using this plugin instead of starting from scratch: | ||
- Automatically comes with the [e2e-test-framework](https://github.com/kubernetes-sigs/e2e-framework) imported/configured | ||
- Includes basic examples so you don't have to look up basic boilerplate | ||
- Automatically comes with a Dockerfile and plugin.yaml so there is less overhead to getting started | ||
- Will get support as the e2e-test-framework and Sonobuoy evolve to get the best features supported by default | ||
|
||
### How to use this plugin | ||
|
||
- Write tests (using main_test.go as a jumping off point) | ||
- Run ./build.sh to build the image and push it to your registry | ||
- `sonobuoy run -p plugin.yaml` to run your own plugin | ||
|
||
|
||
## sonobuoy usage for development of tests | ||
|
||
The development is based on the useage of [kind](https://kind.sigs.k8s.io/) as a test cluster. | ||
|
||
|
||
* (Optional): check if all pre requests for development are met and create a kind test cluster | ||
|
||
``` | ||
make dev-prerequests | ||
make dev-setup | ||
``` | ||
1. Set enviornment variables | ||
``` | ||
export IMAGE_VERSION_TAG="dev" | ||
export K8S_HOST=<kind-cluster-ip> | ||
export K8S_PORT=<kind-cluster-port> | ||
``` | ||
2. Build the image and upload it to the kind cluster | ||
This rule | ||
``` | ||
make dev-build | ||
``` | ||
3. Execute the sonobuoy plugin | ||
``` | ||
make dev-run | ||
``` | ||
This lunches the sonobuoy plugin on the kind cluster in the background | ||
If you want to see the current status of the plugin you can do so by: | ||
``` | ||
sonobuoy status | ||
``` | ||
4. Retrieve the Results | ||
Once sonobuoy is done running the plug in you can retrieve the results as following: | ||
``` | ||
make dev-result | ||
``` | ||
5. Clean the Sonobuoy testcase form the kind cluster | ||
Cleaning up all Kubernetes resources which were placed on the kind cluster by sonobuoy | ||
``` | ||
make dev-clean | ||
``` | ||
6. Purge everything | ||
Deleting the kind cluster | ||
``` | ||
make dev-purge | ||
``` | ||
Oops, something went wrong.