Skip to content

Commit

Permalink
Pre-allocate func test vip ports
Browse files Browse the repository at this point in the history
Resolves: canonical#269
  • Loading branch information
dosaboy committed Oct 8, 2024
1 parent 539b701 commit 8f87b21
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 4 deletions.
16 changes: 13 additions & 3 deletions openstack/tools/charmed_openstack_functest_runner.sh
Original file line number Diff line number Diff line change
Expand Up @@ -138,9 +138,19 @@ OAM_MAX=$(ipcalc $CIDR_OAM| awk '$1=="HostMax:" {print $2}')
OAM_MIN=$(ipcalc $CIDR_OAM| awk '$1=="HostMin:" {print $2}')
OAM_MIN_ABC=${OAM_MIN%.*}
OAM_MAX_D=${OAM_MAX##*.}
# Picking last two addresses and hoping they dont get used by Neutron.
export {OS,TEST}_VIP00=${OAM_MIN_ABC}.$(($OAM_MAX_D - 1))
export {OS,TEST}_VIP01=${OAM_MIN_ABC}.$(($OAM_MAX_D - 2))

NUM_VIPS=2
for ((i=$NUM_VIPS;i;i-=1)); do
vip_port_name=zaza-vip-port-$((i-1))
vip_addr=$(openstack port show -c fixed_ips $vip_port_name -f yaml| yq .fixed_ips[0].ip_address)
if [[ $vip_addr = null ]]; then
vip_addr=${OAM_MIN_ABC}.$(($OAM_MAX_D - $i))
# Pre-allocate ports with addresses used for VIPs so that they don't
# collide with the deployment itself.
allocate_port $vip_addr net_${OS_USERNAME}-psd $vip_port_name
fi
export {OS,TEST}_VIP0$((i-1))=$vip_addr
done

# More information on config https://github.com/openstack-charmers/zaza/blob/master/doc/source/runningcharmtests.rst
export {,TEST_}NET_ID=$(openstack network show net_${OS_USERNAME}-psd-extra -f value -c id)
Expand Down
11 changes: 10 additions & 1 deletion openstack/tools/func_test_tools/common.sh
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,13 @@ apply_func_test_pr ()
-f './test-requirements*.txt' \
-f './src/test-requirements*.txt' \
"$msg"
}
}

allocate_port ()
{
local addr=$1
local net_name=$2
local port_name=$3
openstack port create --network $net_name --fixed-ip ip-address=$addr \
$port_name
}

0 comments on commit 8f87b21

Please sign in to comment.