-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathhaproxy.sh
executable file
·152 lines (141 loc) · 3.58 KB
/
haproxy.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#!/bin/bash
# SPDX-license-identifier: Apache-2.0
##############################################################################
# Copyright (c) 2021
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
set -o errexit
set -o nounset
set -o pipefail
# shellcheck source=tests/_functions.sh
source _functions.sh
# shellcheck source=tests/_assertions.sh
source _assertions.sh
echo_deployment_name="echo"
function cleanup {
destroy_deployment "$echo_deployment_name"
kubectl delete service echo --ignore-not-found
kubectl delete ingress demo --ignore-not-found
}
trap cleanup EXIT
# Setup
HOST=$(kubectl get nodes -o jsonpath='{.items[0].status.addresses[0].address}')
PORT=$(kubectl get svc haproxy-kubernetes-ingress -o jsonpath='{.spec.ports[0].nodePort}' -n haproxy-system)
CURL_PROXY_CMD="curl -s http://${HOST}:${PORT}"
# Test
info "===== Test started ====="
info "Ensure HAProxy Ingress Class"
kubectl get ingressclasses.networking.k8s.io haproxy
# editorconfig-checker-disable
cat <<EOF | kubectl apply -f -
apiVersion: v1
kind: Service
metadata:
labels:
app: echo
name: echo
spec:
ports:
- port: 8080
name: high
protocol: TCP
targetPort: 8080
- port: 80
name: low
protocol: TCP
targetPort: 8080
selector:
app: echo
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: echo
name: $echo_deployment_name
spec:
replicas: 1
selector:
matchLabels:
app: echo
template:
metadata:
labels:
app: echo
spec:
containers:
- image: gcr.io/kubernetes-e2e-test-images/echoserver:2.2
name: echo
ports:
- containerPort: 8080
env:
- name: NODE_NAME
valueFrom:
fieldRef:
fieldPath: spec.nodeName
- name: POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: POD_IP
valueFrom:
fieldRef:
fieldPath: status.podIP
EOF
# editorconfig-checker-enable
wait_deployment "$echo_deployment_name"
if [[ "$(_get_kube_version)" == *"v1.18"* ]]; then
# editorconfig-checker-disable
cat <<EOF | kubectl apply -f -
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: demo
annotations:
haproxy.org/path-rewrite: "/"
ingress.class: haproxy
spec:
rules:
- http:
paths:
- path: /foo
pathType: Prefix
backend:
serviceName: echo
servicePort: 80
EOF
# editorconfig-checker-enable
else
# editorconfig-checker-disable
cat <<EOF | kubectl apply -f -
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: demo
annotations:
haproxy.org/path-rewrite: "/"
ingress.class: haproxy
spec:
rules:
- http:
paths:
- path: /foo
pathType: Prefix
backend:
service:
name: echo
port:
number: 80
EOF
# editorconfig-checker-enable
fi
wait_ingress demo
assert_contains "$(eval "$CURL_PROXY_CMD/foo")" "Pod Information:" "The server response doesn't have pod's info"
info "===== Test completed ====="