Make SKIPPED_IMAGES more flexible

With introduction of new architectures, it seems reasonable to allow
skipping of images based on their architecture.
Additionally, the existing framework had unneccessary duplication.
This commit makes the feature more flexible and cleaner.
Existing skips have been programmatically rewritten.

Change-Id: I34c002a0ee605ca121d9d923b256e4fe1ea3d9aa
Signed-off-by: Radosław Piliszek <radoslaw.piliszek@gmail.com>
This commit is contained in:
Radosław Piliszek 2019-06-13 13:38:34 +02:00
parent 8690768880
commit be54999eb1
2 changed files with 48 additions and 80 deletions

View File

@ -76,9 +76,15 @@ STATUS_SKIPPED = 'skipped'
STATUS_ERRORS = (STATUS_CONNECTION_ERROR, STATUS_PUSH_ERROR, STATUS_ERRORS = (STATUS_CONNECTION_ERROR, STATUS_PUSH_ERROR,
STATUS_ERROR, STATUS_PARENT_ERROR) STATUS_ERROR, STATUS_PARENT_ERROR)
# The dictionary of skipped images supports keys in the format:
# '<distro>+<installation_type>+<arch>' where each component is optional
# and can be omitted along with the + separator which means that component
# is irrelevant. Otherwise all must match for skip to happen.
SKIPPED_IMAGES = { SKIPPED_IMAGES = {
'centos+binary': [ 'source': {
"tripleoclient",
},
'binary': {
"almanach-base", "almanach-base",
"bifrost-base", "bifrost-base",
"blazar-base", "blazar-base",
@ -90,115 +96,65 @@ SKIPPED_IMAGES = {
"monasca-base", "monasca-base",
"monasca-thresh", "monasca-thresh",
"nova-mksproxy", "nova-mksproxy",
"ovsdpdk",
"qinling-base", "qinling-base",
"searchlight-base", "searchlight-base",
"solum-base", "solum-base",
"vmtp", "vmtp",
"zun-base", "zun-base",
], },
'centos+source': [
'centos': {
"ovsdpdk", "ovsdpdk",
"tripleoclient", },
], 'oraclelinux': {
'ubuntu+binary': [ "ovsdpdk",
"almanach-base", },
"bifrost-base", 'debian': {
"blazar-base", "sensu-base",
},
'ubuntu': {
"qdrouterd", # There is no qdrouterd package for ubuntu bionic
},
'debian+binary': {
"cloudkitty-base", "cloudkitty-base",
"congress-base", "congress-base",
"cyborg-base",
"dragonflow-base",
"ec2-api", "ec2-api",
"freezer-base",
"heat-all", "heat-all",
"ironic-neutron-agent", "ironic-neutron-agent",
"karbor-base",
"kuryr-base",
"mistral-event-engine", "mistral-event-engine",
"monasca-base",
"monasca-thresh",
"nova-mksproxy",
"novajoin-base", "novajoin-base",
"octavia-base", "octavia-base",
# There is no qdrouterd package for ubuntu bionic
"qdrouterd",
"qinling-base",
"searchlight-base",
"solum-base",
"tacker-base", "tacker-base",
"tripleoclient", "tripleoclient",
"vitrage-base", "vitrage-base",
"vmtp",
"zaqar", "zaqar",
"zun-base", },
], 'debian+source': {
'ubuntu+source': [
"cyborg-base", "cyborg-base",
# There is no qdrouterd package for ubuntu bionic },
"qdrouterd",
"tripleoclient", 'oraclelinux+source': {
],
'debian+binary': [
"almanach-base",
"bifrost-base", "bifrost-base",
"blazar-base", },
'ubuntu+binary': {
"cloudkitty-base", "cloudkitty-base",
"congress-base", "congress-base",
"cyborg-base",
"dragonflow-base",
"ec2-api", "ec2-api",
"freezer-base",
"heat-all", "heat-all",
"ironic-neutron-agent", "ironic-neutron-agent",
"karbor-base",
"kuryr-base",
"mistral-event-engine", "mistral-event-engine",
"monasca-base",
"monasca-thresh",
"nova-mksproxy",
"novajoin-base", "novajoin-base",
"octavia-base", "octavia-base",
"qinling-base",
"searchlight-base",
"sensu-base",
"solum-base",
"tacker-base", "tacker-base",
"tripleoclient", "tripleoclient",
"vitrage-base", "vitrage-base",
"vmtp",
"zaqar", "zaqar",
"zun-base" },
], 'ubuntu+source': {
'debian+source': [
"cyborg-base", "cyborg-base",
"sensu-base", },
"tripleoclient",
],
'oraclelinux+binary': [
"almanach-base",
"bifrost-base",
"blazar-base",
"cyborg-base",
"dragonflow-base",
"freezer-base",
"karbor-base",
"kuryr-base",
"monasca-base",
"monasca-thresh",
"nova-mksproxy",
"ovsdpdk",
"qinling-base",
"searchlight-base",
"solum-base",
"vmtp",
"zun-base"
],
'oraclelinux+source': [
"bifrost-base",
"ovsdpdk",
"tripleoclient",
]
} }
@ -1035,8 +991,15 @@ class KollaWorker(object):
for image in self.images: for image in self.images:
image.status = STATUS_MATCHED image.status = STATUS_MATCHED
skipped_images = SKIPPED_IMAGES.get('%s+%s' % (self.base, # Unmatch (skip) unsupported images
self.install_type)) tag_element = r'(%s|%s|%s)' % (self.base,
self.install_type,
self.base_arch)
tag_re = re.compile(r'^%s(\+%s)*$' % (tag_element, tag_element))
skipped_images = set()
for set_tag in SKIPPED_IMAGES:
if tag_re.match(set_tag):
skipped_images.update(SKIPPED_IMAGES[set_tag])
if skipped_images: if skipped_images:
for image in self.images: for image in self.images:
if image.name in skipped_images: if image.name in skipped_images:

View File

@ -0,0 +1,5 @@
---
features:
- |
Kolla skipped images feature is now more flexible, allowing filtering
based on used image distribution, installation type and processor architecture.