2019-09-27 15:42:24 +00:00
|
|
|
#!/usr/bin/env bats
|
|
|
|
|
|
|
|
load _helpers
|
|
|
|
|
|
|
|
@test "server/ingress: disabled by default" {
|
|
|
|
cd `chart_dir`
|
2020-02-06 16:44:38 +00:00
|
|
|
local actual=$( (helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
. || echo "---") | tee /dev/stderr |
|
2019-09-27 15:42:24 +00:00
|
|
|
yq 'length > 0' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "false" ]
|
|
|
|
}
|
|
|
|
|
2023-07-04 13:30:35 +00:00
|
|
|
@test "server/ingress: namespace" {
|
|
|
|
cd `chart_dir`
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--namespace foo \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.metadata.namespace' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "foo" ]
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'global.namespace=bar' \
|
|
|
|
--namespace foo \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.metadata.namespace' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "bar" ]
|
|
|
|
}
|
|
|
|
|
2020-02-21 16:16:33 +00:00
|
|
|
@test "server/ingress: disable by injector.externalVaultAddr" {
|
|
|
|
cd `chart_dir`
|
|
|
|
local actual=$( (helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
2024-05-28 11:52:10 +00:00
|
|
|
--set 'injector.externalVaultAddr=http://openbao-outside' \
|
2020-02-21 16:16:33 +00:00
|
|
|
. || echo "---") | tee /dev/stderr |
|
|
|
|
yq 'length > 0' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "false" ]
|
|
|
|
}
|
|
|
|
|
2019-09-27 15:42:24 +00:00
|
|
|
@test "server/ingress: checking host entry gets added and path is /" {
|
|
|
|
cd `chart_dir`
|
|
|
|
local actual=$(helm template \
|
2020-02-06 16:44:38 +00:00
|
|
|
--show-only templates/server-ingress.yaml \
|
2019-09-27 15:42:24 +00:00
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].host' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = 'test.com' ]
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
2020-02-06 16:44:38 +00:00
|
|
|
--show-only templates/server-ingress.yaml \
|
2019-09-27 15:42:24 +00:00
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].http.paths[0].path' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = '/' ]
|
|
|
|
}
|
|
|
|
|
2024-05-28 11:52:10 +00:00
|
|
|
@test "server/ingress: openbao backend should be added when I specify a path" {
|
2019-09-27 15:42:24 +00:00
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
2020-02-06 16:44:38 +00:00
|
|
|
--show-only templates/server-ingress.yaml \
|
2019-09-27 15:42:24 +00:00
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name | length > 0' | tee /dev/stderr)
|
2019-09-27 15:42:24 +00:00
|
|
|
[ "${actual}" = "true" ]
|
|
|
|
|
|
|
|
}
|
2019-11-07 16:23:56 +00:00
|
|
|
|
2021-04-08 14:09:19 +00:00
|
|
|
@test "server/ingress: extra paths prepend host configuration" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
--set 'server.ingress.extraPaths[0].path=/annotation-service' \
|
2021-10-09 00:13:21 +00:00
|
|
|
--set 'server.ingress.extraPaths[0].backend.service.name=ssl-redirect' \
|
2021-04-08 14:09:19 +00:00
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2021-04-08 14:09:19 +00:00
|
|
|
[ "${actual}" = 'ssl-redirect' ]
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
--set 'server.ingress.extraPaths[0].path=/annotation-service' \
|
2021-10-09 00:13:21 +00:00
|
|
|
--set 'server.ingress.extraPaths[0].backend.service.name=ssl-redirect' \
|
2021-04-08 14:09:19 +00:00
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].http.paths[0].path' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = '/annotation-service' ]
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.hosts[0].host=test.com' \
|
|
|
|
--set 'server.ingress.hosts[0].paths[0]=/' \
|
|
|
|
--set 'server.ingress.extraPaths[0].path=/annotation-service' \
|
2021-10-09 00:13:21 +00:00
|
|
|
--set 'server.ingress.extraPaths[0].backend.service.name=ssl-redirect' \
|
2021-04-08 14:09:19 +00:00
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].http.paths[1].path' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = '/' ]
|
|
|
|
}
|
|
|
|
|
2019-11-07 16:23:56 +00:00
|
|
|
@test "server/ingress: labels gets added to object" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
2020-02-06 16:44:38 +00:00
|
|
|
--show-only templates/server-ingress.yaml \
|
2019-11-07 16:23:56 +00:00
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.labels.traffic=external' \
|
|
|
|
--set 'server.ingress.labels.team=dev' \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.metadata.labels.traffic' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "external" ]
|
2020-02-06 16:44:38 +00:00
|
|
|
}
|
2020-03-20 15:37:40 +00:00
|
|
|
|
2020-04-27 15:28:50 +00:00
|
|
|
@test "server/ingress: annotations added to object - string" {
|
2020-03-20 15:37:40 +00:00
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.annotations=kubernetes.io/ingress.class: nginx' \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.metadata.annotations["kubernetes.io/ingress.class"]' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "nginx" ]
|
|
|
|
}
|
2020-04-27 15:28:50 +00:00
|
|
|
|
|
|
|
@test "server/ingress: annotations added to object - yaml" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set server.ingress.annotations."kubernetes\.io/ingress\.class"=nginx \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.metadata.annotations["kubernetes.io/ingress.class"]' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "nginx" ]
|
|
|
|
}
|
2020-05-28 18:51:25 +00:00
|
|
|
|
2021-10-21 16:23:45 +00:00
|
|
|
@test "server/ingress: ingressClassName added to object spec - string" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set server.ingress.ingressClassName=nginx \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.ingressClassName' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "nginx" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "server/ingress: ingressClassName is not added by default" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.ingressClassName' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "null" ]
|
|
|
|
}
|
|
|
|
|
2021-07-15 18:15:46 +00:00
|
|
|
@test "server/ingress: uses active service when ha by default - yaml" {
|
2020-05-28 18:51:25 +00:00
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.dev.enabled=false' \
|
|
|
|
--set 'server.ha.enabled=true' \
|
|
|
|
--set 'server.service.enabled=true' \
|
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2024-05-28 11:52:10 +00:00
|
|
|
[ "${actual}" = "release-name-openbao-active" ]
|
2020-05-28 18:51:25 +00:00
|
|
|
}
|
|
|
|
|
2021-07-15 18:15:46 +00:00
|
|
|
@test "server/ingress: uses regular service when configured with ha - yaml" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.activeService=false' \
|
|
|
|
--set 'server.dev.enabled=false' \
|
|
|
|
--set 'server.ha.enabled=true' \
|
|
|
|
--set 'server.service.enabled=true' \
|
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2024-05-28 11:52:10 +00:00
|
|
|
[ "${actual}" = "release-name-openbao" ]
|
2021-07-15 18:15:46 +00:00
|
|
|
}
|
|
|
|
|
2020-05-28 18:51:25 +00:00
|
|
|
@test "server/ingress: uses regular service when not ha - yaml" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.dev.enabled=false' \
|
|
|
|
--set 'server.ha.enabled=false' \
|
|
|
|
--set 'server.service.enabled=true' \
|
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2024-05-28 11:52:10 +00:00
|
|
|
[ "${actual}" = "release-name-openbao" ]
|
2021-10-09 00:13:21 +00:00
|
|
|
}
|
|
|
|
|
2024-05-28 12:20:48 +00:00
|
|
|
@test "server/ingress: k8s 1.27.0 uses correct service format when not ha - yaml" {
|
2021-10-09 00:13:21 +00:00
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.dev.enabled=false' \
|
|
|
|
--set 'server.ha.enabled=false' \
|
|
|
|
--set 'server.service.enabled=true' \
|
2024-05-28 12:20:48 +00:00
|
|
|
--kube-version 1.27.0 \
|
2021-10-09 00:13:21 +00:00
|
|
|
. | tee /dev/stderr |
|
2023-02-27 20:04:17 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2024-05-28 11:52:10 +00:00
|
|
|
[ "${actual}" = "release-name-openbao" ]
|
2021-07-15 18:15:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "server/ingress: uses regular service when not ha and activeService is true - yaml" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set 'server.ingress.activeService=true' \
|
|
|
|
--set 'server.dev.enabled=false' \
|
|
|
|
--set 'server.ha.enabled=false' \
|
|
|
|
--set 'server.service.enabled=true' \
|
|
|
|
. | tee /dev/stderr |
|
2021-10-09 00:13:21 +00:00
|
|
|
yq -r '.spec.rules[0].http.paths[0].backend.service.name' | tee /dev/stderr)
|
2024-05-28 11:52:10 +00:00
|
|
|
[ "${actual}" = "release-name-openbao" ]
|
2021-07-15 18:15:46 +00:00
|
|
|
}
|
2021-10-25 15:30:06 +00:00
|
|
|
|
2024-05-28 12:20:48 +00:00
|
|
|
@test "server/ingress: pathType is added to Kubernetes version == 1.27.0" {
|
2021-10-25 15:30:06 +00:00
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set server.ingress.pathType=ImplementationSpecific \
|
2024-05-28 12:20:48 +00:00
|
|
|
--kube-version 1.27.0 \
|
2021-10-25 15:30:06 +00:00
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].http.paths[0].pathType' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "ImplementationSpecific" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "server/ingress: pathType is added to Kubernetes versions > 1.19" {
|
|
|
|
cd `chart_dir`
|
|
|
|
|
|
|
|
local actual=$(helm template \
|
|
|
|
--show-only templates/server-ingress.yaml \
|
|
|
|
--set 'server.ingress.enabled=true' \
|
|
|
|
--set server.ingress.pathType=Prefix \
|
2024-05-28 12:20:48 +00:00
|
|
|
--kube-version 1.27.0 \
|
2021-10-25 15:30:06 +00:00
|
|
|
. | tee /dev/stderr |
|
|
|
|
yq -r '.spec.rules[0].http.paths[0].pathType' | tee /dev/stderr)
|
|
|
|
[ "${actual}" = "Prefix" ]
|
|
|
|
}
|