Merge "tests: Simplify catalog functional tests"
This commit is contained in:
@@ -10,35 +10,54 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
|
||||||
from openstackclient.tests.functional.identity.v3 import common
|
from openstackclient.tests.functional.identity.v3 import common
|
||||||
|
|
||||||
|
|
||||||
class CatalogTests(common.IdentityTests):
|
class CatalogTests(common.IdentityTests):
|
||||||
def test_catalog_list(self):
|
"""Functional tests for catalog commands"""
|
||||||
|
|
||||||
|
def test_catalog(self):
|
||||||
|
"""Test catalog list and show functionality"""
|
||||||
|
# Create a test service for isolated testing
|
||||||
|
_dummy_service_name = self._create_dummy_service(add_clean_up=True)
|
||||||
|
|
||||||
|
# list catalogs
|
||||||
raw_output = self.openstack('catalog list')
|
raw_output = self.openstack('catalog list')
|
||||||
items = self.parse_listing(raw_output)
|
items = self.parse_listing(raw_output)
|
||||||
self.assert_table_structure(items, ['Name', 'Type', 'Endpoints'])
|
self.assert_table_structure(items, ['Name', 'Type', 'Endpoints'])
|
||||||
|
|
||||||
def test_catalog_show(self):
|
# Verify created service appears in catalog
|
||||||
"""test catalog show command
|
service_names = [
|
||||||
|
item.get('Name') for item in items if item.get('Name')
|
||||||
|
]
|
||||||
|
self.assertIn(
|
||||||
|
_dummy_service_name,
|
||||||
|
service_names,
|
||||||
|
"Created dummy service should be present in catalog",
|
||||||
|
)
|
||||||
|
|
||||||
The output example:
|
# show service (by name)
|
||||||
+-----------+----------------------------------------+
|
raw_output = self.openstack(f'catalog show {_dummy_service_name}')
|
||||||
| Field | Value |
|
|
||||||
+-----------+----------------------------------------+
|
|
||||||
| endpoints | test1 |
|
|
||||||
| | public: http://localhost:5000/v2.0 |
|
|
||||||
| | test1 |
|
|
||||||
| | internal: http://localhost:5000/v2.0 |
|
|
||||||
| | test1 |
|
|
||||||
| | admin: http://localhost:35357/v2.0 |
|
|
||||||
| | |
|
|
||||||
| id | e1e68b5ba21a43a39ff1cf58e736c3aa |
|
|
||||||
| name | keystone |
|
|
||||||
| type | identity |
|
|
||||||
+-----------+----------------------------------------+
|
|
||||||
"""
|
|
||||||
raw_output = self.openstack('catalog show {}'.format('identity'))
|
|
||||||
items = self.parse_show(raw_output)
|
items = self.parse_show(raw_output)
|
||||||
# items may have multiple endpoint urls with empty key
|
self.assert_show_fields(items, ['endpoints', 'name', 'type', 'id'])
|
||||||
self.assert_show_fields(items, ['endpoints', 'name', 'type', '', 'id'])
|
|
||||||
|
# Extract the type from the dummy service
|
||||||
|
_dummy_service_type = next(
|
||||||
|
(item['type'] for item in items if 'type' in item), None
|
||||||
|
)
|
||||||
|
|
||||||
|
# show service (by type)
|
||||||
|
raw_output = self.openstack(f'catalog show {_dummy_service_type}')
|
||||||
|
items = self.parse_show(raw_output)
|
||||||
|
self.assert_show_fields(items, ['endpoints', 'name', 'type', 'id'])
|
||||||
|
|
||||||
|
# show service (non-existent)
|
||||||
|
result = self.openstack(
|
||||||
|
'catalog show nonexistent-service-xyz', fail_ok=True
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'',
|
||||||
|
result.strip(),
|
||||||
|
"Non-existent service should return empty result",
|
||||||
|
)
|
||||||
|
Reference in New Issue
Block a user