Merge "Endpoints: Add create, delete, list support"

This commit is contained in:
Jenkins
2012-02-28 07:07:59 +00:00
committed by Gerrit Code Review
4 changed files with 197 additions and 0 deletions

View File

@@ -18,6 +18,7 @@ from keystoneclient import client
from keystoneclient import exceptions
from keystoneclient import service_catalog
from keystoneclient.v2_0 import ec2
from keystoneclient.v2_0 import endpoints
from keystoneclient.v2_0 import roles
from keystoneclient.v2_0 import services
from keystoneclient.v2_0 import tenants
@@ -63,6 +64,7 @@ class Client(client.HTTPClient):
def __init__(self, endpoint=None, **kwargs):
""" Initialize a new client for the Keystone v2.0 API. """
super(Client, self).__init__(endpoint=endpoint, **kwargs)
self.endpoints = endpoints.EndpointManager(self)
self.roles = roles.RoleManager(self)
self.services = services.ServiceManager(self)
self.tenants = tenants.TenantManager(self)

View File

@@ -0,0 +1,39 @@
# Copyright 2012 Canonical Ltd.
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from keystoneclient import base
class Endpoint(base.Resource):
def __repr__(self):
return "<Endpoint %s>" % self._info
class EndpointManager(base.ManagerWithFind):
resource_class = Endpoint
def list(self):
return self._list('/endpoints', 'endpoints')
def create(self, region, service_id, publicurl, adminurl, internalurl):
body = {'endpoint': {'region': region,
'service_id': service_id,
'publicurl': publicurl,
'adminurl': adminurl,
'internalurl': internalurl}}
return self._create('/endpoints', body, 'endpoint')
def delete(self, id):
return self._delete('/endpoints/%s' % id)

View File

@@ -305,6 +305,45 @@ def do_endpoint_get(kc, args):
utils.print_dict({'%s.%s' % (args.service, args.endpoint_type): url})
def do_endpoint_list(kc, args):
endpoints = kc.endpoints.list()
utils.print_list(endpoints,
['id', 'region', 'publicurl', 'internalurl', 'publicurl'])
@utils.arg('--region', metavar='<endpoint_region>',
help='Endpoint region', nargs='?', default='regionOne')
@utils.arg('--service_id', metavar='<service_id>',
help='ID of service associated with Endpoint', nargs='?')
@utils.arg('--publicurl', metavar='<publicurl>',
help='Public URL endpoint', nargs='?')
@utils.arg('--adminurl', metavar='<publicurl>',
help='Admin URL endpoint', nargs='?')
@utils.arg('--internalurl', metavar='<publicurl>',
help='Internal URL endpoint', nargs='?')
def do_endpoint_create(kc, args):
kwargs = {
'region': args.region,
'service_id': args.service_id,
'publicurl': args.publicurl,
'adminurl': args.adminurl,
'internalurl': args.internalurl,
}
endpoint = kc.endpoints.create(
args.region, args.service_id, args.publicurl,
args.adminurl, args.internalurl)
utils.print_dict(endpoint._info)
@utils.arg('id', metavar='<endpoint_id>', help='ID of endpoint to delete')
def do_endpoint_delete(kc, args):
try:
kc.endpoints.delete(args.id)
print 'Endpoint has been deleted.'
except:
print 'Unable to delete endpoint.'
def do_token_get(kc, args):
"""Display the current user token"""
utils.print_dict(kc.service_catalog.get_token())

View File

@@ -0,0 +1,117 @@
import urlparse
import json
import httplib2
from keystoneclient.v2_0 import endpoints
from tests import utils
class EndpointTests(utils.TestCase):
def setUp(self):
super(EndpointTests, self).setUp()
self.TEST_REQUEST_HEADERS = {'X-Auth-Token': 'aToken',
'User-Agent': 'python-keystoneclient'}
self.TEST_POST_HEADERS = {'Content-Type': 'application/json',
'X-Auth-Token': 'aToken',
'User-Agent': 'python-keystoneclient'}
self.TEST_ENDPOINTS = {'endpoints': [
{
'adminurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'id':
'8f9531231e044e218824b0e58688d262',
'internalurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'publicurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'region':
'RegionOne'
},
{
'adminurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'id':
'8f9531231e044e218824b0e58688d263',
'internalurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'publicurl':
'http://host-1:8774/v1.1/$(tenant_id)s',
'region':
'RegionOne'
}
]
}
def test_create(self):
req_body = {"endpoint": {"region": "RegionOne",
"publicurl":
"http://host-3:8774/v1.1/$(tenant_id)s",
"internalurl":
"http://host-3:8774/v1.1/$(tenant_id)s",
"adminurl":
"http://host-3:8774/v1.1/$(tenant_id)s",
"service_id": "e044e21"}}
resp_body = {"endpoint": {
"adminurl":
"http://host-3:8774/v1.1/$(tenant_id)s",
"region": "RegionOne",
"id": "1fd485b2ffd54f409a5ecd42cba11401",
"internalurl":
"http://host-3:8774/v1.1/$(tenant_id)s",
"publicurl":
"http://host-3:8774/v1.1/$(tenant_id)s"}}
resp = httplib2.Response({
"status": 200,
"body": json.dumps(resp_body),
})
httplib2.Http.request(urlparse.urljoin(self.TEST_URL,
'v2.0/endpoints'),
'POST',
body=json.dumps(req_body),
headers=self.TEST_POST_HEADERS) \
.AndReturn((resp, resp['body']))
self.mox.ReplayAll()
endpoint = self.client.endpoints.create(
region=req_body['endpoint']['region'],
publicurl=req_body['endpoint']['publicurl'],
adminurl=req_body['endpoint']['adminurl'],
internalurl=req_body['endpoint']['internalurl'],
service_id=req_body['endpoint']['service_id']
)
self.assertTrue(isinstance(endpoint, endpoints.Endpoint))
def test_delete(self):
resp = httplib2.Response({
"status": 200,
"body": ""
})
httplib2.Http.request(urlparse.urljoin(self.TEST_URL,
'v2.0/endpoints/8f953'),
'DELETE',
headers=self.TEST_REQUEST_HEADERS) \
.AndReturn((resp, resp['body']))
self.mox.ReplayAll()
self.client.endpoints.delete('8f953')
def test_list(self):
resp = httplib2.Response({
"status": 200,
"body": json.dumps(self.TEST_ENDPOINTS),
})
httplib2.Http.request(urlparse.urljoin(self.TEST_URL,
'v2.0/endpoints?fresh=1234'),
'GET',
headers=self.TEST_REQUEST_HEADERS) \
.AndReturn((resp, resp['body']))
self.mox.ReplayAll()
endpoint_list = self.client.endpoints.list()
[self.assertTrue(isinstance(r, endpoints.Endpoint)) \
for r in endpoint_list]