mirror of https://github.com/django/django.git
[1.5.x] Fixed #19349 -- Fixed re-rendering of ReadOnlyPasswordHashWidget
Thanks tim.bowden at mapforge.com.au for the report, Andreas Hug
for the patch and Anton Baklanov for the review.
Backport of a0cd6dd11
from master.
This commit is contained in:
parent
88638ddd3d
commit
676e4d5497
|
@ -27,7 +27,7 @@ class ReadOnlyPasswordHashWidget(forms.Widget):
|
||||||
encoded = value
|
encoded = value
|
||||||
final_attrs = self.build_attrs(attrs)
|
final_attrs = self.build_attrs(attrs)
|
||||||
|
|
||||||
if encoded == '' or encoded == UNUSABLE_PASSWORD:
|
if not encoded or encoded == UNUSABLE_PASSWORD:
|
||||||
summary = mark_safe("<strong>%s</strong>" % ugettext("No password set."))
|
summary = mark_safe("<strong>%s</strong>" % ugettext("No password set."))
|
||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
|
@ -52,6 +52,11 @@ class ReadOnlyPasswordHashField(forms.Field):
|
||||||
kwargs.setdefault("required", False)
|
kwargs.setdefault("required", False)
|
||||||
super(ReadOnlyPasswordHashField, self).__init__(*args, **kwargs)
|
super(ReadOnlyPasswordHashField, self).__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
def bound_data(self, data, initial):
|
||||||
|
# Always return initial because the widget doesn't
|
||||||
|
# render an input field.
|
||||||
|
return initial
|
||||||
|
|
||||||
|
|
||||||
class UserCreationForm(forms.ModelForm):
|
class UserCreationForm(forms.ModelForm):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -3,7 +3,8 @@ from __future__ import unicode_literals
|
||||||
import os
|
import os
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.contrib.auth.forms import (UserCreationForm, AuthenticationForm,
|
from django.contrib.auth.forms import (UserCreationForm, AuthenticationForm,
|
||||||
PasswordChangeForm, SetPasswordForm, UserChangeForm, PasswordResetForm)
|
PasswordChangeForm, SetPasswordForm, UserChangeForm, PasswordResetForm,
|
||||||
|
ReadOnlyPasswordHashWidget)
|
||||||
from django.contrib.auth.tests.utils import skipIfCustomUser
|
from django.contrib.auth.tests.utils import skipIfCustomUser
|
||||||
from django.core import mail
|
from django.core import mail
|
||||||
from django.forms.fields import Field, EmailField
|
from django.forms.fields import Field, EmailField
|
||||||
|
@ -282,6 +283,14 @@ class UserChangeFormTest(TestCase):
|
||||||
self.assertTrue(form.is_valid())
|
self.assertTrue(form.is_valid())
|
||||||
self.assertEqual(form.cleaned_data['password'], 'sha1$6efc0$f93efe9fd7542f25a7be94871ea45aa95de57161')
|
self.assertEqual(form.cleaned_data['password'], 'sha1$6efc0$f93efe9fd7542f25a7be94871ea45aa95de57161')
|
||||||
|
|
||||||
|
def test_bug_19349_bound_password_field(self):
|
||||||
|
user = User.objects.get(username='testclient')
|
||||||
|
form = UserChangeForm(data={}, instance=user)
|
||||||
|
# When rendering the bound password field,
|
||||||
|
# ReadOnlyPasswordHashWidget needs the initial
|
||||||
|
# value to render correctly
|
||||||
|
self.assertEqual(form.initial['password'], form['password'].value())
|
||||||
|
|
||||||
|
|
||||||
@skipIfCustomUser
|
@skipIfCustomUser
|
||||||
@override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',))
|
@override_settings(USE_TZ=False, PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',))
|
||||||
|
@ -362,3 +371,13 @@ class PasswordResetFormTest(TestCase):
|
||||||
self.assertFalse(form.is_valid())
|
self.assertFalse(form.is_valid())
|
||||||
self.assertEqual(form["email"].errors,
|
self.assertEqual(form["email"].errors,
|
||||||
[_("The user account associated with this email address cannot reset the password.")])
|
[_("The user account associated with this email address cannot reset the password.")])
|
||||||
|
|
||||||
|
|
||||||
|
class ReadOnlyPasswordHashWidgetTest(TestCase):
|
||||||
|
|
||||||
|
def test_bug_19349_render_with_none_value(self):
|
||||||
|
# Rendering the widget with value set to None
|
||||||
|
# mustn't raise an exception.
|
||||||
|
widget = ReadOnlyPasswordHashWidget()
|
||||||
|
html = widget.render(name='password', value=None, attrs={})
|
||||||
|
self.assertIn(_("No password set."), html)
|
||||||
|
|
Loading…
Reference in New Issue