Allow inventory filtering by cloud name
In some cases only one cloud is in scope for the ansible inventory, this patch enables that workflow. Co-Authored-By: David Shrewsbury <shrewsbury.dave@gmail.com> Change-Id: Ie2a1fc91878c282daaa75e4fc8aeee19f87c3020
This commit is contained in:
parent
59d9135bab
commit
53187f2a53
@ -40,6 +40,8 @@ def parse_args():
|
||||
group.add_argument('--host', help='List details about the specific host')
|
||||
parser.add_argument('--private', action='store_true', default=False,
|
||||
help='Use private IPs for interface_ip')
|
||||
parser.add_argument('--cloud', default=None,
|
||||
help='Return data for one cloud only')
|
||||
parser.add_argument('--yaml', action='store_true', default=False,
|
||||
help='Output data in nicely readable yaml')
|
||||
parser.add_argument('--debug', action='store_true', default=False,
|
||||
@ -52,7 +54,8 @@ def main():
|
||||
try:
|
||||
shade.simple_logging(debug=args.debug)
|
||||
inventory = shade.inventory.OpenStackInventory(
|
||||
refresh=args.refresh, private=args.private)
|
||||
refresh=args.refresh, private=args.private,
|
||||
cloud=args.cloud)
|
||||
if args.list:
|
||||
output = inventory.list_hosts()
|
||||
elif args.host:
|
||||
|
@ -28,7 +28,7 @@ class OpenStackInventory(object):
|
||||
|
||||
def __init__(
|
||||
self, config_files=None, refresh=False, private=False,
|
||||
config_key=None, config_defaults=None):
|
||||
config_key=None, config_defaults=None, cloud=None):
|
||||
if config_files is None:
|
||||
config_files = []
|
||||
config = os_client_config.config.OpenStackConfig(
|
||||
@ -36,10 +36,19 @@ class OpenStackInventory(object):
|
||||
self.extra_config = config.get_extra_config(
|
||||
config_key, config_defaults)
|
||||
|
||||
self.clouds = [
|
||||
shade.OpenStackCloud(cloud_config=cloud_config)
|
||||
for cloud_config in config.get_all_clouds()
|
||||
]
|
||||
if cloud is None:
|
||||
self.clouds = [
|
||||
shade.OpenStackCloud(cloud_config=cloud_config)
|
||||
for cloud_config in config.get_all_clouds()
|
||||
]
|
||||
else:
|
||||
try:
|
||||
self.clouds = [
|
||||
shade.OpenStackCloud(
|
||||
cloud_config=config.get_one_cloud(cloud))
|
||||
]
|
||||
except os_client_config.exceptions.OpenStackConfigException as e:
|
||||
raise shade.OpenStackCloudException(e)
|
||||
|
||||
if private:
|
||||
for cloud in self.clouds:
|
||||
|
@ -16,7 +16,10 @@
|
||||
import mock
|
||||
import os_client_config
|
||||
|
||||
from os_client_config import exceptions as occ_exc
|
||||
|
||||
from shade import _utils
|
||||
from shade import exc
|
||||
from shade import inventory
|
||||
from shade import meta
|
||||
from shade.tests import fakes
|
||||
@ -42,6 +45,38 @@ class TestInventory(base.TestCase):
|
||||
self.assertEqual(1, len(inv.clouds))
|
||||
self.assertTrue(mock_config.return_value.get_all_clouds.called)
|
||||
|
||||
@mock.patch("os_client_config.config.OpenStackConfig")
|
||||
@mock.patch("shade.OpenStackCloud")
|
||||
def test__init_one_cloud(self, mock_cloud, mock_config):
|
||||
mock_config.return_value.get_one_cloud.return_value = [{}]
|
||||
|
||||
inv = inventory.OpenStackInventory(cloud='supercloud')
|
||||
|
||||
mock_config.assert_called_once_with(
|
||||
config_files=os_client_config.config.CONFIG_FILES
|
||||
)
|
||||
self.assertIsInstance(inv.clouds, list)
|
||||
self.assertEqual(1, len(inv.clouds))
|
||||
self.assertFalse(mock_config.return_value.get_all_clouds.called)
|
||||
mock_config.return_value.get_one_cloud.assert_called_once_with(
|
||||
'supercloud')
|
||||
|
||||
@mock.patch("os_client_config.config.OpenStackConfig")
|
||||
@mock.patch("shade.OpenStackCloud")
|
||||
def test__raise_exception_on_no_cloud(self, mock_cloud, mock_config):
|
||||
"""
|
||||
Test that when os-client-config can't find a named cloud, a
|
||||
shade exception is emitted.
|
||||
"""
|
||||
mock_config.return_value.get_one_cloud.side_effect = (
|
||||
occ_exc.OpenStackConfigException()
|
||||
)
|
||||
self.assertRaises(exc.OpenStackCloudException,
|
||||
inventory.OpenStackInventory,
|
||||
cloud='supercloud')
|
||||
mock_config.return_value.get_one_cloud.assert_called_once_with(
|
||||
'supercloud')
|
||||
|
||||
@mock.patch("os_client_config.config.OpenStackConfig")
|
||||
@mock.patch("shade.OpenStackCloud")
|
||||
def test_list_hosts(self, mock_cloud, mock_config):
|
||||
|
Loading…
x
Reference in New Issue
Block a user