Merge "Process subordinate releases packages map"

This commit is contained in:
Zuul 2021-09-29 12:46:21 +00:00 committed by Gerrit Code Review
commit f32f3b735c
3 changed files with 57 additions and 18 deletions

4
bindep.txt Normal file
View File

@ -0,0 +1,4 @@
libxml2-dev [platform:dpkg test]
libxslt1-dev [platform:dpkg test]
build-essential [platform:dpkg test]
zlib1g-dev [platform:dpkg test]

View File

@ -97,6 +97,7 @@ from charmhelpers.contrib.openstack import (
from charmhelpers.contrib.openstack.utils import ( from charmhelpers.contrib.openstack.utils import (
configure_installation_source, configure_installation_source,
get_os_codename_install_source, get_os_codename_install_source,
get_subordinate_release_packages,
os_release, os_release,
reset_os_release, reset_os_release,
make_assess_status_func, make_assess_status_func,
@ -389,13 +390,17 @@ def determine_packages():
pkgs.extend(token_cache_pkgs(source=config()['openstack-origin'])) pkgs.extend(token_cache_pkgs(source=config()['openstack-origin']))
if CompareOpenStackReleases(os_release('cinder')) >= 'rocky': release = os_release('cinder')
if CompareOpenStackReleases(release) >= 'rocky':
pkgs = [p for p in pkgs if not p.startswith('python-')] pkgs = [p for p in pkgs if not p.startswith('python-')]
pkgs.extend(PY3_PACKAGES) pkgs.extend(PY3_PACKAGES)
if service_enabled('api'): if service_enabled('api'):
pkgs.extend(PY3_API_PACKAGES) pkgs.extend(PY3_API_PACKAGES)
return pkgs pkgs = set(pkgs).union(get_subordinate_release_packages(
release).install)
return sorted(pkgs)
def determine_purge_packages(): def determine_purge_packages():
@ -405,12 +410,16 @@ def determine_purge_packages():
:returns: list of package names :returns: list of package names
''' '''
if CompareOpenStackReleases(os_release('cinder')) >= 'rocky': pkgs = []
release = os_release('cinder')
if CompareOpenStackReleases(release) >= 'rocky':
pkgs = [p for p in COMMON_PACKAGES if p.startswith('python-')] pkgs = [p for p in COMMON_PACKAGES if p.startswith('python-')]
pkgs.append('python-cinder') pkgs.append('python-cinder')
pkgs.append('python-memcache') pkgs.append('python-memcache')
return pkgs
return [] pkgs = set(pkgs).union(
get_subordinate_release_packages(release).purge)
return sorted(pkgs)
def remove_old_packages(): def remove_old_packages():

View File

@ -127,21 +127,31 @@ class TestCinderUtils(CharmTestCase):
self.test_config.set('enabled-services', 'api,scheduler') self.test_config.set('enabled-services', 'api,scheduler')
self.assertFalse(cinder_utils.service_enabled('volume')) self.assertFalse(cinder_utils.service_enabled('volume'))
def test_determine_purge_packages(self): @patch.object(cinder_utils, 'get_subordinate_release_packages')
def test_determine_purge_packages(
self,
mock_get_subordinate_release_packages):
'Ensure no packages are identified for purge prior to rocky' 'Ensure no packages are identified for purge prior to rocky'
self.os_release.return_value = 'queens' self.os_release.return_value = 'queens'
self.assertEqual(cinder_utils.determine_purge_packages(), []) self.assertEqual(cinder_utils.determine_purge_packages(), [])
def test_determine_purge_packages_rocky(self): @patch.object(cinder_utils, 'get_subordinate_release_packages')
def test_determine_purge_packages_rocky(
self,
mock_get_subordinate_release_packages):
'Ensure python packages are identified for purge at rocky' 'Ensure python packages are identified for purge at rocky'
self.os_release.return_value = 'rocky' self.os_release.return_value = 'rocky'
self.assertEqual(cinder_utils.determine_purge_packages(), self.assertEqual(cinder_utils.determine_purge_packages(),
[p for p in cinder_utils.COMMON_PACKAGES sorted(set([p for p in cinder_utils.COMMON_PACKAGES
if p.startswith('python-')] + if p.startswith('python-')] +
['python-cinder', 'python-memcache']) ['python-cinder', 'python-memcache'])))
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch('cinder_utils.service_enabled') @patch('cinder_utils.service_enabled')
def test_determine_packages_all(self, service_enabled): def test_determine_packages_all(
self,
service_enabled,
mock_get_subordinate_release_packages):
'It determines all packages required when all services enabled' 'It determines all packages required when all services enabled'
service_enabled.return_value = True service_enabled.return_value = True
self.os_release.return_value = 'icehouse' self.os_release.return_value = 'icehouse'
@ -152,8 +162,12 @@ class TestCinderUtils(CharmTestCase):
cinder_utils.API_PACKAGES + cinder_utils.API_PACKAGES +
cinder_utils.SCHEDULER_PACKAGES)) cinder_utils.SCHEDULER_PACKAGES))
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch('cinder_utils.service_enabled') @patch('cinder_utils.service_enabled')
def test_determine_packages_all_rocky(self, service_enabled): def test_determine_packages_all_rocky(
self,
service_enabled,
mock_get_subordinate_release_packages):
'Check python3 packages are installed @ rocky' 'Check python3 packages are installed @ rocky'
service_enabled.return_value = True service_enabled.return_value = True
self.os_release.return_value = 'rocky' self.os_release.return_value = 'rocky'
@ -168,8 +182,10 @@ class TestCinderUtils(CharmTestCase):
cinder_utils.PY3_PACKAGES + cinder_utils.PY3_PACKAGES +
cinder_utils.PY3_API_PACKAGES)) cinder_utils.PY3_API_PACKAGES))
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch('cinder_utils.service_enabled') @patch('cinder_utils.service_enabled')
def test_determine_packages_subset(self, service_enabled): def test_determine_packages_subset(self, service_enabled,
mock_get_subordinate_release_packages):
'It determines packages required for a subset of enabled services' 'It determines packages required for a subset of enabled services'
service_enabled.side_effect = self.svc_enabled service_enabled.side_effect = self.svc_enabled
self.test_config.set('openstack-origin', 'cloud:xenial-newton') self.test_config.set('openstack-origin', 'cloud:xenial-newton')
@ -771,13 +787,15 @@ class TestCinderUtils(CharmTestCase):
out.write('env CEPH_ARGS="--id %s"\n' % service) out.write('env CEPH_ARGS="--id %s"\n' % service)
""" """
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch.object(cinder_utils, 'service_enabled') @patch.object(cinder_utils, 'service_enabled')
@patch.object(cinder_utils, 'register_configs') @patch.object(cinder_utils, 'register_configs')
@patch.object(cinder_utils, 'services') @patch.object(cinder_utils, 'services')
@patch.object(cinder_utils, 'migrate_database') @patch.object(cinder_utils, 'migrate_database')
@patch.object(cinder_utils, 'determine_packages') @patch.object(cinder_utils, 'determine_packages')
def test_openstack_upgrade_leader(self, pkgs, migrate, services, def test_openstack_upgrade_leader(self, pkgs, migrate, services,
mock_register_configs, service_enabled): mock_register_configs, service_enabled,
mock_get_subordinate_release_packages):
pkgs.return_value = ['mypackage'] pkgs.return_value = ['mypackage']
self.os_release.return_value = 'havana' self.os_release.return_value = 'havana'
self.config.side_effect = None self.config.side_effect = None
@ -796,14 +814,20 @@ class TestCinderUtils(CharmTestCase):
configs.set_release.assert_called_with(openstack_release='havana') configs.set_release.assert_called_with(openstack_release='havana')
self.assertTrue(migrate.called) self.assertTrue(migrate.called)
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch.object(cinder_utils, 'service_enabled') @patch.object(cinder_utils, 'service_enabled')
@patch.object(cinder_utils, 'register_configs') @patch.object(cinder_utils, 'register_configs')
@patch.object(cinder_utils, 'services') @patch.object(cinder_utils, 'services')
@patch.object(cinder_utils, 'migrate_database') @patch.object(cinder_utils, 'migrate_database')
@patch.object(cinder_utils, 'determine_packages') @patch.object(cinder_utils, 'determine_packages')
def test_openstack_upgrade_not_leader(self, pkgs, migrate, services, def test_openstack_upgrade_not_leader(
self,
pkgs,
migrate,
services,
mock_register_configs, mock_register_configs,
service_enabled): service_enabled,
mock_get_subordinate_release_packages):
pkgs.return_value = ['mypackage'] pkgs.return_value = ['mypackage']
self.os_release.return_value = 'havana' self.os_release.return_value = 'havana'
self.config.side_effect = None self.config.side_effect = None
@ -822,6 +846,7 @@ class TestCinderUtils(CharmTestCase):
configs.set_release.assert_called_with(openstack_release='havana') configs.set_release.assert_called_with(openstack_release='havana')
self.assertFalse(migrate.called) self.assertFalse(migrate.called)
@patch.object(cinder_utils, 'get_subordinate_release_packages')
@patch.object(cinder_utils, 'service_enabled') @patch.object(cinder_utils, 'service_enabled')
@patch.object(cinder_utils, 'register_configs') @patch.object(cinder_utils, 'register_configs')
@patch.object(cinder_utils, 'services') @patch.object(cinder_utils, 'services')
@ -829,7 +854,8 @@ class TestCinderUtils(CharmTestCase):
@patch.object(cinder_utils, 'determine_packages') @patch.object(cinder_utils, 'determine_packages')
def test_openstack_upgrade_rocky(self, pkgs, migrate, services, def test_openstack_upgrade_rocky(self, pkgs, migrate, services,
mock_register_configs, mock_register_configs,
service_enabled): service_enabled,
mock_get_subordinate_release_packages):
pkgs.return_value = ['mypackage'] pkgs.return_value = ['mypackage']
self.os_release.return_value = 'rocky' self.os_release.return_value = 'rocky'
self.config.side_effect = None self.config.side_effect = None