Testing

Unit and integration tests

Unit and integration tests can be run using go test

To run all tests:

  1. go test -v ./...

Adding an integration test

The integration tests takes a cluster spec and builds terraform templates. For new functionality, consider adding it to the complex.example.com cluster unless it conflicts with existing functionality in that cluster. To add a new integration test, create a new directory in tests/integration/update_cluster/ and put the cluster spec in in-v1alpha2.yaml. Use a unique cluster name.

Then edit ./cmd/kops/integration_test.go and add the test function with the cluster name and directory from above.

Lastly run ./hack/update-expected.sh to generate the expected output.

Kubernetes e2e testing

Kubetest2 is the framework for launching and running end-to-end tests on Kubernetes, and the best approach to test your kOps cluster is to use the same Go modules to perform the e2e testing.

Preparing the environment

Before running kubetest2 you will need to install the core, and all deployers and testers Go modules.

  1. make test-e2e-install

For reference, the build target commands can be found here.

See GitHub kubetest2 to gain a further understanding of the Kubernetes e2e test framework.

Following the examples below, kubetest2 will download test artifacts to ./_artifacts.

Running against an existing cluster

You can run something like the following to have kubetest2 re-use an existing cluster.

This assumes you have already built the kOps binary from source. The exact path to the kops binary used in the --kops-binary-path flag may differ.

The environment variable KOPS_ROOT is the full path to your local GitHub kOps working directory.

  1. kubetest2 kops \
  2. -v 2 \
  3. --test \
  4. --cloud-provider=aws \
  5. --cluster-name=my.testcluster.com \
  6. --kops-binary-path=${KOPS_ROOT}/.build/dist/$(go env GOOS)/$(go env GOARCH)/kops \
  7. --kubernetes-version=v1.20.2 \
  8. --test=kops \
  9. -- \
  10. --test-package-version=v1.20.2 \
  11. --parallel 25 \
  12. --skip-regex="\[Slow\]|\[Serial\]|\[Disruptive\]|\[Flaky\]|\[Feature:.+\]|\[HPA\]|Dashboard|RuntimeClass|RuntimeHandler"

It’s also possible to run the Kubernetes Conformance test suite by replacing the --skip-regex flag with --focus-regex='\[Conformance\]'.

See Conformance Testing in Kubernetes

Running against a new cluster

By adding the --up flag, kubetest2 will spin up a new cluster. Flags can be passed to the kops create cluster command via the --create-args flag. In most cases, you also need to add a few additional flags. See kubetest2 kops --help for the full list.

  1. kubetest2 kops \
  2. -v 2 \
  3. --up \
  4. --cloud-provider=aws \
  5. --cluster-name=my.testcluster.com \
  6. --create-args="--networking calico" \
  7. --kops-binary-path=${KOPS_ROOT}/.build/dist/$(go env GOOS)/$(go env GOARCH)/kops \
  8. --kubernetes-version=v1.20.2 \
  9. --test=kops \
  10. --
  11. -- \
  12. --test-package-version=v1.20.2 \
  13. --parallel 25 \
  14. --skip-regex="\[Slow\]|\[Serial\]|\[Disruptive\]|\[Flaky\]|\[Feature:.+\]|\[HPA\]|Dashboard|RuntimeClass|RuntimeHandler"

If you don’t specify any additional flags, the kOps deployer Go module will create a kubernetes cluster using the following defaults.

  1. kops create cluster --name my.testcluster.com --admin-access <Client Public IP> --cloud aws --kubernetes-version v1.20.2 --master-count 1 --master-volume-size 48 --node-count 4 --node-volume-size 48 --set cluster.spec.nodePortAccess=0.0.0.0/0 --ssh-public-key /home/ubuntu/.ssh/id_rsa.pub --yes --zones <Random Zone> --master-size c5.large --networking calico

For the --zones flag, the kOps deployer will select a random zone based on the --cloud-provider flag, for aws the full list of AWS zones can be found here and for gce the full list of GCE zones can be found here.

Althernatively, you can generate a kOps cluster spec YAML manifest based on your own requirments using kops create cluster my.testcluster.com ... --dry-run -oyaml > my.testcluster.com.yaml and then run the kubetest2 e2e tests using the --template-path flag to specify the full path to the YAML manifest.

  1. kubetest2 kops \
  2. -v 2 \
  3. --up \
  4. --cloud-provider=aws \
  5. --cluster-name=my.testcluster.com \
  6. --kops-binary-path=${KOPS_ROOT}/.build/dist/$(go env GOOS)/$(go env GOARCH)/kops \
  7. --kubernetes-version=v1.20.2 \
  8. --template-path=my.testcluster.com.yaml \
  9. --test=kops \
  10. -- \
  11. --test-package-version=v1.20.2 \
  12. --parallel 25 \
  13. --skip-regex="\[Slow\]|\[Serial\]|\[Disruptive\]|\[Flaky\]|\[Feature:.+\]|\[HPA\]|Dashboard|RuntimeClass|RuntimeHandler"

If you encounter the following error, you will need to add your SSH public key to the kOps cluster spec YAML manifest.

  1. SSH public key must be specified when running with AWS (create with `kops create secret --name training.kops.k8s.local sshpublickey admin -i ~/.ssh/id_rsa.pub`)
  1. ---
  2. apiVersion: kops.k8s.io/v1alpha2
  3. kind: SSHCredential
  4. metadata:
  5. name: admin
  6. labels:
  7. kops.k8s.io/cluster: my.testcluster.com
  8. spec:
  9. publicKey: "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC..."

If you want to run the tests against your development version of kOps, you need to upload the binaries and set the environment variables as described in Adding a new feature.

Since we assume you are using this cluster for testing, we leave the cluster running after the tests have finished so that you can inspect the nodes if anything unexpected happens. If you do not need this, you can add the --down flag. Otherwise, just delete the cluster as any other cluster: kops delete cluster my.testcluster.com --yes