Skip to content

Commit

Permalink
Add Octavia volume-based Amphora test
Browse files Browse the repository at this point in the history
Enable Amphora to run instances booted from
volume by flipping the config option
`enable-volume-based-amphora` to True and
checking volumes attached to the amphora
instances.

Added version pins for py36

Depends-On: https://review.opendev.org/c/openstack/charm-octavia/+/931587
Related-Bug: https://launchpad.net/bugs/1901732
(cherry picked from commit d096096)
(cherry picked from commit f0f60a5)
(cherry picked from commit 3968c10)
(cherry picked from commit 215af1f)
(cherry picked from commit bf5f4bb)
  • Loading branch information
Nicholas Njihia authored and dosaboy committed Nov 28, 2024
1 parent 5ff0f1b commit 10793de
Show file tree
Hide file tree
Showing 4 changed files with 75 additions and 18 deletions.
5 changes: 4 additions & 1 deletion requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ juju_wait
# https://github.com/pyca/pyopenssl/commit/a145fc3bc6d2e943434beb2f04bbf9b18930296f
pyopenssl<22.1.0

macaroonbakery<=1.3.1 # needed for py36
PyYAML<=4.2,>=3.0; python_version < '3.9'
PyYAML>=5.1; python_version >= '3.9'
flake8>=2.2.4
Expand All @@ -32,7 +33,9 @@ Jinja2>=2.6 # BSD License (3 clause)
six>=1.9.0
dnspython>=1.12.0
psutil>=1.1.1,<2.0.0
python-openstackclient>=3.14.0
platformdirs<3 # needed for py36
python-openstackclient>=3.14.2,<=5.2 # needed for py36
openstacksdk<=0.61 # needed for py36
aodhclient
gnocchiclient>=7.0.5,<8.0.0
pika>=1.1.0,<2.0.0
Expand Down
17 changes: 8 additions & 9 deletions unit_tests/utilities/test_zaza_utilities_os_versions.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,12 @@
class TestOpenStackUtils(ut_utils.BaseTestCase):

def test_compare_openstack(self):
yoga = os_versions.CompareOpenStack('yoga')
xena = os_versions.CompareOpenStack('xena')
wallaby = os_versions.CompareOpenStack('wallaby')
self.assertGreater(yoga, xena)
self.assertLess(xena, yoga)
self.assertGreaterEqual(xena, xena)
self.assertGreaterEqual(yoga, yoga)
self.assertGreaterEqual(yoga, wallaby)
ussuri = os_versions.CompareOpenStack('ussuri')
train = os_versions.CompareOpenStack('train')
self.assertGreater(ussuri, train)
self.assertLess(train, ussuri)
self.assertGreaterEqual(ussuri, ussuri)
self.assertGreaterEqual(train, train)
self.assertGreaterEqual(ussuri, train)

self.assertEqual("CompareOpenStack<xena>", repr(xena))
self.assertEqual("CompareOpenStack<ussuri>", repr(ussuri))
63 changes: 56 additions & 7 deletions zaza/openstack/charm_tests/octavia/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@

"""Encapsulate octavia testing."""

import json
import logging
import subprocess
import tenacity
Expand All @@ -26,6 +27,7 @@
import zaza.openstack.utilities.openstack as openstack_utils

from zaza.openstack.utilities import ObjectRetrierWraps
from zaza.openstack.utilities.os_versions import CompareOpenStack

LBAAS_ADMIN_ROLE = 'load-balancer_admin'

Expand Down Expand Up @@ -136,12 +138,6 @@ def setUpClass(cls):
cls.keystone_client = ObjectRetrierWraps(
openstack_utils.get_keystone_session_client(cls.keystone_session))

if (openstack_utils.get_os_release() >=
openstack_utils.get_os_release('focal_wallaby')):
# add role to admin user for the duration of the test
grant_role_current_user(cls.keystone_client, cls.keystone_session,
LBAAS_ADMIN_ROLE)

cls.neutron_client = ObjectRetrierWraps(
openstack_utils.get_neutron_session_client(cls.keystone_session))
cls.octavia_client = ObjectRetrierWraps(
Expand All @@ -159,6 +155,16 @@ def setUpClass(cls):
# List of floating IPs created by this test
cls.fips = []

def setUp(self):
"""Configure the octavia test environment."""
super(LBAASv2Test, self).setUp()
if (openstack_utils.get_os_release() >=
openstack_utils.get_os_release('focal_wallaby')):
# add role to admin user for the duration of the test
grant_role_current_user(self.keystone_client,
self.keystone_session,
LBAAS_ADMIN_ROLE)

def _remove_amphorae_instances(self):
"""Remove amphorae instances forcefully.
Expand Down Expand Up @@ -189,6 +195,7 @@ def resource_cleanup(self, only_local=False):
:param only_local: When set to true do not call parent method
:type only_local: bool
"""
logging.info("deleting loadbalancer(s): {}".format(self.loadbalancers))
for lb in self.loadbalancers:
try:
self.octavia_client.load_balancer_delete(
Expand Down Expand Up @@ -384,7 +391,7 @@ def _get_payload(ip):
'http://{}/'.format(ip)],
universal_newlines=True)

def test_create_loadbalancer(self):
def create_loadbalancer(self, ensure_volume_backed=False):
"""Create load balancer."""
# Prepare payload instances
# First we allow communication to port 80 by adding a security group
Expand Down Expand Up @@ -451,5 +458,47 @@ def test_create_loadbalancer(self):
.format(snippet, provider,
lb_fp['floating_ip_address']))

if ensure_volume_backed:
amphora_list = self.octavia_client.amphora_list()
self.assertTrue(len(amphora_list) > 0)
attached_volumes = []
for amphora in amphora_list.get('amphorae', []):
server_id = amphora['compute_id']
logging.info("Checking amphora {} server {} for attached "
"volumes".format(amphora['id'], server_id))
volumes = self.nova_client.volumes.get_server_volumes(
server_id)
logging.info('amphora {} server {} has volumes={}'.
format(amphora['id'],
server_id, volumes))
attached_volumes.append(json.dumps(vars(volumes)))

self.assertTrue(len(attached_volumes) > 0)
logging.info("Amphora volumes creation successful: {}".format(
attached_volumes))

# If we get here, it means the tests passed
self.run_resource_cleanup = True

def test_create_loadbalancer(self):
"""Test creating a load balancer."""
self.create_loadbalancer()


class OctaviaVolumeBackedAmphoraTest(LBAASv2Test):
"""Octavia service tests."""

def test_volume_backed_amphora(self):
"""Test volume-backed amphora load balancer."""
os_versions = openstack_utils.get_current_os_versions(['octavia'])
if CompareOpenStack(os_versions['octavia']) < 'ussuri':
self.skipTest('Run only for Openstack Ussuri and newer releases.')
return

"""Test creating a load balancer that uses volume-based amphora."""
default_charm_config = {'enable-volume-based-amphora': False}
alternate_charm_config = {'enable-volume-based-amphora': True}
with self.config_change(default_charm_config,
alternate_charm_config, reset_to_charm_default=True):
logging.info("Testing create volume-backed amphora loadbalancer")
self.create_loadbalancer(ensure_volume_backed=True)
8 changes: 7 additions & 1 deletion zaza/openstack/utilities/os_versions.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,8 @@
('2019.2', 'train'),
('2020.1', 'ussuri'),
('2020.2', 'victoria'),
('2021.1', 'wallaby'),
('2021.2', 'xena'),
])

OPENSTACK_RELEASES_PAIRS = [
Expand Down Expand Up @@ -273,6 +275,11 @@
('3', 'ussuri'),
('4', 'victoria'),
]),
'octavia-common': OrderedDict([
('5', 'train'),
('6', 'ussuri'),
('7', 'victoria'),
]),
}


Expand Down Expand Up @@ -393,4 +400,3 @@ class CompareOpenStack(BasicStringComparator):
"""

_list = list(OPENSTACK_CODENAMES.values())

0 comments on commit 10793de

Please sign in to comment.