Merge "identity: Migrate 'endpoint' commands to SDK"

This commit is contained in:
Zuul 2025-04-01 10:55:58 +00:00 committed by Gerrit Code Review
commit 6e89f9da63
4 changed files with 288 additions and 267 deletions
openstackclient
identity
tests/unit/identity/v3
releasenotes/notes

@ -88,23 +88,22 @@ def find_service_sdk(identity_client, name_type_or_id):
raise exceptions.CommandError(e.message) raise exceptions.CommandError(e.message)
# search for service type # search for service type
services = identity_client.services() services = identity_client.services(type=name_type_or_id)
result = None try:
for service in services: service = next(services)
if name_type_or_id == service.type: except StopIteration:
if result: msg = _(
msg = _( "No service with a type, name or ID of '%(query)s' exists."
"Multiple service matches found for '%s', " ) % {"query": name_type_or_id}
"use an ID or name to be more specific." raise exceptions.CommandError(msg)
)
raise exceptions.CommandError(msg % name_type_or_id)
result = service
if result is None: if next(services, None):
msg = _("No service with a type, name or ID of '%s' exists.") msg = _(
raise exceptions.CommandError(msg % name_type_or_id) "Multiple service matches found for '%(query)s', use an ID to be more specific."
) % {"query": name_type_or_id}
raise exceptions.CommandError(msg)
return result return service
def get_resource(manager, name_type_or_id): def get_resource(manager, name_type_or_id):

@ -28,11 +28,31 @@ from openstackclient.identity import common
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
def get_service_name(service): def _format_endpoint(endpoint, service):
if hasattr(service, 'name'): columns = (
return service.name 'is_enabled',
else: 'id',
return '' 'interface',
'region_id',
'region_id',
'service_id',
'url',
)
column_headers = (
'enabled',
'id',
'interface',
'region',
'region_id',
'service_id',
'url',
'service_name',
'service_type',
)
data = utils.get_item_properties(endpoint, columns)
data += (getattr(service, 'name', ''), service.type)
return column_headers, data
class AddProjectToEndpoint(command.Command): class AddProjectToEndpoint(command.Command):
@ -112,23 +132,23 @@ class CreateEndpoint(command.ShowOne):
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.sdk_connection.identity
service = common.find_service(identity_client, parsed_args.service) service = common.find_service_sdk(identity_client, parsed_args.service)
endpoint = identity_client.endpoints.create( kwargs = {}
service=service.id,
url=parsed_args.url,
interface=parsed_args.interface,
region=parsed_args.region,
enabled=parsed_args.enabled,
)
info = {} kwargs['service_id'] = service.id
endpoint._info.pop('links') kwargs['url'] = parsed_args.url
info.update(endpoint._info) kwargs['interface'] = parsed_args.interface
info['service_name'] = get_service_name(service) kwargs['is_enabled'] = parsed_args.enabled
info['service_type'] = service.type
return zip(*sorted(info.items())) if parsed_args.region:
region = identity_client.get_region(parsed_args.region)
kwargs['region_id'] = region.id
endpoint = identity_client.create_endpoint(**kwargs)
return _format_endpoint(endpoint, service=service)
class DeleteEndpoint(command.Command): class DeleteEndpoint(command.Command):
@ -145,14 +165,12 @@ class DeleteEndpoint(command.Command):
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.sdk_connection.identity
result = 0 result = 0
for i in parsed_args.endpoint: for i in parsed_args.endpoint:
try: try:
endpoint_id = utils.find_resource( endpoint_id = identity_client.find_endpoint(i).id
identity_client.endpoints, i identity_client.delete_endpoint(endpoint_id)
).id
identity_client.endpoints.delete(endpoint_id)
except Exception as e: except Exception as e:
result += 1 result += 1
LOG.error( LOG.error(
@ -208,28 +226,24 @@ class ListEndpoint(command.Lister):
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.sdk_connection.identity
endpoint = None endpoint = None
if parsed_args.endpoint: if parsed_args.endpoint:
endpoint = utils.find_resource( endpoint = identity_client.find_endpoint(parsed_args.endpoint)
identity_client.endpoints, parsed_args.endpoint
)
project = None project = None
if parsed_args.project: if parsed_args.project:
project = common.find_project( project = identity_client.find_project(
identity_client,
parsed_args.project, parsed_args.project,
parsed_args.project_domain, parsed_args.project_domain,
) )
if endpoint: if endpoint:
columns: tuple[str, ...] = ('ID', 'Name') column_headers = ('ID', 'Name')
data = identity_client.endpoint_filter.list_projects_for_endpoint( columns: tuple[str, ...] = ('id', 'name')
endpoint=endpoint.id data = identity_client.endpoint_projects(endpoint=endpoint.id)
)
else: else:
columns = ( column_headers = (
'ID', 'ID',
'Region', 'Region',
'Service Name', 'Service Name',
@ -238,37 +252,41 @@ class ListEndpoint(command.Lister):
'Interface', 'Interface',
'URL', 'URL',
) )
columns = (
'id',
'region_id',
'service_name',
'service_type',
'is_enabled',
'interface',
'url',
)
kwargs = {} kwargs = {}
if parsed_args.service: if parsed_args.service:
service = common.find_service( service = common.find_service_sdk(
identity_client, parsed_args.service identity_client, parsed_args.service
) )
kwargs['service'] = service.id kwargs['service_id'] = service.id
if parsed_args.interface: if parsed_args.interface:
kwargs['interface'] = parsed_args.interface kwargs['interface'] = parsed_args.interface
if parsed_args.region: if parsed_args.region:
kwargs['region'] = parsed_args.region region = identity_client.get_region(parsed_args.region)
kwargs['region_id'] = region.id
if project: if project:
data = ( data = list(
identity_client.endpoint_filter.list_endpoints_for_project( identity_client.project_endpoints(project=project.id)
project=project.id
)
) )
else: else:
data = identity_client.endpoints.list(**kwargs) data = list(identity_client.endpoints(**kwargs))
service_list = identity_client.services.list()
for ep in data: for ep in data:
service = common.find_service_in_list( service = identity_client.find_service(ep.service_id)
service_list, ep.service_id ep.service_name = getattr(service, 'name', '')
)
ep.service_name = get_service_name(service)
ep.service_type = service.type ep.service_type = service.type
return ( return (
columns, column_headers,
( (
utils.get_item_properties( utils.get_item_properties(
s, s,
@ -363,28 +381,34 @@ class SetEndpoint(command.Command):
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.sdk_connection.identity
endpoint = utils.find_resource( endpoint = identity_client.find_endpoint(parsed_args.endpoint)
identity_client.endpoints, parsed_args.endpoint
) kwargs = {}
service_id = None
if parsed_args.service: if parsed_args.service:
service = common.find_service(identity_client, parsed_args.service) service = common.find_service_sdk(
service_id = service.id identity_client, parsed_args.service
enabled = None )
if parsed_args.enabled: kwargs['service_id'] = service.id
enabled = True
if parsed_args.disabled:
enabled = False
identity_client.endpoints.update( if parsed_args.enabled:
kwargs['is_enabled'] = True
if parsed_args.disabled:
kwargs['is_enabled'] = False
if parsed_args.url:
kwargs['url'] = parsed_args.url
if parsed_args.interface:
kwargs['interface'] = parsed_args.interface
if parsed_args.region:
kwargs['region_id'] = parsed_args.region
identity_client.update_endpoint(
endpoint.id, endpoint.id,
service=service_id, **kwargs,
url=parsed_args.url,
interface=parsed_args.interface,
region=parsed_args.region,
enabled=enabled,
) )
@ -404,16 +428,9 @@ class ShowEndpoint(command.ShowOne):
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.sdk_connection.identity
endpoint = utils.find_resource( endpoint = identity_client.find_endpoint(parsed_args.endpoint)
identity_client.endpoints, parsed_args.endpoint
)
service = common.find_service(identity_client, endpoint.service_id) service = common.find_service_sdk(identity_client, endpoint.service_id)
info = {} return _format_endpoint(endpoint, service)
endpoint._info.pop('links')
info.update(endpoint._info)
info['service_name'] = get_service_name(service)
info['service_type'] = service.type
return zip(*sorted(info.items()))

@ -10,6 +10,13 @@
# 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 openstack.identity.v3 import domain as _domain
from openstack.identity.v3 import endpoint as _endpoint
from openstack.identity.v3 import project as _project
from openstack.identity.v3 import region as _region
from openstack.identity.v3 import service as _service
from openstack.test import fakes as sdk_fakes
from openstackclient.identity.v3 import endpoint from openstackclient.identity.v3 import endpoint
from openstackclient.tests.unit.identity.v3 import fakes as identity_fakes from openstackclient.tests.unit.identity.v3 import fakes as identity_fakes
@ -37,30 +44,34 @@ class TestEndpoint(identity_fakes.TestIdentityv3):
self.projects_mock.reset_mock() self.projects_mock.reset_mock()
class TestEndpointCreate(TestEndpoint): class TestEndpointCreate(identity_fakes.TestIdentityv3):
service = identity_fakes.FakeService.create_one_service()
columns = ( columns = (
'enabled', 'enabled',
'id', 'id',
'interface', 'interface',
'region', 'region',
'region_id',
'service_id', 'service_id',
'url',
'service_name', 'service_name',
'service_type', 'service_type',
'url',
) )
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.endpoint = identity_fakes.FakeEndpoint.create_one_endpoint( self.service = sdk_fakes.generate_fake_resource(_service.Service)
attrs={'service_id': self.service.id} self.region = sdk_fakes.generate_fake_resource(_region.Region)
self.endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=self.service.id,
interface='admin',
region_id=self.region.id,
) )
self.endpoints_mock.create.return_value = self.endpoint
# This is the return value for common.find_resource(service) self.identity_sdk_client.create_endpoint.return_value = self.endpoint
self.services_mock.get.return_value = self.service self.identity_sdk_client.find_service.return_value = self.service
self.identity_sdk_client.get_region.return_value = self.region
# Get the command object to test # Get the command object to test
self.cmd = endpoint.CreateEndpoint(self.app, None) self.cmd = endpoint.CreateEndpoint(self.app, None)
@ -79,6 +90,9 @@ class TestEndpointCreate(TestEndpoint):
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
# Fake endpoints come with a region ID by default, so set it to None
setattr(self.endpoint, "region_id", None)
# In base command class ShowOne in cliff, abstract method take_action() # In base command class ShowOne in cliff, abstract method take_action()
# returns a two-part tuple with a tuple of column names and a tuple of # returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown. # data to be shown.
@ -86,25 +100,25 @@ class TestEndpointCreate(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'service': self.service.id, 'service_id': self.service.id,
'url': self.endpoint.url, 'url': self.endpoint.url,
'interface': self.endpoint.interface, 'interface': self.endpoint.interface,
'enabled': True, 'is_enabled': True,
'region': None,
} }
self.endpoints_mock.create.assert_called_with(**kwargs) self.identity_sdk_client.create_endpoint.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
True, True,
self.endpoint.id, self.endpoint.id,
self.endpoint.interface, self.endpoint.interface,
self.endpoint.region, None,
None,
self.service.id, self.service.id,
self.endpoint.url,
self.service.name, self.service.name,
self.service.type, self.service.type,
self.endpoint.url,
) )
self.assertEqual(datalist, data) self.assertEqual(datalist, data)
@ -114,14 +128,14 @@ class TestEndpointCreate(TestEndpoint):
self.endpoint.interface, self.endpoint.interface,
self.endpoint.url, self.endpoint.url,
'--region', '--region',
self.endpoint.region, self.region.id,
] ]
verifylist = [ verifylist = [
('enabled', True), ('enabled', True),
('service', self.service.id), ('service', self.service.id),
('interface', self.endpoint.interface), ('interface', self.endpoint.interface),
('url', self.endpoint.url), ('url', self.endpoint.url),
('region', self.endpoint.region), ('region', self.region.id),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
@ -132,25 +146,26 @@ class TestEndpointCreate(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'service': self.service.id, 'service_id': self.service.id,
'url': self.endpoint.url, 'url': self.endpoint.url,
'interface': self.endpoint.interface, 'interface': self.endpoint.interface,
'enabled': True, 'is_enabled': True,
'region': self.endpoint.region, 'region_id': self.region.id,
} }
self.endpoints_mock.create.assert_called_with(**kwargs) self.identity_sdk_client.create_endpoint.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
True, True,
self.endpoint.id, self.endpoint.id,
self.endpoint.interface, self.endpoint.interface,
self.endpoint.region, self.region.id,
self.region.id,
self.service.id, self.service.id,
self.endpoint.url,
self.service.name, self.service.name,
self.service.type, self.service.type,
self.endpoint.url,
) )
self.assertEqual(datalist, data) self.assertEqual(datalist, data)
@ -169,6 +184,9 @@ class TestEndpointCreate(TestEndpoint):
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
# Fake endpoints come with a region ID by default, so set it to None
setattr(self.endpoint, "region_id", None)
# In base command class ShowOne in cliff, abstract method take_action() # In base command class ShowOne in cliff, abstract method take_action()
# returns a two-part tuple with a tuple of column names and a tuple of # returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown. # data to be shown.
@ -176,25 +194,25 @@ class TestEndpointCreate(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'service': self.service.id, 'service_id': self.service.id,
'url': self.endpoint.url, 'url': self.endpoint.url,
'interface': self.endpoint.interface, 'interface': self.endpoint.interface,
'enabled': True, 'is_enabled': True,
'region': None,
} }
self.endpoints_mock.create.assert_called_with(**kwargs) self.identity_sdk_client.create_endpoint.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
True, True,
self.endpoint.id, self.endpoint.id,
self.endpoint.interface, self.endpoint.interface,
self.endpoint.region, None,
None,
self.service.id, self.service.id,
self.endpoint.url,
self.service.name, self.service.name,
self.service.type, self.service.type,
self.endpoint.url,
) )
self.assertEqual(datalist, data) self.assertEqual(datalist, data)
@ -213,6 +231,10 @@ class TestEndpointCreate(TestEndpoint):
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
# Fake endpoints come with a region ID by default, so set it to None
setattr(self.endpoint, "region_id", None)
setattr(self.endpoint, "is_enabled", False)
# In base command class ShowOne in cliff, abstract method take_action() # In base command class ShowOne in cliff, abstract method take_action()
# returns a two-part tuple with a tuple of column names and a tuple of # returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown. # data to be shown.
@ -220,38 +242,37 @@ class TestEndpointCreate(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'service': self.service.id, 'service_id': self.service.id,
'url': self.endpoint.url, 'url': self.endpoint.url,
'interface': self.endpoint.interface, 'interface': self.endpoint.interface,
'enabled': False, 'is_enabled': False,
'region': None,
} }
self.endpoints_mock.create.assert_called_with(**kwargs) self.identity_sdk_client.create_endpoint.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
True, False,
self.endpoint.id, self.endpoint.id,
self.endpoint.interface, self.endpoint.interface,
self.endpoint.region, None,
None,
self.service.id, self.service.id,
self.endpoint.url,
self.service.name, self.service.name,
self.service.type, self.service.type,
self.endpoint.url,
) )
self.assertEqual(datalist, data) self.assertEqual(datalist, data)
class TestEndpointDelete(TestEndpoint): class TestEndpointDelete(identity_fakes.TestIdentityv3):
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint()
def setUp(self): def setUp(self):
super().setUp() super().setUp()
# This is the return value for utils.find_resource(endpoint) self.endpoint = sdk_fakes.generate_fake_resource(_endpoint.Endpoint)
self.endpoints_mock.get.return_value = self.endpoint
self.endpoints_mock.delete.return_value = None self.identity_sdk_client.find_endpoint.return_value = self.endpoint
self.identity_sdk_client.delete_endpoint.return_value = None
# Get the command object to test # Get the command object to test
self.cmd = endpoint.DeleteEndpoint(self.app, None) self.cmd = endpoint.DeleteEndpoint(self.app, None)
@ -267,18 +288,13 @@ class TestEndpointDelete(TestEndpoint):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.endpoints_mock.delete.assert_called_with( self.identity_sdk_client.delete_endpoint.assert_called_with(
self.endpoint.id, self.endpoint.id,
) )
self.assertIsNone(result) self.assertIsNone(result)
class TestEndpointList(TestEndpoint): class TestEndpointList(identity_fakes.TestIdentityv3):
service = identity_fakes.FakeService.create_one_service()
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint(
attrs={'service_id': service.id}
)
columns = ( columns = (
'ID', 'ID',
'Region', 'Region',
@ -292,11 +308,19 @@ class TestEndpointList(TestEndpoint):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.endpoints_mock.list.return_value = [self.endpoint] self.service = sdk_fakes.generate_fake_resource(_service.Service)
self.region = sdk_fakes.generate_fake_resource(_region.Region)
self.endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=self.service.id,
interface='admin',
region_id=self.region.id,
)
# This is the return value for common.find_resource(service) self.identity_sdk_client.endpoints.return_value = [self.endpoint]
self.services_mock.get.return_value = self.service self.identity_sdk_client.find_service.return_value = self.service
self.services_mock.list.return_value = [self.service] self.identity_sdk_client.services.return_value = [self.service]
self.identity_sdk_client.get_region.return_value = self.region
# Get the command object to test # Get the command object to test
self.cmd = endpoint.ListEndpoint(self.app, None) self.cmd = endpoint.ListEndpoint(self.app, None)
@ -310,13 +334,13 @@ class TestEndpointList(TestEndpoint):
# returns a tuple containing the column names and an iterable # returns a tuple containing the column names and an iterable
# containing the data to be listed. # containing the data to be listed.
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.endpoints_mock.list.assert_called_with() self.identity_sdk_client.endpoints.assert_called_with()
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
( (
self.endpoint.id, self.endpoint.id,
self.endpoint.region, self.region.id,
self.service.name, self.service.name,
self.service.type, self.service.type,
True, True,
@ -343,15 +367,15 @@ class TestEndpointList(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'service': self.service.id, 'service_id': self.service.id,
} }
self.endpoints_mock.list.assert_called_with(**kwargs) self.identity_sdk_client.endpoints.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
( (
self.endpoint.id, self.endpoint.id,
self.endpoint.region, self.region.id,
self.service.name, self.service.name,
self.service.type, self.service.type,
True, True,
@ -380,13 +404,13 @@ class TestEndpointList(TestEndpoint):
kwargs = { kwargs = {
'interface': self.endpoint.interface, 'interface': self.endpoint.interface,
} }
self.endpoints_mock.list.assert_called_with(**kwargs) self.identity_sdk_client.endpoints.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
( (
self.endpoint.id, self.endpoint.id,
self.endpoint.region, self.region.id,
self.service.name, self.service.name,
self.service.type, self.service.type,
True, True,
@ -399,10 +423,10 @@ class TestEndpointList(TestEndpoint):
def test_endpoint_list_region(self): def test_endpoint_list_region(self):
arglist = [ arglist = [
'--region', '--region',
self.endpoint.region, self.region.id,
] ]
verifylist = [ verifylist = [
('region', self.endpoint.region), ('region', self.region.id),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
@ -413,15 +437,15 @@ class TestEndpointList(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'region': self.endpoint.region, 'region_id': self.region.id,
} }
self.endpoints_mock.list.assert_called_with(**kwargs) self.identity_sdk_client.endpoints.assert_called_with(**kwargs)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
datalist = ( datalist = (
( (
self.endpoint.id, self.endpoint.id,
self.endpoint.region, self.region.id,
self.service.name, self.service.name,
self.service.type, self.service.type,
True, True,
@ -432,13 +456,13 @@ class TestEndpointList(TestEndpoint):
self.assertEqual(datalist, tuple(data)) self.assertEqual(datalist, tuple(data))
def test_endpoint_list_project_with_project_domain(self): def test_endpoint_list_project_with_project_domain(self):
project = identity_fakes.FakeProject.create_one_project() project = sdk_fakes.generate_fake_resource(_project.Project)
domain = identity_fakes.FakeDomain.create_one_domain() domain = sdk_fakes.generate_fake_resource(_domain.Domain)
self.ep_filter_mock.list_endpoints_for_project.return_value = [ self.identity_sdk_client.project_endpoints.return_value = [
self.endpoint self.endpoint
] ]
self.projects_mock.get.return_value = project self.identity_sdk_client.find_project.return_value = project
arglist = ['--project', project.name, '--project-domain', domain.name] arglist = ['--project', project.name, '--project-domain', domain.name]
verifylist = [ verifylist = [
@ -451,7 +475,7 @@ class TestEndpointList(TestEndpoint):
# returns a tuple containing the column names and an iterable # returns a tuple containing the column names and an iterable
# containing the data to be listed. # containing the data to be listed.
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.ep_filter_mock.list_endpoints_for_project.assert_called_with( self.identity_sdk_client.project_endpoints.assert_called_with(
project=project.id project=project.id
) )
@ -459,7 +483,7 @@ class TestEndpointList(TestEndpoint):
datalist = ( datalist = (
( (
self.endpoint.id, self.endpoint.id,
self.endpoint.region, self.region.id,
self.service.name, self.service.name,
self.service.type, self.service.type,
True, True,
@ -470,22 +494,20 @@ class TestEndpointList(TestEndpoint):
self.assertEqual(datalist, tuple(data)) self.assertEqual(datalist, tuple(data))
class TestEndpointSet(TestEndpoint): class TestEndpointSet(identity_fakes.TestIdentityv3):
service = identity_fakes.FakeService.create_one_service()
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint(
attrs={'service_id': service.id}
)
def setUp(self): def setUp(self):
super().setUp() super().setUp()
# This is the return value for utils.find_resource(endpoint) self.service = sdk_fakes.generate_fake_resource(_service.Service)
self.endpoints_mock.get.return_value = self.endpoint self.endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=self.service.id,
interface='admin',
)
self.endpoints_mock.update.return_value = self.endpoint self.identity_sdk_client.find_endpoint.return_value = self.endpoint
self.identity_sdk_client.update_endpoint.return_value = self.endpoint
# This is the return value for common.find_resource(service) self.identity_sdk_client.find_service.return_value = self.service
self.services_mock.get.return_value = self.service
# Get the command object to test # Get the command object to test
self.cmd = endpoint.SetEndpoint(self.app, None) self.cmd = endpoint.SetEndpoint(self.app, None)
@ -501,15 +523,8 @@ class TestEndpointSet(TestEndpoint):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
kwargs = { self.identity_sdk_client.update_endpoint.assert_called_with(
'enabled': None, self.endpoint.id
'interface': None,
'region': None,
'service': None,
'url': None,
}
self.endpoints_mock.update.assert_called_with(
self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -525,13 +540,9 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': None,
'interface': 'public', 'interface': 'public',
'url': None,
'region': None,
'service': None,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -548,13 +559,9 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': None,
'interface': None,
'url': 'http://localhost:5000', 'url': 'http://localhost:5000',
'region': None,
'service': None,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -571,13 +578,9 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': None, 'service_id': self.service.id,
'interface': None,
'url': None,
'region': None,
'service': self.service.id,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -594,13 +597,9 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': None, 'region_id': 'e-rzzz',
'interface': None,
'url': None,
'region': 'e-rzzz',
'service': None,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -617,13 +616,9 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': True, 'is_enabled': True,
'interface': None,
'url': None,
'region': None,
'service': None,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
@ -640,31 +635,31 @@ class TestEndpointSet(TestEndpoint):
# Set expected values # Set expected values
kwargs = { kwargs = {
'enabled': False, 'is_enabled': False,
'interface': None,
'url': None,
'region': None,
'service': None,
} }
self.endpoints_mock.update.assert_called_with( self.identity_sdk_client.update_endpoint.assert_called_with(
self.endpoint.id, **kwargs self.endpoint.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
class TestEndpointShow(TestEndpoint): class TestEndpointShow(identity_fakes.TestIdentityv3):
service = identity_fakes.FakeService.create_one_service()
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint(
attrs={'service_id': service.id}
)
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.endpoints_mock.get.return_value = self.endpoint self.service = sdk_fakes.generate_fake_resource(_service.Service)
self.region = sdk_fakes.generate_fake_resource(_region.Region)
self.endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=self.service.id,
interface='admin',
region_id=self.region.id,
)
# This is the return value for common.find_resource(service) self.identity_sdk_client.find_endpoint.return_value = self.endpoint
self.services_mock.get.return_value = self.service
self.identity_sdk_client.find_service.return_value = self.service
self.identity_sdk_client.get_region.return_value = self.region
# Get the command object to test # Get the command object to test
self.cmd = endpoint.ShowEndpoint(self.app, None) self.cmd = endpoint.ShowEndpoint(self.app, None)
@ -682,7 +677,7 @@ class TestEndpointShow(TestEndpoint):
# returns a two-part tuple with a tuple of column names and a tuple of # returns a two-part tuple with a tuple of column names and a tuple of
# data to be shown. # data to be shown.
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.endpoints_mock.get.assert_called_with( self.identity_sdk_client.find_endpoint.assert_called_with(
self.endpoint.id, self.endpoint.id,
) )
@ -691,82 +686,82 @@ class TestEndpointShow(TestEndpoint):
'id', 'id',
'interface', 'interface',
'region', 'region',
'region_id',
'service_id', 'service_id',
'url',
'service_name', 'service_name',
'service_type', 'service_type',
'url',
) )
self.assertEqual(collist, columns) self.assertEqual(collist, columns)
datalist = ( datalist = (
True, True,
self.endpoint.id, self.endpoint.id,
self.endpoint.interface, self.endpoint.interface,
self.endpoint.region, self.region.id,
self.region.id,
self.service.id, self.service.id,
self.endpoint.url,
self.service.name, self.service.name,
self.service.type, self.service.type,
self.endpoint.url,
) )
self.assertEqual(datalist, data) self.assertEqual(datalist, data)
class TestEndpointCreateServiceWithoutName(TestEndpointCreate): class TestEndpointCreateServiceWithoutName(TestEndpointCreate):
service = identity_fakes.FakeService.create_one_service( service = sdk_fakes.generate_fake_resource(
attrs={'service_name': ''} resource_type=_service.Service,
name='',
)
region = sdk_fakes.generate_fake_resource(_region.Region)
endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=service.id,
interface='admin',
region_id=region.id,
) )
def setUp(self): def setUp(self):
super(TestEndpointCreate, self).setUp() super().setUp()
self.endpoint = identity_fakes.FakeEndpoint.create_one_endpoint(
attrs={'service_id': self.service.id}
)
self.endpoints_mock.create.return_value = self.endpoint
# This is the return value for common.find_resource(service)
self.services_mock.get.return_value = self.service
# Get the command object to test # Get the command object to test
self.cmd = endpoint.CreateEndpoint(self.app, None) self.cmd = endpoint.CreateEndpoint(self.app, None)
class TestEndpointListServiceWithoutName(TestEndpointList): class TestEndpointListServiceWithoutName(TestEndpointList):
service = identity_fakes.FakeService.create_one_service( service = sdk_fakes.generate_fake_resource(
attrs={'service_name': ''} resource_type=_service.Service,
name='',
) )
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint( region = sdk_fakes.generate_fake_resource(_region.Region)
attrs={'service_id': service.id} endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=service.id,
interface='admin',
region_id=region.id,
) )
def setUp(self): def setUp(self):
super(TestEndpointList, self).setUp() super().setUp()
self.endpoints_mock.list.return_value = [self.endpoint]
# This is the return value for common.find_resource(service)
self.services_mock.get.return_value = self.service
self.services_mock.list.return_value = [self.service]
# Get the command object to test # Get the command object to test
self.cmd = endpoint.ListEndpoint(self.app, None) self.cmd = endpoint.ListEndpoint(self.app, None)
class TestEndpointShowServiceWithoutName(TestEndpointShow): class TestEndpointShowServiceWithoutName(TestEndpointShow):
service = identity_fakes.FakeService.create_one_service( service = sdk_fakes.generate_fake_resource(
attrs={'service_name': ''} resource_type=_service.Service,
name='',
) )
endpoint = identity_fakes.FakeEndpoint.create_one_endpoint( region = sdk_fakes.generate_fake_resource(_region.Region)
attrs={'service_id': service.id} endpoint = sdk_fakes.generate_fake_resource(
resource_type=_endpoint.Endpoint,
service_id=service.id,
interface='admin',
region_id=region.id,
) )
def setUp(self): def setUp(self):
super(TestEndpointShow, self).setUp() super().setUp()
self.endpoints_mock.get.return_value = self.endpoint
# This is the return value for common.find_resource(service)
self.services_mock.get.return_value = self.service
# Get the command object to test # Get the command object to test
self.cmd = endpoint.ShowEndpoint(self.app, None) self.cmd = endpoint.ShowEndpoint(self.app, None)

@ -0,0 +1,10 @@
---
upgrade:
- |
The following commands have been migrated to SDK:
- ``endpoint create``
- ``endpoint delete``
- ``endpoint list``
- ``endpoint show``
- ``endpoint set``