Fix broken Tempest conf options in API tests
Tempest commit ed6e586b9f8f0ada10af7711f297afa01b2b7754
changed configuration options defined in Tempest from
tenant to project. Currently we use Tempest from PyPI,
and since there hasn't yet been a Tempest release with
the change that breaks us, we're still safe, however the
next release will break us, so let's be ready for it.
Long term I think the correct thing to do would be to
define new options used exclusively in the Neutron tree.
Change-Id: I054b94a43d900e42872a9cb28d33a3ed45e14779
diff --git a/neutron/tests/tempest/config.py b/neutron/tests/tempest/config.py
index 08b235a..f50fa39 100644
--- a/neutron/tests/tempest/config.py
+++ b/neutron/tests/tempest/config.py
@@ -14,6 +14,7 @@
from tempest import config
+
CONF = config.CONF
@@ -27,3 +28,20 @@
# transition to the Tempest plugin architecture
for opt in NeutronPluginOptions:
CONF.register_opt(opt, 'neutron_plugin_options')
+
+
+config_opts_translator = {
+ 'project_network_cidr': 'tenant_network_cidr',
+ 'project_network_v6_cidr': 'tenant_network_v6_cidr',
+ 'project_network_mask_bits': 'tenant_network_mask_bits',
+ 'project_network_v6_mask_bits': 'tenant_network_v6_mask_bits'}
+
+
+def safe_get_config_value(group, name):
+ """Safely get Oslo config opts from Tempest, using old and new names."""
+ conf_group = getattr(CONF, group)
+
+ try:
+ return getattr(conf_group, name)
+ except cfg.NoSuchOptError:
+ return getattr(conf_group, config_opts_translator[name])