Fixed bug with account_info
There was a bug where account_info wasn't converting the container_count value to an int. Causes max container count cap to get hit pretty quick since '0' > 0. Change-Id: Ibfc6eebbff5a00aaebb47e9731dd053b60e3caa4
This commit is contained in:
parent
5e427e5e3b
commit
f6d1fa1c15
@ -387,7 +387,10 @@ class Controller(object):
|
|||||||
container_count = 0
|
container_count = 0
|
||||||
else:
|
else:
|
||||||
result_code = cache_value['status']
|
result_code = cache_value['status']
|
||||||
container_count = cache_value['container_count']
|
try:
|
||||||
|
container_count = int(cache_value['container_count'])
|
||||||
|
except ValueError:
|
||||||
|
container_count = 0
|
||||||
if result_code == HTTP_OK:
|
if result_code == HTTP_OK:
|
||||||
return partition, nodes, container_count
|
return partition, nodes, container_count
|
||||||
elif result_code == HTTP_NOT_FOUND and not autocreate:
|
elif result_code == HTTP_NOT_FOUND and not autocreate:
|
||||||
@ -456,7 +459,11 @@ class Controller(object):
|
|||||||
account_info,
|
account_info,
|
||||||
time=cache_timeout)
|
time=cache_timeout)
|
||||||
if result_code == HTTP_OK:
|
if result_code == HTTP_OK:
|
||||||
return partition, nodes, account_info['container_count']
|
try:
|
||||||
|
container_count = int(account_info['container_count'])
|
||||||
|
except ValueError:
|
||||||
|
container_count = 0
|
||||||
|
return partition, nodes, container_count
|
||||||
return None, None, None
|
return None, None, None
|
||||||
|
|
||||||
def container_info(self, account, container, account_autocreate=False):
|
def container_info(self, account, container, account_autocreate=False):
|
||||||
|
@ -247,7 +247,7 @@ def fake_http_connect(*code_iter, **kwargs):
|
|||||||
'x-object-meta-test': 'testing',
|
'x-object-meta-test': 'testing',
|
||||||
'etag': etag,
|
'etag': etag,
|
||||||
'x-works': 'yes',
|
'x-works': 'yes',
|
||||||
'x-account-container-count': 12345}
|
'x-account-container-count': kwargs.get('count', 12345)}
|
||||||
if not self.timestamp:
|
if not self.timestamp:
|
||||||
del headers['x-timestamp']
|
del headers['x-timestamp']
|
||||||
try:
|
try:
|
||||||
@ -445,6 +445,32 @@ class TestController(unittest.TestCase):
|
|||||||
self.assertEqual(p, partition)
|
self.assertEqual(p, partition)
|
||||||
self.assertEqual(n, nodes)
|
self.assertEqual(n, nodes)
|
||||||
|
|
||||||
|
def test_account_info_container_count(self):
|
||||||
|
with save_globals():
|
||||||
|
set_http_connect(200, count=123)
|
||||||
|
partition, nodes, count = \
|
||||||
|
self.controller.account_info(self.account)
|
||||||
|
self.assertEquals(count, 123)
|
||||||
|
with save_globals():
|
||||||
|
set_http_connect(200, count='123')
|
||||||
|
partition, nodes, count = \
|
||||||
|
self.controller.account_info(self.account)
|
||||||
|
self.assertEquals(count, 123)
|
||||||
|
with save_globals():
|
||||||
|
cache_key = get_account_memcache_key(self.account)
|
||||||
|
account_info = {'status': 200, 'container_count': 1234}
|
||||||
|
self.memcache.set(cache_key, account_info)
|
||||||
|
partition, nodes, count = \
|
||||||
|
self.controller.account_info(self.account)
|
||||||
|
self.assertEquals(count, 1234)
|
||||||
|
with save_globals():
|
||||||
|
cache_key = get_account_memcache_key(self.account)
|
||||||
|
account_info = {'status': 200, 'container_count': '1234'}
|
||||||
|
self.memcache.set(cache_key, account_info)
|
||||||
|
partition, nodes, count = \
|
||||||
|
self.controller.account_info(self.account)
|
||||||
|
self.assertEquals(count, 1234)
|
||||||
|
|
||||||
def test_make_requests(self):
|
def test_make_requests(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
set_http_connect(200)
|
set_http_connect(200)
|
||||||
|
Loading…
Reference in New Issue
Block a user