/vk8s

Setting up a virtual Kubernetes cluster inside a Docker container for integration testing

Primary LanguageShell

vk8s

Setting up a virtual Kubernetes cluster inside a Docker container for integration testing.

Note: A virtual Kubernetes cluster consists of virtual nodes, once newly-created pods are assigned to these nodes, pods will immediately be reported as RUNNING status, but in reality no any container of pods has been created and run, this is a trick achieved by virtual-kubelet.

Examples

Use in Shell

# Run vk8s in background
docker run --name=vk8s -e TTL=300 -d --rm -p 9191:8080 ghcr.io/go-tk/vk8s:v0.2.1

# Ensure vk8s is ready (~15s)
docker exec vk8s ./wait-for-ready.bash

# Create a pod
kubectl -s http://127.0.0.1:9191 apply -f - <<EOF
apiVersion: v1
kind: Pod
metadata:
  name: nginx
spec:
  containers:
  - name: nginx
    image: nginx:1.14.2
EOF

# List pods
kubectl -s http://127.0.0.1:9191 get pods

# Clean up
docker rm -f vk8s

Use in Go

package xxx

import (
        "context"
        "testing"
        "time"

        "github.com/go-tk/vk8s"
        "k8s.io/client-go/kubernetes"
        "k8s.io/client-go/tools/clientcmd"
)

func TestXXX(t *testing.T) {
        kubeConfigData := vk8s.SetUp(context.Background(), 5*time.Minute, t)

        config, err := clientcmd.RESTConfigFromKubeConfig(kubeConfigData)
        if err != nil {
                t.Fatal(err)
        }

        clientset, err := kubernetes.NewForConfig(config)
        if err != nil {
                t.Fatal(err)
        }

        _ = clientset // Do anything you want to do with clientset
}