Changeset 7694
- Timestamp:
- 06/18/08 14:05:16 (5 months ago)
- Files:
Legend:
- Unmodified
- Added
- Removed
- Modified
- Copied
- Moved
django/branches/newforms-admin/django/contrib/admin/sites.py
r7638 r7694 227 227 try: 228 228 user = User.objects.get(email=username) 229 except User.DoesNotExist:229 except (User.DoesNotExist, User.MultipleObjectsReturned): 230 230 message = _("Usernames cannot contain the '@' character.") 231 231 else: 232 message = _("Your e-mail address is not your username. Try '%s' instead.") % user.username 232 if user.check_password(password): 233 message = _("Your e-mail address is not your username." 234 " Try '%s' instead." % user.username) 235 else: 236 message = _("Usernames cannot contain the '@' character.") 233 237 return self.display_login_form(request, message) 234 238 django/branches/newforms-admin/tests/regressiontests/admin_views/tests.py
r7685 r7694 50 50 'username': 'super', 51 51 'password': 'secret'} 52 self.super_email_login = {'post_data': _encode_post_data({}), 53 LOGIN_FORM_KEY: 1, 54 'username': 'super@example.com', 55 'password': 'secret'} 56 self.super_email_bad_login = {'post_data': _encode_post_data({}), 57 LOGIN_FORM_KEY: 1, 58 'username': 'super@example.com', 59 'password': 'notsecret'} 52 60 self.adduser_login = {'post_data': _encode_post_data({}), 53 61 LOGIN_FORM_KEY: 1, … … 83 91 self.assertFalse(login.context) 84 92 self.client.get('/test_admin/admin/logout/') 93 94 # Test if user enters e-mail address 95 request = self.client.get('/test_admin/admin/') 96 self.failUnlessEqual(request.status_code, 200) 97 login = self.client.post('/test_admin/admin/', self.super_email_login) 98 print login 99 self.assertContains(login, "Your e-mail address is not your username") 100 # only correct passwords get a username hint 101 login = self.client.post('/test_admin/admin/', self.super_email_bad_login) 102 self.assertContains(login, "Usernames cannot contain the '@' character") 103 new_user = User(username='jondoe', password='secret', email='super@example.com') 104 new_user.save() 105 # check to ensure if there are multiple e-mail addresses a user doesn't get a 500 106 login = self.client.post('/test_admin/admin/', self.super_email_login) 107 self.assertContains(login, "Usernames cannot contain the '@' character") 85 108 86 109 # Add User
