kind.sh 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #!/usr/bin/env bash
  2. # shellcheck disable=SC2034
  3. KUBECONFIG="kind.yaml"
  4. KIND_CLUSTER="kind-cluster-kilo"
  5. KIND_BINARY="${KIND_BINARY:-kind}"
  6. KUBECTL_BINARY="${KUBECTL_BINARY:-kubectl}"
  7. KILO_IMAGE="${KILO_IMAGE:-squat/kilo}"
  8. is_ready() {
  9. for pod in $($KUBECTL_BINARY -n "$1" get pods -o name -l "$2"); do
  10. if ! $KUBECTL_BINARY -n "$1" get "$pod" | tail -n 1 | grep -q Running; then
  11. return 1;
  12. fi
  13. done
  14. return 0
  15. }
  16. # Returns non zero if one pod of the given name in the given namespace is not ready.
  17. block_until_ready_by_name() {
  18. block_until_ready "$1" "app.kubernetes.io/name=$2"
  19. }
  20. # Blocks until all pods of a deployment are ready.
  21. block_until_ready() {
  22. # Just abort after 150s
  23. for c in {1..30}; do
  24. if is_ready "$1" "$2"; then
  25. break
  26. else
  27. echo "some $2 pods are not ready, yet. Retries=$c/30"
  28. sleep 5
  29. fi
  30. done
  31. return 0
  32. }
  33. # Block waits until pods are ready. When patching pods, it is not very reliable because sometimes it checkts the state of old pods.
  34. block() {
  35. $KUBECTL_BINARY -n "$1" wait -l "app.kubernetes.io/name=$2" pod --for=condition=Ready
  36. }
  37. # Set up the kind cluster and deploy Kilo, Adjacency and a helper with curl.
  38. setup_suite() {
  39. $KIND_BINARY delete clusters $KIND_CLUSTER > /dev/null
  40. # Create the kind cluster.
  41. $KIND_BINARY create cluster --name $KIND_CLUSTER --config ./kind-config.yaml
  42. # Load the Kilo image into kind.
  43. docker tag "$KILO_IMAGE" squat/kilo:test
  44. $KIND_BINARY load docker-image squat/kilo:test --name $KIND_CLUSTER
  45. # Apply Kilo the the cluster.
  46. $KUBECTL_BINARY apply -f kilo-kind-userspace.yaml
  47. block_until_ready_by_name kube-system kilo-userspace
  48. $KUBECTL_BINARY wait nodes --all --for=condition=Ready
  49. # wait for coredns
  50. block_until_ready kube_system k8s-app=kube-dns
  51. $KUBECTL_BINARY taint node $KIND_CLUSTER-control-plane node-role.kubernetes.io/master:NoSchedule-
  52. $KUBECTL_BINARY apply -f https://raw.githubusercontent.com/heptoprint/adjacency/master/example.yaml
  53. $KUBECTL_BINARY apply -f helper-curl.yaml
  54. block_until_ready_by_name adjacency adjacency
  55. block_until_ready_by_name default curl
  56. }
  57. block_until_ping() {
  58. for c in {1..30}; do
  59. keepgoing=1
  60. # Block until all IP addresses of the adjacency pods are reached.
  61. for ip in $($KUBECTL_BINARY get pods -l app.kubernetes.io/name=adjacency -o jsonpath='{.items[*].status.podIP}'); do
  62. ping=$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c "curl -s http://$ip:8080/ping")
  63. if [[ $ping == "pong" ]]; then
  64. echo "successfully pinged $ip"
  65. keepgoing=0
  66. else
  67. keepgoing=1
  68. echo "expected \"pong\" got \"$ping\""
  69. break
  70. fi
  71. done
  72. if [[ $keepgoing == 0 ]]; then
  73. break
  74. else
  75. sleep 5
  76. fi
  77. done
  78. }
  79. check_adjacent() {
  80. echo
  81. $KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=fancy'
  82. assert_equals "12" \
  83. "$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=json' | jq | grep -c true)" \
  84. "Adjacency returned the wrong number of successful pings"
  85. echo "sleep for 30s (one reconciliation period) and try again..."
  86. sleep 30
  87. echo
  88. $KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=fancy'
  89. assert_equals "12" \
  90. "$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=json' | jq | grep -c true)" \
  91. "Adjacency returned the wrong number of successful pings"
  92. }
  93. test_locationmesh() {
  94. # shellcheck disable=SC2016
  95. $KUBECTL_BINARY patch ds -n kube-system kilo -p '{"spec": {"template":{"spec":{"containers":[{"name":"kilo","args":["--hostname=$(NODE_NAME)","--create-interface=false","--mesh-granularity=location"]}]}}}}'
  96. sleep 5
  97. block_until_ready_by_name kube-system kilo-userspace
  98. block_until_ping
  99. $KUBECTL_BINARY wait pod -l app.kubernetes.io/name=adjacency --for=condition=Ready --timeout 3m
  100. sleep 5
  101. check_adjacent
  102. }
  103. test_fullmesh() {
  104. # shellcheck disable=SC2016
  105. $KUBECTL_BINARY patch ds -n kube-system kilo -p '{"spec": {"template":{"spec":{"containers":[{"name":"kilo","args":["--hostname=$(NODE_NAME)","--create-interface=false","--mesh-granularity=full"]}]}}}}'
  106. sleep 5
  107. block_until_ready_by_name kube-system kilo-userspace
  108. block_until_ping
  109. $KUBECTL_BINARY wait pod -l app.kubernetes.io/name=adjacency --for=condition=Ready --timeout 3m
  110. sleep 5
  111. check_adjacent
  112. }
  113. teardown_suite () {
  114. $KIND_BINARY delete clusters $KIND_CLUSTER
  115. }