summaryrefslogtreecommitdiff
path: root/tests/test_authentication.py
blob: 418dbd82eaa6e9cae4d5f5bacc8d3b01ff2fb8fa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
from paste import wsgilib
from paste import login
from paste.fixture import *

from_cmdline = 0

def application(environ, start_response):
    if environ.has_key('REMOTE_USER'):
	start_response('200 OK', [('Content-type', 'text/plain')])
	return ['Logged in: ' + environ['REMOTE_USER']]
    else:
	start_response('401 Unauthorized',
                       [('Content-type', 'text/plain')])
	return ['Not logged in.']

class AuthTest(login.Authenticator):
    def check_auth(self, username, password):
        return username == password

def report(res):
    if from_cmdline:
        print res
        
# @@ this should be part of a test fixture, I think
def mk_basic_auth_app(**kw):
    kw['http_login'] = True
    kw['authenticator'] =  AuthTest
    app = login.middleware(application, **kw)
    testapp = TestApp(app)
    return testapp
    
def test_basicauth_noauth():
    res = mk_basic_auth_app().get('/', status=401)
    report(res)

def run_userpass(user, password, status=200):
    userpass = user + ':' + password
    env = {'AUTHORIZATION' : 'Basic ' + userpass.encode('base64')}
    return mk_basic_auth_app().get('/', headers=env, status=status)

def test_basicauth_okuser():
    res = run_userpass('test', 'test') # should succeed
    report(res)

def test_basicauth_baduser():
    res = run_userpass('test', 'badpass',
                       status=401) # should succeed
    report(res)

def test_basicauth_cookie():
    res = run_userpass('test', 'test') # should succeed
    report(res)
    cookie_val = res.header('SET-COOKIE')
    print "cookie value", cookie_val
    app = mk_basic_auth_app()
    env = {'Cookie': cookie_val}
    res = app.get('/', headers=env)
    report(res)
    
    # ensure that secret is actually used
    res = mk_basic_auth_app(secret='bogus').get(
        '/', headers=env, status=401, expect_errors=True)
    report(res)

if __name__ == '__main__':
    from_cmdline = 1
    test_basicauth_noauth()
    test_basicauth_okuser()
    test_basicauth_baduser()
    test_basicauth_cookie()