Skip to content

Commit

Permalink
Make sure we don't mask LB tests failures and fix what was failing (#…
Browse files Browse the repository at this point in the history
…2360) (#2430)

* Fix shared LBs tests

PR #2190 prohibited sharing an LB that is internal for security reasons.
This commit fixes the shared LBs tests to not create internal LBs.

* Make sure we don't mask LB tests failures

In `test-lb-service.sh` we do `trap "delete_resources" EXIT` to make
sure we cleanup resources on a test failure. In there, we only fetched
the `$?` after making a check for `${AUTO_CLEAN_UP}`, which itself
alters the code to 0, so function always returns success. This means
tests can never really fail.

This commit fixes it by making sure `$ERROR_CODE` is fetched at the very
beginning of the cleanup function.

Co-authored-by: Michal Dulko <[email protected]>
  • Loading branch information
k8s-infra-cherrypick-robot and dulek authored Oct 16, 2023
1 parent faaf4ea commit b32e73a
Showing 1 changed file with 22 additions and 8 deletions.
30 changes: 22 additions & 8 deletions tests/e2e/cloudprovider/test-lb-service.sh
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,12 @@ LB_SUBNET_NAME=${LB_SUBNET_NAME:-"private-subnet"}
AUTO_CLEAN_UP=${AUTO_CLEAN_UP:-"true"}

function delete_resources() {
ERROR_CODE="$?"

if [[ ${AUTO_CLEAN_UP} != "true" ]]; then
exit ${ERROR_CODE}
fi

ERROR_CODE="$?"

printf "\n>>>>>>> Deleting k8s services\n"
kubectl -n ${NAMESPACE} get svc -o name | xargs -r kubectl -n $NAMESPACE delete
printf "\n>>>>>>> Deleting k8s deployments\n"
Expand All @@ -34,6 +34,12 @@ function delete_resources() {
printf "\n>>>>>>> Deleting openstack load balancer \n"
openstack loadbalancer delete test_shared_user_lb --cascade

printf "\n>>>>>>> Deleting openstack FIPs \n"
fips=$(openstack floating ip list --tag occm-test -f value -c ID)
for fip in $fips; do
openstack floating ip delete ${fip}
done

if [[ "$ERROR_CODE" != "0" ]]; then
printf "\n>>>>>>> Dump openstack-cloud-controller-manager logs \n"
pod_name=$(kubectl -n kube-system get pod -l k8s-app=openstack-cloud-controller-manager -o name | awk 'NR==1 {print}')
Expand Down Expand Up @@ -438,7 +444,6 @@ metadata:
name: ${service1}
namespace: $NAMESPACE
annotations:
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
spec:
type: LoadBalancer
Expand Down Expand Up @@ -474,7 +479,6 @@ metadata:
name: ${service2}
namespace: $NAMESPACE
annotations:
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
loadbalancer.openstack.org/load-balancer-id: "$lbID"
spec:
Expand Down Expand Up @@ -521,7 +525,6 @@ metadata:
name: ${service2}
namespace: $NAMESPACE
annotations:
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
loadbalancer.openstack.org/load-balancer-id: "$lbID"
spec:
Expand Down Expand Up @@ -580,7 +583,6 @@ metadata:
name: ${service3}
namespace: $NAMESPACE
annotations:
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
loadbalancer.openstack.org/load-balancer-id: "$lbID"
spec:
Expand Down Expand Up @@ -614,7 +616,6 @@ metadata:
name: ${service4}
namespace: $NAMESPACE
annotations:
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
loadbalancer.openstack.org/load-balancer-id: "$lbID"
spec:
Expand Down Expand Up @@ -725,6 +726,20 @@ function test_shared_user_lb {
printf "\n>>>>>>> Waiting for openstack load balancer $lbID ACTIVE after creating listener \n"
wait_for_loadbalancer $lbID

printf "\n>>>>>>> Getting an external network \n"
extNetID=$(openstack network list --external -f value -c ID | head -1)
if [[ -z extNetID ]]; then
printf "\n>>>>>>> FAIL: failed to find an external network\n"
exit 1
fi
fip=$(openstack floating ip create --tag occm-test -f value -c id ${extNetID})
if [ $? -ne 0 ]; then
printf "\n>>>>>>> FAIL: failed to create FIP\n"
exit 1
fi
vip=$(openstack loadbalancer show $lbID -f value -c vip_port_id)
openstack floating ip set --port ${vip} ${fip}

local service1="test-shared-user-lb"
printf "\n>>>>>>> Create Service ${service1}\n"
cat <<EOF | kubectl apply -f -
Expand All @@ -735,7 +750,6 @@ metadata:
namespace: $NAMESPACE
annotations:
loadbalancer.openstack.org/load-balancer-id: "$lbID"
service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
loadbalancer.openstack.org/enable-health-monitor: "false"
spec:
type: LoadBalancer
Expand Down

0 comments on commit b32e73a

Please sign in to comment.