2019-12-20 11:35:35 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -o xtrace
|
|
|
|
set -o errexit
|
|
|
|
set -o pipefail
|
|
|
|
|
2020-04-16 12:25:07 +02:00
|
|
|
# Enable unbuffered output
|
2019-12-20 11:35:35 +01:00
|
|
|
export PYTHONUNBUFFERED=1
|
|
|
|
|
2020-11-09 10:17:10 +01:00
|
|
|
function test_ovn {
|
2020-04-17 16:46:09 +02:00
|
|
|
# NOTE(yoctozepto): could use real ini parsing but this is fine for now
|
|
|
|
local neutron_ml2_conf_path=/etc/kolla/neutron-server/ml2_conf.ini
|
|
|
|
ovn_nb_connection=$(sudo grep -P -o -e "(?<=^ovn_nb_connection = ).*" "$neutron_ml2_conf_path")
|
|
|
|
ovn_sb_connection=$(sudo grep -P -o -e "(?<=^ovn_sb_connection = ).*" "$neutron_ml2_conf_path")
|
|
|
|
|
2020-04-16 12:25:07 +02:00
|
|
|
# List OVN NB/SB entries
|
|
|
|
echo "OVN NB DB entries:"
|
2020-04-17 16:46:09 +02:00
|
|
|
sudo docker exec ovn_northd ovn-nbctl --db "$ovn_nb_connection" show
|
2020-04-16 12:25:07 +02:00
|
|
|
|
|
|
|
echo "OVN SB DB entries:"
|
2020-04-17 16:46:09 +02:00
|
|
|
sudo docker exec ovn_northd ovn-sbctl --db "$ovn_sb_connection" show
|
2020-04-16 12:25:07 +02:00
|
|
|
|
2019-12-20 11:35:35 +01:00
|
|
|
# Test OVSDB cluster state
|
|
|
|
if [[ $BASE_DISTRO =~ ^(debian|ubuntu)$ ]]; then
|
2020-04-16 12:25:07 +02:00
|
|
|
OVNNB_STATUS=$(sudo docker exec ovn_nb_db ovs-appctl -t /var/run/openvswitch/ovnnb_db.ctl cluster/status OVN_Northbound)
|
|
|
|
OVNSB_STATUS=$(sudo docker exec ovn_sb_db ovs-appctl -t /var/run/openvswitch/ovnsb_db.ctl cluster/status OVN_Southbound)
|
2019-12-20 11:35:35 +01:00
|
|
|
else
|
2020-04-16 12:25:07 +02:00
|
|
|
OVNNB_STATUS=$(sudo docker exec ovn_nb_db ovs-appctl -t /var/run/ovn/ovnnb_db.ctl cluster/status OVN_Northbound)
|
|
|
|
OVNSB_STATUS=$(sudo docker exec ovn_sb_db ovs-appctl -t /var/run/ovn/ovnsb_db.ctl cluster/status OVN_Southbound)
|
2019-12-20 11:35:35 +01:00
|
|
|
fi
|
|
|
|
|
2020-04-16 12:25:07 +02:00
|
|
|
if [[ $(grep -o "at tcp:" <<< ${OVNNB_STATUS} | wc -l) != "3" ]]; then
|
|
|
|
echo "ERR: NB Cluster does not have 3 nodes"
|
|
|
|
echo "Output: ${OVNNB_STATUS}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ $(grep -o "at tcp:" <<< ${OVNSB_STATUS} | wc -l) != "3" ]]; then
|
|
|
|
echo "ERR: SB Cluster does not have 3 nodes"
|
|
|
|
echo "Output: ${OVNSB_STATUS}"
|
|
|
|
exit 1
|
|
|
|
fi
|
2019-12-20 11:35:35 +01:00
|
|
|
}
|
|
|
|
|
2020-11-09 10:17:10 +01:00
|
|
|
function test_octavia {
|
|
|
|
. /etc/kolla/admin-openrc.sh
|
|
|
|
. ~/openstackclient-venv/bin/activate
|
|
|
|
echo "Testing OVN Octavia provider"
|
|
|
|
echo "Smoke test"
|
|
|
|
openstack loadbalancer list
|
|
|
|
|
|
|
|
# Create a server to act as a backend
|
|
|
|
openstack server create --wait --image cirros --flavor m1.tiny --key-name mykey --network demo-net lb_member --wait
|
|
|
|
member_fip=$(openstack floating ip create public1 -f value -c floating_ip_address)
|
|
|
|
openstack server add floating ip lb_member ${member_fip}
|
|
|
|
member_ip=$(openstack floating ip show ${member_fip} -f value -c fixed_ip_address)
|
|
|
|
|
|
|
|
# Dummy HTTP server.
|
|
|
|
attempts=12
|
|
|
|
for i in $(seq 1 ${attempts}); do
|
|
|
|
if ssh -v -o BatchMode=yes -o StrictHostKeyChecking=no cirros@${member_fip} 'nohup sh -c "while true; do echo -e \"HTTP/1.1 200 OK\n\n $(date)\" | sudo nc -l -p 8000; done &"'; then
|
|
|
|
break
|
|
|
|
elif [[ $i -eq ${attempts} ]]; then
|
|
|
|
echo "Failed to access server via SSH after ${attempts} attempts"
|
|
|
|
echo "Console log:"
|
|
|
|
openstack console log show lb_member
|
|
|
|
return 1
|
|
|
|
else
|
|
|
|
echo "Cannot access server - retrying"
|
|
|
|
fi
|
|
|
|
sleep 10
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "Creating Octavia OVN LB:"
|
|
|
|
openstack loadbalancer create --vip-network-id demo-net --provider ovn --name test_ovn_lb --wait
|
|
|
|
openstack loadbalancer listener create --protocol TCP --protocol-port 8000 --name test_ovn_lb_listener --wait test_ovn_lb
|
|
|
|
openstack loadbalancer pool create --protocol TCP --lb-algorithm SOURCE_IP_PORT --listener test_ovn_lb_listener --name test_ovn_lb_pool --wait
|
|
|
|
subnet_id=$(openstack subnet list -c ID -f value --name demo-subnet)
|
|
|
|
openstack loadbalancer member create --address ${member_ip} --subnet-id ${subnet_id} --protocol-port 8000 --wait test_ovn_lb_pool
|
|
|
|
echo "Add a floating IP to the load balancer."
|
|
|
|
lb_fip=$(openstack floating ip create public1 -f value -c name)
|
|
|
|
lb_vip=$(openstack loadbalancer show test_ovn_lb -f value -c vip_address)
|
|
|
|
lb_port_id=$(openstack port list --fixed-ip ip-address=$lb_vip -f value -c ID)
|
|
|
|
openstack floating ip set $lb_fip --port $lb_port_id
|
|
|
|
|
|
|
|
echo "OVN NB entries for LB:"
|
|
|
|
sudo docker exec ovn_northd ovn-nbctl --db "$ovn_nb_connection" list load_balancer
|
|
|
|
echo "OVN NB entries for NAT:"
|
|
|
|
sudo docker exec ovn_northd ovn-nbctl --db "$ovn_nb_connection" list nat
|
|
|
|
|
|
|
|
echo "Attempt to access the load balanced HTTP server."
|
|
|
|
attempts=12
|
|
|
|
curl_args=(
|
|
|
|
--include
|
|
|
|
--location
|
|
|
|
--fail
|
|
|
|
)
|
|
|
|
for i in $(seq 1 ${attempts}); do
|
|
|
|
if curl "${curl_args[@]}" $lb_fip:8000; then
|
|
|
|
break
|
|
|
|
elif [[ $i -eq ${attempts} ]]; then
|
|
|
|
echo "Failed to access load balanced service after ${attempts} attempts"
|
|
|
|
return 1
|
|
|
|
else
|
|
|
|
echo "Cannot access load balancer - retrying"
|
|
|
|
fi
|
|
|
|
sleep 10
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "Cleaning up"
|
|
|
|
openstack loadbalancer delete test_ovn_lb --cascade --wait
|
|
|
|
openstack floating ip delete ${lb_fip}
|
|
|
|
openstack server remove floating ip lb_member ${member_fip}
|
|
|
|
openstack floating ip delete ${member_fip}
|
|
|
|
openstack server delete --wait lb_member
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_ovn_logged {
|
|
|
|
test_ovn
|
|
|
|
test_octavia
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_ovn_setup {
|
|
|
|
echo "Testing OVN and Octavia OVN provider"
|
|
|
|
test_ovn_logged &> /tmp/logs/ansible/test-ovn
|
2019-12-20 11:35:35 +01:00
|
|
|
result=$?
|
|
|
|
if [[ $result != 0 ]]; then
|
|
|
|
echo "Testing OVN failed. See ansible/test-ovn for details"
|
|
|
|
else
|
|
|
|
echo "Successfully tested OVN. See ansible/test-ovn for details"
|
|
|
|
fi
|
|
|
|
return $result
|
|
|
|
}
|
|
|
|
|
2020-11-09 10:17:10 +01:00
|
|
|
|
|
|
|
|
|
|
|
test_ovn_setup
|