Kubernetes test support with KIND for pytest
Project description
pytest-kind
Test your Python Kubernetes app/operator end-to-end with kind and pytest.
pytest-kind
is a plugin for pytest which provides the kind_cluster
fixture.
The fixture will install kind 0.8.0, create a Kubernetes 1.18 cluster, and provide convenience functionality such as port forwarding.
Usage
Install pytest-kind
via pip or via poetry, e.g.:
poetry add --dev pytest-kind
Write your pytest functions and use the provided kind_cluster
fixture, e.g.:
def test_kubernetes_version(kind_cluster):
assert kind_cluster.api.version == ('1', '18')
To load your custom Docker image and apply deployment manifests:
import requests
from pykube import Pod
def test_myapp(kind_cluster):
kind_cluster.load_docker_image("myapp")
kind_cluster.kubectl("apply", "-f", "deployment.yaml")
kind_cluster.kubectl("rollout", "status", "deployment/myapp")
# using Pykube to query pods
for pod in Pod.objects(kind_cluster.api).filter(selector="app=myapp"):
assert "Sucessfully started" in pod.logs()
with kind_cluster.port_forward("service/myapp", 80) as port:
r = requests.get(f"http://localhost:{port}/hello/world")
r.raise_for_status()
assert r.text == "Hello world!"
See the examples
directory for sample projects and also check out kube-web-view which uses pytest-kind for its e2e tests.
KindCluster object
The kind_cluster
fixture is an instance of the KindCluster class with the following methods:
load_docker_image(docker_image)
: load the specified Docker image into the kind clusterkubectl(*args)
: run thekubectl
binary against the cluster with the specified arguments. Returns the process output as string.port_forward(service_or_pod_name, remote_port, *args)
: run "kubectl port-forward" for the given service/pod and return the (random) local port. To be used as context manager ("with" statement). Pass the namespace as additional args to kubectl via "-n", "mynamespace".
KindCluster has the following attributes:
name
: the kind cluster namekubeconfig_path
: the path to the Kubeconfig file to access the clusterkind_path
: path to thekind
binarykubectl_path
: path to thekubectl
binaryapi
: pykube HTTPClient instance to access the cluster from Python
You can also use KindCluster directly without pytest:
from pytest_kind import KindCluster
cluster = KindCluster("myclustername")
cluster.create()
cluster.kubectl("apply", "-f", "..")
# ...
cluster.delete()
Pytest Options
The kind cluster name can be set via the --cluster-name
CLI option.
The kind cluster is deleted after each pytest session, you can keep the cluster by passing --keep-cluster
to pytest.
Note that you can use the PYTEST_ADDOPTS
environment variable to pass these options to pytest. This also works if you call pytest from a Makefile:
# for test debugging: don't delete the kind cluster
PYTEST_ADDOPTS=--keep-cluster make test
Notes
- The
kind_cluster
fixture is session-scoped, i.e. the same cluster will be used across all test modules/functions. - The
kind
andkubectl
binaries will be downloaded once to the local directory./.pytest-kind/{cluster-name}/
. You can use them to interact with the cluster (e.g. when--keep-cluster
is used). - Some cluster pods might not be ready immediately (e.g. kind's CoreDNS take a moment), add wait/poll functionality as required to make your tests predictable.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pytest-kind-20.5.1.tar.gz
.
File metadata
- Download URL: pytest-kind-20.5.1.tar.gz
- Upload date:
- Size: 17.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/5.4.0-28-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a5c625780d2ab0488e0f75a334643739200a15031bb3965a84024994626160fc |
|
MD5 | df6f7c2a2bd88481ee2525d9f5f0abef |
|
BLAKE2b-256 | 55d5eeb171138bcafed4e25e37f48ea0503aaab90dcc5f9a702a2cd0cef5006d |
Provenance
File details
Details for the file pytest_kind-20.5.1-py3-none-any.whl
.
File metadata
- Download URL: pytest_kind-20.5.1-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/5.4.0-28-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 83c558f214c6dc3be43262ee55a54051c15ebbfdf7b2116e6de779d0ca381d71 |
|
MD5 | c8516910931c5e96a71317d894252ea5 |
|
BLAKE2b-256 | 05d053b6b419eead69332a4bd1aab3dcbd84bfa89396b58822fb268c68f79dcf |