Merge "identity: Migrate 'endpoint' commands to SDK"
This commit is contained in:
commit
6e89f9da63
openstackclient
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``
|
Loading…
x
Reference in New Issue
Block a user