changed urls and response format according to the review comments

This commit is contained in:
Manali Latkar 2013-11-25 15:11:01 +05:30
parent a997a6a102
commit 6bab377a37
4 changed files with 88 additions and 31 deletions

View File

@ -121,27 +121,48 @@ def _deletes_model_factory(service):
if service == 'glance': if service == 'glance':
return {'klass': models.ImageDeletes, 'order_by': 'deleted_at'} return {'klass': models.ImageDeletes, 'order_by': 'deleted_at'}
@api_call @api_call
def list_usage_launches(request): def list_usage_launches(request):
service = request.GET.get('service', 'nova') return {'launches': list_usage_launches_with_service(request, 'nova')}
@api_call
def list_usage_images(request):
return { 'images': list_usage_launches_with_service(request, 'glance')}
def list_usage_launches_with_service(request, service):
model = _usage_model_factory(service) model = _usage_model_factory(service)
objects = get_db_objects(model['klass'], request, objects = get_db_objects(model['klass'], request,
model['order_by']) model['order_by'])
dicts = _convert_model_list(objects) dicts = _convert_model_list(objects)
return {'launches': dicts} return dicts
def get_usage_launch_with_service(launch_id, service):
model = _usage_model_factory(service)
return {'launch': _get_model_by_id(model['klass'], launch_id)}
@api_call @api_call
def get_usage_launch(request, launch_id): def get_usage_launch(request, launch_id):
service = request.GET.get('service', 'nova') return get_usage_launch_with_service(launch_id, 'nova')
model = _usage_model_factory(service)
return {'launch': _get_model_by_id(model['klass'], launch_id)}
@api_call
def get_usage_image(request, image_id):
return get_usage_launch_with_service(image_id, 'glance')
@api_call @api_call
def list_usage_deletes(request): def list_usage_deletes(request):
service = request.GET.get('service', 'nova') return list_usage_deletes_with_service(request, 'nova')
@api_call
def list_usage_deletes_glance(request):
return list_usage_deletes_with_service(request, 'glance')
def list_usage_deletes_with_service(request, service):
model = _deletes_model_factory(service) model = _deletes_model_factory(service)
objects = get_db_objects(model['klass'], request, objects = get_db_objects(model['klass'], request,
model['order_by']) model['order_by'])
@ -151,8 +172,13 @@ def list_usage_deletes(request):
@api_call @api_call
def get_usage_delete(request, delete_id): def get_usage_delete(request, delete_id):
service = request.GET.get('service', 'nova') model = _deletes_model_factory('nova')
model = _deletes_model_factory(service) return {'delete': _get_model_by_id(model['klass'], delete_id)}
@api_call
def get_usage_delete_glance(request, delete_id):
model = _deletes_model_factory('glance')
return {'delete': _get_model_by_id(model['klass'], delete_id)} return {'delete': _get_model_by_id(model['klass'], delete_id)}
@ -163,7 +189,15 @@ def _exists_extra_values(exist):
@api_call @api_call
def list_usage_exists(request): def list_usage_exists(request):
service = request.GET.get('service', 'nova') return list_usage_exists_with_service(request, 'nova')
@api_call
def list_usage_exists_glance(request):
return list_usage_exists_with_service(request, 'glance')
def list_usage_exists_with_service(request, service):
model = _exists_model_factory(service) model = _exists_model_factory(service)
try: try:
custom_filters = {} custom_filters = {}
@ -192,6 +226,11 @@ def get_usage_exist(request, exist_id):
return {'exist': _get_model_by_id(models.InstanceExists, exist_id, return {'exist': _get_model_by_id(models.InstanceExists, exist_id,
_exists_extra_values)} _exists_extra_values)}
@api_call
def get_usage_exist_glance(request, exist_id):
return {'exist': _get_model_by_id(models.ImageExists, exist_id,
_exists_extra_values)}
@api_call @api_call
def exists_send_status(request, message_id): def exists_send_status(request, message_id):

View File

@ -437,10 +437,6 @@ class ImageUsage(models.Model):
size = models.BigIntegerField(max_length=20) size = models.BigIntegerField(max_length=20)
last_raw = models.ForeignKey(GlanceRawData, null=True) last_raw = models.ForeignKey(GlanceRawData, null=True)
@property
def launched_at(self):
return self.created_at
class ImageDeletes(models.Model): class ImageDeletes(models.Model):
uuid = models.CharField(max_length=50, db_index=True) uuid = models.CharField(max_length=50, db_index=True)

View File

@ -36,15 +36,37 @@ urlpatterns = patterns('',
url(r'db/usage/launches/$', url(r'db/usage/launches/$',
'stacktach.dbapi.list_usage_launches'), 'stacktach.dbapi.list_usage_launches'),
url(r'db/usage/nova/launches/$',
'stacktach.dbapi.list_usage_launches'),
url(r'db/usage/glance/images/$',
'stacktach.dbapi.list_usage_images'),
url(r'db/usage/launches/(?P<launch_id>\d+)/$', url(r'db/usage/launches/(?P<launch_id>\d+)/$',
'stacktach.dbapi.get_usage_launch'), 'stacktach.dbapi.get_usage_launch'),
url(r'db/usage/nova/launches/(?P<launch_id>\d+)/$',
'stacktach.dbapi.get_usage_launch'),
url(r'db/usage/glance/images/(?P<image_id>\d+)/$',
'stacktach.dbapi.get_usage_image'),
url(r'db/usage/deletes/$', url(r'db/usage/deletes/$',
'stacktach.dbapi.list_usage_deletes'), 'stacktach.dbapi.list_usage_deletes'),
url(r'db/usage/nova/deletes/$',
'stacktach.dbapi.list_usage_deletes'),
url(r'db/usage/glance/deletes/$',
'stacktach.dbapi.list_usage_deletes_glance'),
url(r'db/usage/deletes/(?P<delete_id>\d+)/$', url(r'db/usage/deletes/(?P<delete_id>\d+)/$',
'stacktach.dbapi.get_usage_delete'), 'stacktach.dbapi.get_usage_delete'),
url(r'db/usage/nova/deletes/(?P<delete_id>\d+)/$',
'stacktach.dbapi.get_usage_delete'),
url(r'db/usage/glance/deletes/(?P<delete_id>\d+)/$',
'stacktach.dbapi.get_usage_delete_glance'),
url(r'db/usage/exists/$', 'stacktach.dbapi.list_usage_exists'), url(r'db/usage/exists/$', 'stacktach.dbapi.list_usage_exists'),
url(r'db/usage/nova/exists/$', 'stacktach.dbapi.list_usage_exists'),
url(r'db/usage/glance/exists/$', 'stacktach.dbapi.list_usage_exists_glance'),
url(r'db/usage/exists/(?P<exist_id>\d+)/$', url(r'db/usage/exists/(?P<exist_id>\d+)/$',
'stacktach.dbapi.get_usage_exist'), 'stacktach.dbapi.get_usage_exist'),
url(r'db/usage/nova/exists/(?P<exist_id>\d+)/$',
'stacktach.dbapi.get_usage_exist'),
url(r'db/usage/glance/exists/(?P<exist_id>\d+)/$',
'stacktach.dbapi.get_usage_exist_glance'),
url(r'db/confirm/usage/exists/(?P<message_id>[\w\-]+)/$', url(r'db/confirm/usage/exists/(?P<message_id>[\w\-]+)/$',
'stacktach.dbapi.exists_send_status'), 'stacktach.dbapi.exists_send_status'),

View File

@ -328,10 +328,10 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_list_usage_exists_no_custom_filters_for_nova(self): def test_list_usage_exists_no_custom_filters_for_nova(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
objects = self.mox.CreateMockAnything() objects = self.mox.CreateMockAnything()
dbapi.get_db_objects(models.ImageExists, fake_request, 'id', dbapi.get_db_objects(models.InstanceExists, fake_request, 'id',
custom_filters={}).AndReturn(objects) custom_filters={}).AndReturn(objects)
self.mox.StubOutWithMock(dbapi, '_convert_model_list') self.mox.StubOutWithMock(dbapi, '_convert_model_list')
dbapi._convert_model_list(objects, dbapi._exists_extra_values) dbapi._convert_model_list(objects, dbapi._exists_extra_values)
@ -342,7 +342,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_list_usage_exists_no_custom_filters_for_glance(self): def test_list_usage_exists_no_custom_filters_for_glance(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
objects = self.mox.CreateMockAnything() objects = self.mox.CreateMockAnything()
dbapi.get_db_objects(models.ImageExists, fake_request, 'id', dbapi.get_db_objects(models.ImageExists, fake_request, 'id',
@ -350,7 +350,7 @@ class DBAPITestCase(StacktachBaseTestCase):
self.mox.StubOutWithMock(dbapi, '_convert_model_list') self.mox.StubOutWithMock(dbapi, '_convert_model_list')
dbapi._convert_model_list(objects, dbapi._exists_extra_values) dbapi._convert_model_list(objects, dbapi._exists_extra_values)
self.mox.ReplayAll() self.mox.ReplayAll()
resp = dbapi.list_usage_exists(fake_request) resp = dbapi.list_usage_exists_glance(fake_request)
self.assertEqual(resp.status_code, 200) self.assertEqual(resp.status_code, 200)
self.mox.VerifyAll() self.mox.VerifyAll()
@ -770,7 +770,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_list_usage_launches_for_glance(self): def test_list_usage_launches_for_glance(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
mock_objects = self.mox.CreateMockAnything() mock_objects = self.mox.CreateMockAnything()
launches = {'a': 1} launches = {'a': 1}
@ -779,15 +779,15 @@ class DBAPITestCase(StacktachBaseTestCase):
dbapi.get_db_objects(models.ImageUsage, fake_request, 'created_at').AndReturn(mock_objects) dbapi.get_db_objects(models.ImageUsage, fake_request, 'created_at').AndReturn(mock_objects)
self.mox.ReplayAll() self.mox.ReplayAll()
resp = dbapi.list_usage_launches(fake_request) resp = dbapi.list_usage_images(fake_request)
self.assertEqual(resp.status_code, 200) self.assertEqual(resp.status_code, 200)
self.assertEqual(json.loads(resp.content), {'launches': launches}) self.assertEqual(json.loads(resp.content), {'images': launches})
self.mox.VerifyAll() self.mox.VerifyAll()
def test_list_usage_launches_for_nova(self): def test_list_usage_launches_for_nova(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'nova'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
mock_objects = self.mox.CreateMockAnything() mock_objects = self.mox.CreateMockAnything()
launches = {'a': 1} launches = {'a': 1}
@ -818,7 +818,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_get_usage_launch_for_nova(self): def test_get_usage_launch_for_nova(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'nova'} fake_request.GET = {}
launch = {'a': 1} launch = {'a': 1}
self.mox.StubOutWithMock(dbapi, '_get_model_by_id') self.mox.StubOutWithMock(dbapi, '_get_model_by_id')
dbapi._get_model_by_id(models.InstanceUsage, 1).AndReturn(launch) dbapi._get_model_by_id(models.InstanceUsage, 1).AndReturn(launch)
@ -832,13 +832,13 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_get_usage_launch_for_glance(self): def test_get_usage_launch_for_glance(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
launch = {'a': 1} launch = {'a': 1}
self.mox.StubOutWithMock(dbapi, '_get_model_by_id') self.mox.StubOutWithMock(dbapi, '_get_model_by_id')
dbapi._get_model_by_id(models.ImageUsage, 1).AndReturn(launch) dbapi._get_model_by_id(models.ImageUsage, 1).AndReturn(launch)
self.mox.ReplayAll() self.mox.ReplayAll()
resp = dbapi.get_usage_launch(fake_request, 1) resp = dbapi.get_usage_image(fake_request, 1)
self.assertEqual(resp.status_code, 200) self.assertEqual(resp.status_code, 200)
self.assertEqual(json.loads(resp.content), {'launch': {'a': 1}}) self.assertEqual(json.loads(resp.content), {'launch': {'a': 1}})
self.mox.VerifyAll() self.mox.VerifyAll()
@ -846,7 +846,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_get_usage_delete_for_nova(self): def test_get_usage_delete_for_nova(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'nova'} fake_request.GET = {}
delete = {'a': 1} delete = {'a': 1}
self.mox.StubOutWithMock(dbapi, '_get_model_by_id') self.mox.StubOutWithMock(dbapi, '_get_model_by_id')
dbapi._get_model_by_id(models.InstanceDeletes, 1).AndReturn(delete) dbapi._get_model_by_id(models.InstanceDeletes, 1).AndReturn(delete)
@ -860,13 +860,13 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_get_usage_delete_for_glance(self): def test_get_usage_delete_for_glance(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
delete = {'a': 1} delete = {'a': 1}
self.mox.StubOutWithMock(dbapi, '_get_model_by_id') self.mox.StubOutWithMock(dbapi, '_get_model_by_id')
dbapi._get_model_by_id(models.ImageDeletes, 1).AndReturn(delete) dbapi._get_model_by_id(models.ImageDeletes, 1).AndReturn(delete)
self.mox.ReplayAll() self.mox.ReplayAll()
resp = dbapi.get_usage_delete(fake_request, 1) resp = dbapi.get_usage_delete_glance(fake_request, 1)
self.assertEqual(resp.status_code, 200) self.assertEqual(resp.status_code, 200)
self.assertEqual(json.loads(resp.content), {'delete': {'a': 1}}) self.assertEqual(json.loads(resp.content), {'delete': {'a': 1}})
self.mox.VerifyAll() self.mox.VerifyAll()
@ -891,7 +891,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_list_usage_deletes_for_nova(self): def test_list_usage_deletes_for_nova(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'nova'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
mock_objects = self.mox.CreateMockAnything() mock_objects = self.mox.CreateMockAnything()
deletes = {'a': 1} deletes = {'a': 1}
@ -908,7 +908,7 @@ class DBAPITestCase(StacktachBaseTestCase):
def test_list_usage_deletes_for_glance(self): def test_list_usage_deletes_for_glance(self):
fake_request = self.mox.CreateMockAnything() fake_request = self.mox.CreateMockAnything()
fake_request.method = 'GET' fake_request.method = 'GET'
fake_request.GET = {'service': 'glance'} fake_request.GET = {}
self.mox.StubOutWithMock(dbapi, 'get_db_objects') self.mox.StubOutWithMock(dbapi, 'get_db_objects')
mock_objects = self.mox.CreateMockAnything() mock_objects = self.mox.CreateMockAnything()
deletes = {'a': 1} deletes = {'a': 1}
@ -917,7 +917,7 @@ class DBAPITestCase(StacktachBaseTestCase):
dbapi.get_db_objects(models.ImageDeletes, fake_request, 'deleted_at').AndReturn(mock_objects) dbapi.get_db_objects(models.ImageDeletes, fake_request, 'deleted_at').AndReturn(mock_objects)
self.mox.ReplayAll() self.mox.ReplayAll()
resp = dbapi.list_usage_deletes(fake_request) resp = dbapi.list_usage_deletes_glance(fake_request)
self.assertEqual(resp.status_code, 200) self.assertEqual(resp.status_code, 200)
self.assertEqual(json.loads(resp.content), {'deletes': deletes}) self.assertEqual(json.loads(resp.content), {'deletes': deletes})
self.mox.VerifyAll() self.mox.VerifyAll()