Improved autocreate testing
Increase testing coverage and make some of the test more accurate (Some of the tests included too many responses from the account servers that were not used by the test) Change-Id: Ide2e0fcb89d5905e70d3111f7ac57b1cff23a99c Fixes: Bug #1172152
This commit is contained in:
parent
5d52d2d1cc
commit
0a75a9d509
@ -438,14 +438,16 @@ class TestController(unittest.TestCase):
|
|||||||
def test_account_info_account_autocreate(self):
|
def test_account_info_account_autocreate(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
self.memcache.store = {}
|
self.memcache.store = {}
|
||||||
set_http_connect(404, 404, 404, 201, 201, 201)
|
# account_info returns after 3 non 2xx responses unless autocreate
|
||||||
|
# is True
|
||||||
|
set_http_connect(404, 404, 404)
|
||||||
partition, nodes, count = \
|
partition, nodes, count = \
|
||||||
self.controller.account_info(self.account, autocreate=False)
|
self.controller.account_info(self.account, autocreate=False)
|
||||||
self.check_account_info_return(partition, nodes, is_none=True)
|
self.check_account_info_return(partition, nodes, is_none=True)
|
||||||
self.assertEquals(count, None)
|
self.assertEquals(count, None)
|
||||||
|
|
||||||
self.memcache.store = {}
|
self.memcache.store = {}
|
||||||
set_http_connect(404, 404, 404, 201, 201, 201)
|
set_http_connect(404, 404, 404)
|
||||||
partition, nodes, count = \
|
partition, nodes, count = \
|
||||||
self.controller.account_info(self.account)
|
self.controller.account_info(self.account)
|
||||||
self.check_account_info_return(partition, nodes, is_none=True)
|
self.check_account_info_return(partition, nodes, is_none=True)
|
||||||
@ -4464,7 +4466,7 @@ class TestContainerController(unittest.TestCase):
|
|||||||
res = method(req)
|
res = method(req)
|
||||||
self.assertEquals(res.status_int, expected)
|
self.assertEquals(res.status_int, expected)
|
||||||
|
|
||||||
def test_HEAD(self):
|
def test_HEAD_GET(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.ContainerController(self.app, 'account',
|
controller = proxy_server.ContainerController(self.app, 'account',
|
||||||
'container')
|
'container')
|
||||||
@ -4480,14 +4482,29 @@ class TestContainerController(unittest.TestCase):
|
|||||||
if expected < 400:
|
if expected < 400:
|
||||||
self.assert_('x-works' in res.headers)
|
self.assert_('x-works' in res.headers)
|
||||||
self.assertEquals(res.headers['x-works'], 'yes')
|
self.assertEquals(res.headers['x-works'], 'yes')
|
||||||
|
|
||||||
|
set_http_connect(*statuses, **kwargs)
|
||||||
|
self.app.memcache.store = {}
|
||||||
|
req = Request.blank('/a/c', {})
|
||||||
|
self.app.update_request(req)
|
||||||
|
res = controller.GET(req)
|
||||||
|
self.assertEquals(res.status[:len(str(expected))],
|
||||||
|
str(expected))
|
||||||
|
if expected < 400:
|
||||||
|
self.assert_('x-works' in res.headers)
|
||||||
|
self.assertEquals(res.headers['x-works'], 'yes')
|
||||||
test_status_map((200, 200, 404, 404), 200)
|
test_status_map((200, 200, 404, 404), 200)
|
||||||
test_status_map((200, 200, 500, 404), 200)
|
test_status_map((200, 200, 500, 404), 200)
|
||||||
test_status_map((200, 304, 500, 404), 304)
|
test_status_map((200, 304, 500, 404), 304)
|
||||||
test_status_map((200, 404, 404, 404), 404)
|
test_status_map((200, 404, 404, 404), 404)
|
||||||
test_status_map((200, 404, 404, 500), 404)
|
test_status_map((200, 404, 404, 500), 404)
|
||||||
test_status_map((200, 500, 500, 500), 503)
|
test_status_map((200, 500, 500, 500), 503)
|
||||||
|
self.assertFalse(self.app.account_autocreate)
|
||||||
|
test_status_map((404, 404, 404), 404)
|
||||||
|
self.app.account_autocreate = True
|
||||||
|
test_status_map((404, 404, 404), 404)
|
||||||
|
|
||||||
def test_PUT(self):
|
def test_PUT_POST(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.ContainerController(self.app, 'account',
|
controller = proxy_server.ContainerController(self.app, 'account',
|
||||||
'container')
|
'container')
|
||||||
@ -4501,10 +4518,28 @@ class TestContainerController(unittest.TestCase):
|
|||||||
res = controller.PUT(req)
|
res = controller.PUT(req)
|
||||||
expected = str(expected)
|
expected = str(expected)
|
||||||
self.assertEquals(res.status[:len(expected)], expected)
|
self.assertEquals(res.status[:len(expected)], expected)
|
||||||
|
|
||||||
|
set_http_connect(*statuses, **kwargs)
|
||||||
|
self.app.memcache.store = {}
|
||||||
|
req = Request.blank('/a/c', {})
|
||||||
|
req.content_length = 0
|
||||||
|
self.app.update_request(req)
|
||||||
|
res = controller.POST(req)
|
||||||
|
expected = str(expected)
|
||||||
|
self.assertEquals(res.status[:len(expected)], expected)
|
||||||
test_status_map((200, 201, 201, 201), 201, missing_container=True)
|
test_status_map((200, 201, 201, 201), 201, missing_container=True)
|
||||||
test_status_map((200, 201, 201, 500), 201, missing_container=True)
|
test_status_map((200, 201, 201, 500), 201, missing_container=True)
|
||||||
test_status_map((200, 204, 404, 404), 404, missing_container=True)
|
test_status_map((200, 204, 404, 404), 404, missing_container=True)
|
||||||
test_status_map((200, 204, 500, 404), 503, missing_container=True)
|
test_status_map((200, 204, 500, 404), 503, missing_container=True)
|
||||||
|
self.assertFalse(self.app.account_autocreate)
|
||||||
|
test_status_map((404, 404, 404), 404, missing_container=True)
|
||||||
|
self.app.account_autocreate = True
|
||||||
|
test_status_map((404, 404, 404, 201, 201, 201, 200, 200, 200), 200,
|
||||||
|
missing_container=True)
|
||||||
|
test_status_map((404, 404, 404, 403, 403, 403), 404,
|
||||||
|
missing_container=True)
|
||||||
|
test_status_map((404, 404, 404, 403, 201, 201, 403, 201, 201), 201,
|
||||||
|
missing_container=True)
|
||||||
|
|
||||||
def test_PUT_max_containers_per_account(self):
|
def test_PUT_max_containers_per_account(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
@ -4661,6 +4696,12 @@ class TestContainerController(unittest.TestCase):
|
|||||||
(200, 404, 404, 404), 404)
|
(200, 404, 404, 404), 404)
|
||||||
self.assert_status_map(controller.DELETE,
|
self.assert_status_map(controller.DELETE,
|
||||||
(200, 204, 503, 404), 503)
|
(200, 204, 503, 404), 503)
|
||||||
|
self.assertFalse(self.app.account_autocreate)
|
||||||
|
self.assert_status_map(controller.DELETE,
|
||||||
|
(404, 404, 404), 404)
|
||||||
|
self.app.account_autocreate = True
|
||||||
|
self.assert_status_map(controller.DELETE,
|
||||||
|
(404, 404, 404), 404)
|
||||||
|
|
||||||
self.app.memcache = FakeMemcacheReturnsNone()
|
self.app.memcache = FakeMemcacheReturnsNone()
|
||||||
# 200: Account check, 404x3: Container check
|
# 200: Account check, 404x3: Container check
|
||||||
@ -5254,20 +5295,21 @@ class TestAccountController(unittest.TestCase):
|
|||||||
def test_GET(self):
|
def test_GET(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.AccountController(self.app, 'account')
|
controller = proxy_server.AccountController(self.app, 'account')
|
||||||
self.assert_status_map(controller.GET, (200, 200, 200), 200)
|
# GET returns after the first successful call to an Account Server
|
||||||
self.assert_status_map(controller.GET, (200, 200, 503), 200)
|
self.assert_status_map(controller.GET, (200,), 200)
|
||||||
self.assert_status_map(controller.GET, (200, 503, 503), 200)
|
self.assert_status_map(controller.GET, (503, 200), 200)
|
||||||
self.assert_status_map(controller.GET, (204, 204, 204), 204)
|
self.assert_status_map(controller.GET, (503, 503, 200), 200)
|
||||||
self.assert_status_map(controller.GET, (204, 204, 503), 204)
|
self.assert_status_map(controller.GET, (204,), 204)
|
||||||
self.assert_status_map(controller.GET, (204, 503, 503), 204)
|
self.assert_status_map(controller.GET, (503, 204), 204)
|
||||||
self.assert_status_map(controller.GET, (204, 204, 200), 204)
|
self.assert_status_map(controller.GET, (503, 503, 204), 204)
|
||||||
self.assert_status_map(controller.GET, (204, 200, 200), 204)
|
self.assert_status_map(controller.GET, (404, 200), 200)
|
||||||
self.assert_status_map(controller.GET, (404, 404, 404), 404)
|
|
||||||
self.assert_status_map(controller.GET, (404, 404, 200), 200)
|
self.assert_status_map(controller.GET, (404, 404, 200), 200)
|
||||||
self.assert_status_map(controller.GET, (404, 200, 200), 200)
|
self.assert_status_map(controller.GET, (404, 503, 204), 204)
|
||||||
|
# If Account servers fail, if autocreate = False, return majority
|
||||||
|
# response
|
||||||
|
self.assert_status_map(controller.GET, (404, 404, 404), 404)
|
||||||
self.assert_status_map(controller.GET, (404, 404, 503), 404)
|
self.assert_status_map(controller.GET, (404, 404, 503), 404)
|
||||||
self.assert_status_map(controller.GET, (404, 503, 503), 503)
|
self.assert_status_map(controller.GET, (404, 503, 503), 503)
|
||||||
self.assert_status_map(controller.GET, (404, 204, 503), 204)
|
|
||||||
|
|
||||||
self.app.memcache = FakeMemcacheReturnsNone()
|
self.app.memcache = FakeMemcacheReturnsNone()
|
||||||
self.assert_status_map(controller.GET, (404, 404, 404), 404)
|
self.assert_status_map(controller.GET, (404, 404, 404), 404)
|
||||||
@ -5276,35 +5318,49 @@ class TestAccountController(unittest.TestCase):
|
|||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.AccountController(self.app, 'account')
|
controller = proxy_server.AccountController(self.app, 'account')
|
||||||
self.app.memcache = FakeMemcacheReturnsNone()
|
self.app.memcache = FakeMemcacheReturnsNone()
|
||||||
|
# Repeat the test for autocreate = False and 404 by all
|
||||||
self.assert_status_map(controller.GET,
|
self.assert_status_map(controller.GET,
|
||||||
(404, 404, 404, 201, 201, 201, 204), 404)
|
(404, 404, 404, 201, 201, 201, 204), 404)
|
||||||
|
self.assert_status_map(controller.GET,
|
||||||
|
(404, 503, 404, 201, 201, 201, 204), 404)
|
||||||
|
# When autocreate is True, if none of the nodes respond 2xx
|
||||||
|
# And quorum of the nodes responded 404,
|
||||||
|
# ALL nodes are asked to create the account
|
||||||
|
# If successful, the GET request is repeated.
|
||||||
controller.app.account_autocreate = True
|
controller.app.account_autocreate = True
|
||||||
self.assert_status_map(controller.GET,
|
self.assert_status_map(controller.GET,
|
||||||
(404, 404, 404, 201, 201, 201, 204), 204)
|
(404, 404, 404, 201, 201, 201, 204), 204)
|
||||||
self.assert_status_map(controller.GET,
|
self.assert_status_map(controller.GET,
|
||||||
(404, 404, 404, 403, 403, 403, 403), 403)
|
(404, 503, 404, 201, 503, 201, 204), 204)
|
||||||
|
# Test a case when less than quorum responded 2xx during
|
||||||
|
# account create
|
||||||
self.assert_status_map(controller.GET,
|
self.assert_status_map(controller.GET,
|
||||||
(404, 404, 404, 409, 409, 409, 409), 409)
|
(404, 404, 404, 201, 409, 409), 409)
|
||||||
|
self.assert_status_map(controller.GET,
|
||||||
|
(404, 404, 404, 403, 403, 403), 403)
|
||||||
|
self.assert_status_map(controller.GET,
|
||||||
|
(404, 503, 404, 403, 503, 403), 403)
|
||||||
|
|
||||||
def test_HEAD(self):
|
def test_HEAD(self):
|
||||||
|
# Same behaviour as GET
|
||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.AccountController(self.app, 'account')
|
controller = proxy_server.AccountController(self.app, 'account')
|
||||||
self.assert_status_map(controller.HEAD, (200, 200, 200), 200)
|
self.assert_status_map(controller.HEAD, (200,), 200)
|
||||||
self.assert_status_map(controller.HEAD, (200, 200, 503), 200)
|
self.assert_status_map(controller.HEAD, (503, 200), 200)
|
||||||
self.assert_status_map(controller.HEAD, (200, 503, 503), 200)
|
self.assert_status_map(controller.HEAD, (503, 503, 200), 200)
|
||||||
self.assert_status_map(controller.HEAD, (204, 204, 204), 204)
|
self.assert_status_map(controller.HEAD, (204,), 204)
|
||||||
self.assert_status_map(controller.HEAD, (204, 204, 503), 204)
|
self.assert_status_map(controller.HEAD, (503, 204), 204)
|
||||||
self.assert_status_map(controller.HEAD, (204, 503, 503), 204)
|
self.assert_status_map(controller.HEAD, (204, 503, 503), 204)
|
||||||
self.assert_status_map(controller.HEAD, (204, 204, 200), 204)
|
self.assert_status_map(controller.HEAD, (204,), 204)
|
||||||
self.assert_status_map(controller.HEAD, (204, 200, 200), 204)
|
|
||||||
self.assert_status_map(controller.HEAD, (404, 404, 404), 404)
|
self.assert_status_map(controller.HEAD, (404, 404, 404), 404)
|
||||||
self.assert_status_map(controller.HEAD, (404, 404, 200), 200)
|
self.assert_status_map(controller.HEAD, (404, 404, 200), 200)
|
||||||
self.assert_status_map(controller.HEAD, (404, 200, 200), 200)
|
self.assert_status_map(controller.HEAD, (404, 200), 200)
|
||||||
self.assert_status_map(controller.HEAD, (404, 404, 503), 404)
|
self.assert_status_map(controller.HEAD, (404, 404, 503), 404)
|
||||||
self.assert_status_map(controller.HEAD, (404, 503, 503), 503)
|
self.assert_status_map(controller.HEAD, (404, 503, 503), 503)
|
||||||
self.assert_status_map(controller.HEAD, (404, 204, 503), 204)
|
self.assert_status_map(controller.HEAD, (404, 503, 204), 204)
|
||||||
|
|
||||||
def test_HEAD_autocreate(self):
|
def test_HEAD_autocreate(self):
|
||||||
|
# Same behaviour as GET
|
||||||
with save_globals():
|
with save_globals():
|
||||||
controller = proxy_server.AccountController(self.app, 'account')
|
controller = proxy_server.AccountController(self.app, 'account')
|
||||||
self.app.memcache = FakeMemcacheReturnsNone()
|
self.app.memcache = FakeMemcacheReturnsNone()
|
||||||
@ -5314,9 +5370,9 @@ class TestAccountController(unittest.TestCase):
|
|||||||
self.assert_status_map(controller.HEAD,
|
self.assert_status_map(controller.HEAD,
|
||||||
(404, 404, 404, 201, 201, 201, 204), 204)
|
(404, 404, 404, 201, 201, 201, 204), 204)
|
||||||
self.assert_status_map(controller.HEAD,
|
self.assert_status_map(controller.HEAD,
|
||||||
(404, 404, 404, 403, 403, 403, 403), 403)
|
(404, 404, 404, 201, 409, 409), 409)
|
||||||
self.assert_status_map(controller.HEAD,
|
self.assert_status_map(controller.HEAD,
|
||||||
(404, 404, 404, 409, 409, 409, 409), 409)
|
(404, 404, 404, 201, 403, 201, 204), 204)
|
||||||
|
|
||||||
def test_POST_autocreate(self):
|
def test_POST_autocreate(self):
|
||||||
with save_globals():
|
with save_globals():
|
||||||
@ -5328,9 +5384,13 @@ class TestAccountController(unittest.TestCase):
|
|||||||
self.assert_status_map(controller.POST,
|
self.assert_status_map(controller.POST,
|
||||||
(404, 404, 404, 201, 201, 201), 201)
|
(404, 404, 404, 201, 201, 201), 201)
|
||||||
self.assert_status_map(controller.POST,
|
self.assert_status_map(controller.POST,
|
||||||
(404, 404, 404, 403, 403, 403, 403), 403)
|
(404, 404, 404, 403, 403, 403), 403)
|
||||||
self.assert_status_map(controller.POST,
|
self.assert_status_map(controller.POST,
|
||||||
(404, 404, 404, 409, 409, 409, 409), 409)
|
(404, 404, 404, 409, 409, 409), 409)
|
||||||
|
self.assert_status_map(controller.POST,
|
||||||
|
(404, 404, 404, 201, 409, 409), 409)
|
||||||
|
self.assert_status_map(controller.POST,
|
||||||
|
(404, 404, 404, 201, 201, 409), 201)
|
||||||
|
|
||||||
def test_connection_refused(self):
|
def test_connection_refused(self):
|
||||||
self.app.account_ring.get_nodes('account')
|
self.app.account_ring.get_nodes('account')
|
||||||
|
Loading…
Reference in New Issue
Block a user