Encode username and password for basic auth
This is to ensure session creation also works if username and password contain unicode characters. Otherwise, python's requests will use latin-1 to encode these string. Change-Id: Ia2a1c26cffe213d23cafcf5c33b6f82b8ef364e5
This commit is contained in:
parent
c8a80f7e6f
commit
e843f3a734
@ -74,7 +74,9 @@ class RequestsHTTPProviderTestCase(unittest.TestCase):
|
|||||||
mock_api, cluster.Provider('9.8.7.6', 'https://9.8.7.6',
|
mock_api, cluster.Provider('9.8.7.6', 'https://9.8.7.6',
|
||||||
'nsxuser', password, None))
|
'nsxuser', password, None))
|
||||||
|
|
||||||
self.assertEqual(('nsxuser', password), session.auth)
|
self.assertEqual(('nsxuser'.encode('utf-8'),
|
||||||
|
password.encode('utf-8')),
|
||||||
|
session.auth)
|
||||||
self.assertFalse(session.verify)
|
self.assertFalse(session.verify)
|
||||||
self.assertIsNone(session.cert)
|
self.assertIsNone(session.cert)
|
||||||
self.assertEqual(100,
|
self.assertEqual(100,
|
||||||
|
@ -214,7 +214,8 @@ class NSXRequestsHTTPProvider(AbstractHTTPProvider):
|
|||||||
# Set the headers with Auth info when token provider is set,
|
# Set the headers with Auth info when token provider is set,
|
||||||
# otherwise set the username and password
|
# otherwise set the username and password
|
||||||
elif not config.token_provider:
|
elif not config.token_provider:
|
||||||
session.auth = (provider.username, provider.password)
|
session.auth = (provider.username.encode('utf-8'),
|
||||||
|
provider.password.encode('utf-8'))
|
||||||
|
|
||||||
# NSX v3 doesn't use redirects
|
# NSX v3 doesn't use redirects
|
||||||
session.max_redirects = 0
|
session.max_redirects = 0
|
||||||
|
Loading…
x
Reference in New Issue
Block a user