Make os-services API extensions consistent.

Updates the os-services API extension so that it is consistent
internally (index and update return similar formats), and so
that it works with the recent novaclient code which sends
the following request body format:

  {"binary": "nova-cert", "host": "nova1"}

Also, updates the response body format of the update call so that it
wraps things in an extra service dict which should make novaclient
happier here as well (and is consistent with other extensions too).

Fixes LP Bug #1147746.

Change-Id: I932160d64fdd3aaeb2ed90a092ecc7a36dcc9665
This commit is contained in:
Dan Prince
2013-03-05 16:17:29 -05:00
parent 9df61c0b06
commit 37c618da7c
11 changed files with 51 additions and 41 deletions

View File

@@ -1,4 +1,4 @@
{
"host": "host1",
"service": "nova-compute"
}
"binary": "nova-compute"
}

View File

@@ -1,5 +1,7 @@
{
"disabled": true,
"host": "host1",
"service": "nova-compute"
}
"service": {
"host": "host1",
"binary": "nova-compute",
"status": "disabled"
}
}

View File

@@ -1,5 +1,7 @@
{
"disabled": false,
"host": "host1",
"service": "nova-compute"
}
"service": {
"host": "host1",
"binary": "nova-compute",
"status": "enabled"
}
}

View File

@@ -33,4 +33,4 @@
"zone": "nova"
}
]
}
}

View File

@@ -51,8 +51,8 @@ class ServicesUpdateTemplate(xmlutil.TemplateBuilder):
def construct(self):
root = xmlutil.TemplateElement('host')
root.set('host')
root.set('service')
root.set('disabled')
root.set('binary')
root.set('status')
return xmlutil.MasterTemplate(root, 1)
@@ -76,13 +76,13 @@ class ServiceController(object):
host = ''
if 'host' in req.GET:
host = req.GET['host']
service = ''
if 'service' in req.GET:
service = req.GET['service']
binary = ''
if 'binary' in req.GET:
binary = req.GET['binary']
if host:
services = [s for s in services if s['host'] == host]
if service:
services = [s for s in services if s['binary'] == service]
if binary:
services = [s for s in services if s['binary'] == binary]
svcs = []
for svc in services:
@@ -113,12 +113,12 @@ class ServiceController(object):
try:
host = body['host']
service = body['service']
binary = body['binary']
except (TypeError, KeyError):
raise webob.exc.HTTPUnprocessableEntity()
try:
svc = db.service_get_by_args(context, host, service)
svc = db.service_get_by_args(context, host, binary)
if not svc:
raise webob.exc.HTTPNotFound('Unknown service')
@@ -126,7 +126,8 @@ class ServiceController(object):
except exception.ServiceNotFound:
raise webob.exc.HTTPNotFound("service not found")
return {'host': host, 'service': service, 'disabled': disabled}
status = id + 'd'
return {'service': {'host': host, 'binary': binary, 'status': status}}
class Services(extensions.ExtensionDescriptor):

View File

@@ -64,7 +64,7 @@ class FakeRequest(object):
class FakeRequestWithService(object):
environ = {"nova.context": context.get_admin_context()}
GET = {"service": "nova-compute"}
GET = {"binary": "nova-compute"}
class FakeRequestWithHost(object):
@@ -74,7 +74,7 @@ class FakeRequestWithHost(object):
class FakeRequestWithHostService(object):
environ = {"nova.context": context.get_admin_context()}
GET = {"host": "host1", "service": "nova-compute"}
GET = {"host": "host1", "binary": "nova-compute"}
def fake_host_api_service_get_all(context, filters=None, set_zones=False):
@@ -190,15 +190,15 @@ class ServicesTest(test.TestCase):
self.assertEqual(res_dict, response)
def test_services_enable(self):
body = {'host': 'host1', 'service': 'nova-compute'}
body = {'host': 'host1', 'binary': 'nova-compute'}
req = fakes.HTTPRequest.blank('/v2/fake/os-services/enable')
res_dict = self.controller.update(req, "enable", body)
self.assertEqual(res_dict['disabled'], False)
self.assertEqual(res_dict['service']['status'], 'enabled')
def test_services_disable(self):
req = fakes.HTTPRequest.blank('/v2/fake/os-services/disable')
body = {'host': 'host1', 'service': 'nova-compute'}
body = {'host': 'host1', 'binary': 'nova-compute'}
res_dict = self.controller.update(req, "disable", body)
self.assertEqual(res_dict['disabled'], True)
self.assertEqual(res_dict['service']['status'], 'disabled')

View File

@@ -1,4 +1,4 @@
{
"host": "%(host)s",
"service": "%(service)s"
"binary": "%(binary)s"
}

View File

@@ -1,5 +1,7 @@
{
"disabled": true,
"host": "%(host)s",
"service": "%(service)s"
"service": {
"host": "%(host)s",
"binary": "%(binary)s",
"status": "disabled"
}
}

View File

@@ -1,4 +1,4 @@
{
"host": "%(host)s",
"service": "%(service)s"
"binary": "%(binary)s"
}

View File

@@ -1,5 +1,8 @@
{
"disabled": false,
"host": "%(host)s",
"service": "%(service)s"
"service": {
"host": "%(host)s",
"binary": "%(binary)s",
"status": "enabled"
}
}

View File

@@ -1990,24 +1990,24 @@ class ServicesJsonTest(ApiSampleTestBase):
def test_service_enable(self):
"""Enable an existing agent build."""
subs = {"host": "host1",
'service': 'nova-compute'}
response = self._do_put('/os-services/enable',
'binary': 'nova-compute'}
response = self._do_put('os-services/enable',
'service-enable-put-req', subs)
self.assertEqual(response.status, 200)
subs = {"host": "host1",
"service": "nova-compute"}
"binary": "nova-compute"}
return self._verify_response('service-enable-put-resp',
subs, response)
def test_service_disable(self):
"""Disable an existing agent build."""
subs = {"host": "host1",
'service': 'nova-compute'}
response = self._do_put('/os-services/disable',
'binary': 'nova-compute'}
response = self._do_put('os-services/disable',
'service-disable-put-req', subs)
self.assertEqual(response.status, 200)
subs = {"host": "host1",
"service": "nova-compute"}
"binary": "nova-compute"}
return self._verify_response('service-disable-put-resp',
subs, response)