Commit 5333bd7d by John Cox

Fix bug that prevented account association during registration

parent f7683833
...@@ -350,7 +350,7 @@ def redirect_to_supplementary_form(strategy, details, response, uid, is_dashboar ...@@ -350,7 +350,7 @@ def redirect_to_supplementary_form(strategy, details, response, uid, is_dashboar
user_inactive = user and not user.is_active user_inactive = user and not user.is_active
user_unset = user is None user_unset = user is None
dispatch_to_login = (is_login and user_unset) or user_inactive dispatch_to_login = is_login and (user_unset or user_inactive)
if is_dashboard: if is_dashboard:
return return
......
...@@ -640,21 +640,17 @@ class IntegrationTest(testutil.TestCase, test.TestCase): ...@@ -640,21 +640,17 @@ class IntegrationTest(testutil.TestCase, test.TestCase):
created_user = self.get_user_by_email(strategy, email) created_user = self.get_user_by_email(strategy, email)
self.assert_password_overridden_by_pipeline(overridden_password, created_user.username) self.assert_password_overridden_by_pipeline(overridden_password, created_user.username)
# The user's account isn't created yet, so an attempt to complete the # At this point the user object exists, but there is no associated
# pipeline will error out on /login: # social auth.
self.assert_redirect_to_login_looks_correct( self.assert_social_auth_does_not_exist_for_user(created_user, strategy)
actions.do_complete(strategy, social_views._do_login, user=created_user))
# So we activate the account in order to verify the redirect to /dashboard:
created_user.is_active = True
created_user.save()
# Last step in the pipeline: we re-invoke the pipeline and expect to # Pick the pipeline back up. This will create the account association
# end up on /dashboard, with the correct social auth object now in the # and send the user to the dashboard, where the association will be
# backend and the correct user's data on display. # displayed.
self.assert_redirect_to_dashboard_looks_correct( self.assert_redirect_to_dashboard_looks_correct(
actions.do_complete(strategy, social_views._do_login, user=created_user)) actions.do_complete(strategy, social_views._do_login, user=created_user))
self.assert_social_auth_exists_for_user(created_user, strategy) self.assert_social_auth_exists_for_user(created_user, strategy)
self.assert_dashboard_response_looks_correct(student_views.dashboard(request), created_user) self.assert_dashboard_response_looks_correct(student_views.dashboard(request), created_user, linked=True)
def test_new_account_registration_assigns_distinct_username_on_collision(self): def test_new_account_registration_assigns_distinct_username_on_collision(self):
original_username = self.get_username() original_username = self.get_username()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment