aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/tests/test_auth.py
diff options
context:
space:
mode:
authorChristopher Allan Webber <cwebber@dustycloud.org>2011-06-18 11:10:46 -0500
committerChristopher Allan Webber <cwebber@dustycloud.org>2011-06-18 11:10:46 -0500
commitc897283849abbe7f7e6506c2c3b179ff0fd3f9d2 (patch)
treed545dc3fe7a3a2c2c9cadab630d815c47776e54a /mediagoblin/tests/test_auth.py
parente2c6436e3e7c654a8d4196ac378debf185c74fa4 (diff)
parent5a994e37c2947d20e3aedfb78f9d6194dd59d506 (diff)
downloadmediagoblin-c897283849abbe7f7e6506c2c3b179ff0fd3f9d2.tar.lz
mediagoblin-c897283849abbe7f7e6506c2c3b179ff0fd3f9d2.tar.xz
mediagoblin-c897283849abbe7f7e6506c2c3b179ff0fd3f9d2.zip
Merge branch 'master' into configobj
Conflicts: setup.py
Diffstat (limited to 'mediagoblin/tests/test_auth.py')
-rw-r--r--mediagoblin/tests/test_auth.py48
1 files changed, 43 insertions, 5 deletions
diff --git a/mediagoblin/tests/test_auth.py b/mediagoblin/tests/test_auth.py
index 3d569093..b8389f8d 100644
--- a/mediagoblin/tests/test_auth.py
+++ b/mediagoblin/tests/test_auth.py
@@ -77,7 +77,7 @@ def test_register_views(test_app):
# Make sure it rendered with the appropriate template
assert util.TEMPLATE_TEST_CONTEXT.has_key(
'mediagoblin/auth/register.html')
-
+
# Try to register without providing anything, should error
# --------------------------------------------------------
@@ -182,7 +182,7 @@ def test_register_views(test_app):
unicode(new_user['_id'])]
assert parsed_get_params['token'] == [
new_user['verification_key']]
-
+
## Try verifying with bs verification key, shouldn't work
util.clear_test_template_context()
test_app.get(
@@ -209,8 +209,6 @@ def test_register_views(test_app):
assert new_user['status'] == u'active'
assert new_user['email_verified'] == True
- ## TODO: Try logging in
-
# Uniqueness checks
# -----------------
## We shouldn't be able to register with that user twice
@@ -221,7 +219,7 @@ def test_register_views(test_app):
'password': 'iamsohappy2',
'confirm_password': 'iamsohappy2',
'email': 'happygrrl2@example.org'})
-
+
context = util.TEMPLATE_TEST_CONTEXT[
'mediagoblin/auth/register.html']
form = context['register_form']
@@ -229,3 +227,43 @@ def test_register_views(test_app):
u'Sorry, a user with that name already exists.']
## TODO: Also check for double instances of an email address?
+
+
+@setup_fresh_app
+def test_authentication_views(test_app):
+ """
+ Test logging in and logging out
+ """
+ # Make a new user
+ test_user = mg_globals.database.User()
+ test_user['username'] = u'chris'
+ test_user['email'] = u'chris@example.com'
+ test_user['pw_hash'] = auth_lib.bcrypt_gen_password_hash('toast')
+ test_user.save()
+
+ # Get login
+ test_app.get('/auth/login/')
+ # Make sure it rendered with the appropriate template
+ assert util.TEMPLATE_TEST_CONTEXT.has_key(
+ 'mediagoblin/auth/login.html')
+
+ # Log in as that user
+ util.clear_test_template_context()
+ response = test_app.post(
+ '/auth/login/', {
+ 'username': u'chris',
+ 'password': 'toast'})
+ response.follow()
+ assert_equal(
+ urlparse.urlsplit(response.location)[2],
+ '/')
+ assert util.TEMPLATE_TEST_CONTEXT.has_key(
+ 'mediagoblin/root.html')
+
+ # Make sure we're in the session or something
+ session = util.TEMPLATE_TEST_CONTEXT['mediagoblin/root.html']['request'].session
+ assert session['user_id'] == unicode(test_user['_id'])
+
+ # Log out as that user
+ # Make sure we're not in the session
+