You've already forked httpie-cli
mirror of
https://github.com/httpie/cli.git
synced 2025-06-15 00:15:06 +02:00
Improved auth tests.
This commit is contained in:
@ -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'}
|
||||
|
Reference in New Issue
Block a user