Fixed #9859 -- Added another missing force_unicode needed in admin when running on Python 2.3. Many thanks for report & patch to nfg.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@9656 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
5f78eff909
commit
10894da8a8
|
@ -104,7 +104,7 @@ def get_deleted_objects(deleted_objects, perms_needed, user, obj, opts, current_
|
||||||
if not has_admin:
|
if not has_admin:
|
||||||
# Don't display link to edit, because it either has no
|
# Don't display link to edit, because it either has no
|
||||||
# admin or is edited inline.
|
# admin or is edited inline.
|
||||||
nh(deleted_objects, current_depth, [u'%s: %s' % (force_unicode(capfirst(related.opts.verbose_name)), sub_obj), []])
|
nh(deleted_objects, current_depth, [u'%s: %s' % (capfirst(related.opts.verbose_name), force_unicode(sub_obj)), []])
|
||||||
else:
|
else:
|
||||||
# Display a link to the admin page.
|
# Display a link to the admin page.
|
||||||
nh(deleted_objects, current_depth, [mark_safe(u'%s: <a href="../../../../%s/%s/%s/">%s</a>' % \
|
nh(deleted_objects, current_depth, [mark_safe(u'%s: <a href="../../../../%s/%s/%s/">%s</a>' % \
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<django-objects version="1.0">
|
||||||
|
<object pk="100" model="auth.user">
|
||||||
|
<field type="CharField" name="username">super</field>
|
||||||
|
<field type="CharField" name="first_name">Super</field>
|
||||||
|
<field type="CharField" name="last_name">User</field>
|
||||||
|
<field type="CharField" name="email">super@example.com</field>
|
||||||
|
<field type="CharField" name="password">sha1$995a3$6011485ea3834267d719b4c801409b8b1ddd0158</field>
|
||||||
|
<field type="BooleanField" name="is_staff">True</field>
|
||||||
|
<field type="BooleanField" name="is_active">True</field>
|
||||||
|
<field type="BooleanField" name="is_superuser">True</field>
|
||||||
|
<field type="DateTimeField" name="last_login">2007-05-30 13:20:10</field>
|
||||||
|
<field type="DateTimeField" name="date_joined">2007-05-30 13:20:10</field>
|
||||||
|
<field to="auth.group" name="groups" rel="ManyToManyRel"></field>
|
||||||
|
<field to="auth.permission" name="user_permissions" rel="ManyToManyRel"></field>
|
||||||
|
</object>
|
||||||
|
<object pk="1" model="admin_views.book">
|
||||||
|
<field type="CharField" name="name">Lærdommer</field>
|
||||||
|
</object>
|
||||||
|
<object pk="1" model="admin_views.chapter">
|
||||||
|
<field type="CharField" name="title">Norske bostaver æøå skaper problemer</field>
|
||||||
|
<field type="TextField" name="content"><p>Svært frustrerende med UnicodeDecodeErro</p></field>
|
||||||
|
<field to="admin_views.book" name="book" rel="ManyToOneRel">1</field>
|
||||||
|
</object>
|
||||||
|
<object pk="2" model="admin_views.chapter">
|
||||||
|
<field type="CharField" name="title">Kjærlighet</field>
|
||||||
|
<field type="TextField" name="content"><p>La kjærligheten til de lidende seire.</p></field>
|
||||||
|
<field to="admin_views.book" name="book" rel="ManyToOneRel">1</field>
|
||||||
|
</object>
|
||||||
|
<object pk="3" model="admin_views.chapter">
|
||||||
|
<field type="CharField" name="title">Kjærlighet</field>
|
||||||
|
<field type="TextField" name="content"><p>Noe innhold</p></field>
|
||||||
|
<field to="admin_views.book" name="book" rel="ManyToOneRel">1</field>
|
||||||
|
</object>
|
||||||
|
</django-objects>
|
|
@ -24,6 +24,20 @@ class Article(models.Model):
|
||||||
return self.date.year
|
return self.date.year
|
||||||
model_year.admin_order_field = 'date'
|
model_year.admin_order_field = 'date'
|
||||||
|
|
||||||
|
class Book(models.Model):
|
||||||
|
"""
|
||||||
|
A simple book that has chapters.
|
||||||
|
"""
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
class Chapter(models.Model):
|
||||||
|
title = models.CharField(max_length=100)
|
||||||
|
content = models.TextField()
|
||||||
|
book = models.ForeignKey(Book)
|
||||||
|
|
||||||
|
def __unicode__(self):
|
||||||
|
return self.title
|
||||||
|
|
||||||
def callable_year(dt_value):
|
def callable_year(dt_value):
|
||||||
return dt_value.year
|
return dt_value.year
|
||||||
callable_year.admin_order_field = 'date'
|
callable_year.admin_order_field = 'date'
|
||||||
|
@ -31,6 +45,9 @@ callable_year.admin_order_field = 'date'
|
||||||
class ArticleInline(admin.TabularInline):
|
class ArticleInline(admin.TabularInline):
|
||||||
model = Article
|
model = Article
|
||||||
|
|
||||||
|
class ChapterInline(admin.TabularInline):
|
||||||
|
model = Chapter
|
||||||
|
|
||||||
class ArticleAdmin(admin.ModelAdmin):
|
class ArticleAdmin(admin.ModelAdmin):
|
||||||
list_display = ('content', 'date', callable_year, 'model_year', 'modeladmin_year')
|
list_display = ('content', 'date', callable_year, 'model_year', 'modeladmin_year')
|
||||||
list_filter = ('date',)
|
list_filter = ('date',)
|
||||||
|
@ -92,6 +109,7 @@ class ThingAdmin(admin.ModelAdmin):
|
||||||
admin.site.register(Article, ArticleAdmin)
|
admin.site.register(Article, ArticleAdmin)
|
||||||
admin.site.register(CustomArticle, CustomArticleAdmin)
|
admin.site.register(CustomArticle, CustomArticleAdmin)
|
||||||
admin.site.register(Section, inlines=[ArticleInline])
|
admin.site.register(Section, inlines=[ArticleInline])
|
||||||
|
admin.site.register(Book, inlines=[ChapterInline])
|
||||||
admin.site.register(ModelWithStringPrimaryKey)
|
admin.site.register(ModelWithStringPrimaryKey)
|
||||||
admin.site.register(Color)
|
admin.site.register(Color)
|
||||||
admin.site.register(Thing, ThingAdmin)
|
admin.site.register(Thing, ThingAdmin)
|
||||||
|
|
|
@ -684,3 +684,54 @@ class SecureViewTest(TestCase):
|
||||||
self.client.post('/test_admin/admin/secure-view/', self.super_login)
|
self.client.post('/test_admin/admin/secure-view/', self.super_login)
|
||||||
# make sure the view removes test cookie
|
# make sure the view removes test cookie
|
||||||
self.failUnlessEqual(self.client.session.test_cookie_worked(), False)
|
self.failUnlessEqual(self.client.session.test_cookie_worked(), False)
|
||||||
|
|
||||||
|
class AdminViewUnicodeTest(TestCase):
|
||||||
|
fixtures = ['admin-views-unicode.xml']
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
self.client.login(username='super', password='secret')
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
self.client.logout()
|
||||||
|
|
||||||
|
def testUnicodeEdit(self):
|
||||||
|
"""
|
||||||
|
A test to ensure that POST on edit_view handles non-ascii characters.
|
||||||
|
"""
|
||||||
|
post_data = {
|
||||||
|
"name": u"Test lærdommer",
|
||||||
|
# inline data
|
||||||
|
"chapter_set-TOTAL_FORMS": u"6",
|
||||||
|
"chapter_set-INITIAL_FORMS": u"3",
|
||||||
|
"chapter_set-0-id": u"1",
|
||||||
|
"chapter_set-0-title": u"Norske bostaver æøå skaper problemer",
|
||||||
|
"chapter_set-0-content": u"<p>Svært frustrerende med UnicodeDecodeError</p>",
|
||||||
|
"chapter_set-1-id": u"2",
|
||||||
|
"chapter_set-1-title": u"Kjærlighet.",
|
||||||
|
"chapter_set-1-content": u"<p>La kjærligheten til de lidende seire.</p>",
|
||||||
|
"chapter_set-2-id": u"3",
|
||||||
|
"chapter_set-2-title": u"Need a title.",
|
||||||
|
"chapter_set-2-content": u"<p>Newest content</p>",
|
||||||
|
"chapter_set-3-id": u"",
|
||||||
|
"chapter_set-3-title": u"",
|
||||||
|
"chapter_set-3-content": u"",
|
||||||
|
"chapter_set-4-id": u"",
|
||||||
|
"chapter_set-4-title": u"",
|
||||||
|
"chapter_set-4-content": u"",
|
||||||
|
"chapter_set-5-id": u"",
|
||||||
|
"chapter_set-5-title": u"",
|
||||||
|
"chapter_set-5-content": u"",
|
||||||
|
}
|
||||||
|
|
||||||
|
response = self.client.post('/test_admin/admin/admin_views/book/1/', post_data)
|
||||||
|
self.failUnlessEqual(response.status_code, 302) # redirect somewhere
|
||||||
|
|
||||||
|
def testUnicodeDelete(self):
|
||||||
|
"""
|
||||||
|
Ensure that the delete_view handles non-ascii characters
|
||||||
|
"""
|
||||||
|
delete_dict = {'post': 'yes'}
|
||||||
|
response = self.client.get('/test_admin/admin/admin_views/book/1/delete/')
|
||||||
|
self.failUnlessEqual(response.status_code, 200)
|
||||||
|
response = self.client.post('/test_admin/admin/admin_views/book/1/delete/', delete_dict)
|
||||||
|
self.assertRedirects(response, '/test_admin/admin/admin_views/book/')
|
||||||
|
|
Loading…
Reference in New Issue