mirror of
https://github.com/django/django.git
synced 2025-10-31 09:41:08 +00:00
[1.0.X] Fixed #9859 -- Added another missing force_unicode needed in admin when running on Python 2.3. Many thanks for report & patch with test to nfg.
Also enhanced the new test to hopefully exercise all paths through the get_deleted_objects function, and fixed the errors pointed out by the beefed-up test. r9656 and r9657 from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.0.X@9658 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -1,3 +1,4 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
from django.db import models
|
||||
from django.contrib import admin
|
||||
|
||||
@@ -24,6 +25,47 @@ class Article(models.Model):
|
||||
return self.date.year
|
||||
model_year.admin_order_field = 'date'
|
||||
|
||||
class Book(models.Model):
|
||||
"""
|
||||
A simple book that has chapters.
|
||||
"""
|
||||
name = models.CharField(max_length=100, verbose_name=u'¿Name?')
|
||||
|
||||
def __unicode__(self):
|
||||
return self.name
|
||||
|
||||
class Promo(models.Model):
|
||||
name = models.CharField(max_length=100, verbose_name=u'¿Name?')
|
||||
book = models.ForeignKey(Book)
|
||||
|
||||
def __unicode__(self):
|
||||
return self.name
|
||||
|
||||
class Chapter(models.Model):
|
||||
title = models.CharField(max_length=100, verbose_name=u'¿Title?')
|
||||
content = models.TextField()
|
||||
book = models.ForeignKey(Book)
|
||||
|
||||
def __unicode__(self):
|
||||
return self.title
|
||||
|
||||
class Meta:
|
||||
verbose_name = u'¿Chapter?'
|
||||
|
||||
class ChapterXtra1(models.Model):
|
||||
chap = models.OneToOneField(Chapter, verbose_name=u'¿Chap?')
|
||||
xtra = models.CharField(max_length=100, verbose_name=u'¿Xtra?')
|
||||
|
||||
def __unicode__(self):
|
||||
return u'¿Xtra1: %s' % self.xtra
|
||||
|
||||
class ChapterXtra2(models.Model):
|
||||
chap = models.OneToOneField(Chapter, verbose_name=u'¿Chap?')
|
||||
xtra = models.CharField(max_length=100, verbose_name=u'¿Xtra?')
|
||||
|
||||
def __unicode__(self):
|
||||
return u'¿Xtra2: %s' % self.xtra
|
||||
|
||||
def callable_year(dt_value):
|
||||
return dt_value.year
|
||||
callable_year.admin_order_field = 'date'
|
||||
@@ -31,6 +73,9 @@ callable_year.admin_order_field = 'date'
|
||||
class ArticleInline(admin.TabularInline):
|
||||
model = Article
|
||||
|
||||
class ChapterInline(admin.TabularInline):
|
||||
model = Chapter
|
||||
|
||||
class ArticleAdmin(admin.ModelAdmin):
|
||||
list_display = ('content', 'date', callable_year, 'model_year', 'modeladmin_year')
|
||||
list_filter = ('date',)
|
||||
@@ -95,3 +140,16 @@ admin.site.register(Section, inlines=[ArticleInline])
|
||||
admin.site.register(ModelWithStringPrimaryKey)
|
||||
admin.site.register(Color)
|
||||
admin.site.register(Thing, ThingAdmin)
|
||||
|
||||
# We intentionally register Promo and ChapterXtra1 but not Chapter nor ChapterXtra2.
|
||||
# That way we cover all four cases:
|
||||
# related ForeignKey object registered in admin
|
||||
# related ForeignKey object not registered in admin
|
||||
# related OneToOne object registered in admin
|
||||
# related OneToOne object not registered in admin
|
||||
# when deleting Book so as exercise all four troublesome (w.r.t escaping
|
||||
# and calling force_unicode to avoid problems on Python 2.3) paths through
|
||||
# contrib.admin.util's get_deleted_objects function.
|
||||
admin.site.register(Book, inlines=[ChapterInline])
|
||||
admin.site.register(Promo)
|
||||
admin.site.register(ChapterXtra1)
|
||||
|
||||
Reference in New Issue
Block a user