Added unit tests for swift_auth_url @property. It was broken. startwith('swift+http') matches swift+https first
This commit is contained in:
parent
70b9389377
commit
a4fe58efec
@ -142,14 +142,10 @@ class StoreLocation(glance.store.location.StoreLocation):
|
|||||||
try:
|
try:
|
||||||
self.obj = path_parts.pop()
|
self.obj = path_parts.pop()
|
||||||
self.container = path_parts.pop()
|
self.container = path_parts.pop()
|
||||||
if self.scheme == 'swift+http':
|
|
||||||
self.authurl = 'http://'
|
|
||||||
else:
|
|
||||||
self.authurl = '' # default is https anyway
|
|
||||||
if not netloc.startswith('http'):
|
if not netloc.startswith('http'):
|
||||||
# push hostname back into the remaining to build full authurl
|
# push hostname back into the remaining to build full authurl
|
||||||
path_parts.insert(0, netloc)
|
path_parts.insert(0, netloc)
|
||||||
self.authurl += '/'.join(path_parts)
|
self.authurl = '/'.join(path_parts)
|
||||||
except IndexError:
|
except IndexError:
|
||||||
reason = "Badly formed Swift URI"
|
reason = "Badly formed Swift URI"
|
||||||
raise exception.BadStoreUri(uri, reason)
|
raise exception.BadStoreUri(uri, reason)
|
||||||
@ -163,16 +159,10 @@ class StoreLocation(glance.store.location.StoreLocation):
|
|||||||
|
|
||||||
HTTPS is assumed, unless 'swift+http' is specified.
|
HTTPS is assumed, unless 'swift+http' is specified.
|
||||||
"""
|
"""
|
||||||
if self.scheme.startswith('swift+http'):
|
if self.scheme in ('swift+https', 'swift'):
|
||||||
auth_scheme = 'http://'
|
|
||||||
elif self.scheme.startswith('swift+https'):
|
|
||||||
auth_scheme = 'https://'
|
|
||||||
elif self.scheme.startswith('swift'):
|
|
||||||
auth_scheme = 'https://'
|
auth_scheme = 'https://'
|
||||||
else:
|
else:
|
||||||
logger.warn("Unrecognized scheme '%s', defaulting auth url"
|
auth_scheme = 'http://'
|
||||||
" to https", self.scheme)
|
|
||||||
auth_scheme = 'https://'
|
|
||||||
|
|
||||||
full_url = ''.join([auth_scheme, self.authurl])
|
full_url = ''.join([auth_scheme, self.authurl])
|
||||||
return full_url
|
return full_url
|
||||||
|
@ -138,6 +138,7 @@ class TestStoreLocation(unittest.TestCase):
|
|||||||
|
|
||||||
self.assertEqual("swift", loc.scheme)
|
self.assertEqual("swift", loc.scheme)
|
||||||
self.assertEqual("example.com", loc.authurl)
|
self.assertEqual("example.com", loc.authurl)
|
||||||
|
self.assertEqual("https://example.com", loc.swift_auth_url)
|
||||||
self.assertEqual("images", loc.container)
|
self.assertEqual("images", loc.container)
|
||||||
self.assertEqual("1", loc.obj)
|
self.assertEqual("1", loc.obj)
|
||||||
self.assertEqual(None, loc.user)
|
self.assertEqual(None, loc.user)
|
||||||
@ -148,6 +149,7 @@ class TestStoreLocation(unittest.TestCase):
|
|||||||
|
|
||||||
self.assertEqual("swift+https", loc.scheme)
|
self.assertEqual("swift+https", loc.scheme)
|
||||||
self.assertEqual("authurl.com", loc.authurl)
|
self.assertEqual("authurl.com", loc.authurl)
|
||||||
|
self.assertEqual("https://authurl.com", loc.swift_auth_url)
|
||||||
self.assertEqual("images", loc.container)
|
self.assertEqual("images", loc.container)
|
||||||
self.assertEqual("1", loc.obj)
|
self.assertEqual("1", loc.obj)
|
||||||
self.assertEqual("user", loc.user)
|
self.assertEqual("user", loc.user)
|
||||||
@ -159,17 +161,19 @@ class TestStoreLocation(unittest.TestCase):
|
|||||||
|
|
||||||
self.assertEqual("swift+https", loc.scheme)
|
self.assertEqual("swift+https", loc.scheme)
|
||||||
self.assertEqual("authurl.com/v1", loc.authurl)
|
self.assertEqual("authurl.com/v1", loc.authurl)
|
||||||
|
self.assertEqual("https://authurl.com/v1", loc.swift_auth_url)
|
||||||
self.assertEqual("container", loc.container)
|
self.assertEqual("container", loc.container)
|
||||||
self.assertEqual("12345", loc.obj)
|
self.assertEqual("12345", loc.obj)
|
||||||
self.assertEqual("user", loc.user)
|
self.assertEqual("user", loc.user)
|
||||||
self.assertEqual("pass", loc.key)
|
self.assertEqual("pass", loc.key)
|
||||||
self.assertEqual(uri, loc.get_uri())
|
self.assertEqual(uri, loc.get_uri())
|
||||||
|
|
||||||
uri = 'swift://account:user:pass@authurl.com/v1/container/12345'
|
uri = 'swift+http://account:user:pass@authurl.com/v1/container/12345'
|
||||||
loc.parse_uri(uri)
|
loc.parse_uri(uri)
|
||||||
|
|
||||||
self.assertEqual("swift", loc.scheme)
|
self.assertEqual("swift+http", loc.scheme)
|
||||||
self.assertEqual("authurl.com/v1", loc.authurl)
|
self.assertEqual("authurl.com/v1", loc.authurl)
|
||||||
|
self.assertEqual("http://authurl.com/v1", loc.swift_auth_url)
|
||||||
self.assertEqual("container", loc.container)
|
self.assertEqual("container", loc.container)
|
||||||
self.assertEqual("12345", loc.obj)
|
self.assertEqual("12345", loc.obj)
|
||||||
self.assertEqual("account:user", loc.user)
|
self.assertEqual("account:user", loc.user)
|
||||||
|
Loading…
Reference in New Issue
Block a user