From 3c2de34285b0f78c6dfbc3994b5777f12883f27c Mon Sep 17 00:00:00 2001 From: Jakub Roztocil Date: Fri, 25 Apr 2014 13:10:01 +0200 Subject: [PATCH] Improved auth tests. --- tests/__init__.py | 14 +++++++++----- tests/test_auth.py | 43 +++++++++++++------------------------------ 2 files changed, 22 insertions(+), 35 deletions(-) diff --git a/tests/__init__.py b/tests/__init__.py index 8111224e..b23090f8 100644 --- a/tests/__init__.py +++ b/tests/__init__.py @@ -15,8 +15,6 @@ from httpie.compat import bytes, str TESTS_ROOT = os.path.abspath(os.path.dirname(__file__)) -HTTPBIN_URL = os.environ.get('HTTPBIN_URL', - 'http://httpbin.org').rstrip('/') CRLF = '\r\n' @@ -29,16 +27,22 @@ HTTP_OK_COLOR = ( ) -def httpbin(path): +def httpbin(path, auth=None, + base=os.environ.get('HTTPBIN_URL', 'http://httpbin.org')): """ Return a fully-qualified httpbin URL for `path`. >>> httpbin('/get') 'http://httpbin.org/get' + >>> httpbin('/get', auth='user:password') + 'http://user:password@httpbin.org/get' + """ - url = HTTPBIN_URL + path - return url + if auth: + proto, rest = base.split('://', 1) + base = proto + '://' + auth + '@' + rest + return base.rstrip('/') + path class TestEnvironment(Environment): diff --git a/tests/test_auth.py b/tests/test_auth.py index a66bd641..ca8f8705 100644 --- a/tests/test_auth.py +++ b/tests/test_auth.py @@ -8,53 +8,36 @@ import httpie.input class TestAuth: def test_basic_auth(self): - r = http('--auth=user:password', 'GET', - httpbin('/basic-auth/user/password')) + r = http('--auth=user:password', + 'GET', httpbin('/basic-auth/user/password')) assert HTTP_OK in r - assert r.json == { - 'authenticated': True, - 'user': 'user' - } + assert r.json == {'authenticated': True, 'user': 'user'} @pytest.mark.skipif( requests.__version__ == '0.13.6', reason='Redirects with prefetch=False are broken in Requests 0.13.6') def test_digest_auth(self): - r = http('--auth-type=digest', '--auth=user:password', 'GET', - httpbin('/digest-auth/auth/user/password')) + r = http('--auth-type=digest', '--auth=user:password', + 'GET', httpbin('/digest-auth/auth/user/password')) assert HTTP_OK in r - assert r.json == { - 'authenticated': True, - 'user': 'user' - } + assert r.json == {'authenticated': True, 'user': 'user'} def test_password_prompt(self): httpie.input.AuthCredentials._getpass = lambda self, prompt: 'password' r = http('--auth', 'user', 'GET', httpbin('/basic-auth/user/password')) assert HTTP_OK in r - assert r.json == { - 'authenticated': True, - 'user': 'user' - } + assert r.json == {'authenticated': True, 'user': 'user'} def test_credentials_in_url(self): - url = httpbin('/basic-auth/user/password') - url = 'http://user:password@' + url.split('http://', 1)[1] - r = http('GET', url) + r = http('GET', httpbin('/basic-auth/user/password', + auth='user:password')) assert HTTP_OK in r - assert r.json == { - 'authenticated': True, - 'user': 'user' - } + assert r.json == {'authenticated': True, 'user': 'user'} def test_credentials_in_url_auth_flag_has_priority(self): """When credentials are passed in URL and via -a at the same time, then the ones from -a are used.""" - url = httpbin('/basic-auth/user/password') - url = 'http://user:wrong_password@' + url.split('http://', 1)[1] - r = http('--auth=user:password', 'GET', url) + r = http('--auth=user:password', 'GET', + httpbin('/basic-auth/user/password', auth='user:wrong')) assert HTTP_OK in r - assert r.json == { - 'authenticated': True, - 'user': 'user' - } + assert r.json == {'authenticated': True, 'user': 'user'}