summaryrefslogtreecommitdiff
path: root/tests/admin_views
diff options
context:
space:
mode:
authorLincoln Smith <lincoln.smith@anu.edu.au>2017-04-05 13:54:46 +1000
committerTim Graham <timograham@gmail.com>2017-06-14 13:07:06 -0400
commit15b465c584f49a1d43b6c18796f83521ee4ffc22 (patch)
treea15da857498224fa76c27b149a5ba7bbbfc978dd /tests/admin_views
parent451b585c2f76507b1be9d855a41cf2bb5aad6026 (diff)
Fixed #27998 -- Made ManyToManyField changes logged in admin's object history.
Diffstat (limited to 'tests/admin_views')
-rw-r--r--tests/admin_views/admin.py17
-rw-r--r--tests/admin_views/models.py7
-rw-r--r--tests/admin_views/tests.py24
3 files changed, 34 insertions, 14 deletions
diff --git a/tests/admin_views/admin.py b/tests/admin_views/admin.py
index cd323a10cf..6139f0460f 100644
--- a/tests/admin_views/admin.py
+++ b/tests/admin_views/admin.py
@@ -35,14 +35,14 @@ from .models import (
OtherStory, Paper, Parent, ParentWithDependentChildren, ParentWithUUIDPK,
Person, Persona, Picture, Pizza, Plot, PlotDetails, PlotProxy,
PluggableSearchPerson, Podcast, Post, PrePopulatedPost,
- PrePopulatedPostLargeSlug, PrePopulatedSubPost, Promo, Question, Recipe,
- Recommendation, Recommender, ReferencedByGenRel, ReferencedByInline,
- ReferencedByParent, RelatedPrepopulated, RelatedWithUUIDPKModel, Report,
- Reservation, Restaurant, RowLevelChangePermissionModel, Section,
- ShortMessage, Simple, Sketch, State, Story, StumpJoke, Subscriber,
- SuperVillain, Telegram, Thing, Topping, UnchangeableObject,
- UndeletableObject, UnorderedObject, UserMessenger, Villain, Vodcast,
- Whatsit, Widget, Worker, WorkHour,
+ PrePopulatedPostLargeSlug, PrePopulatedSubPost, Promo, Question,
+ ReadablePizza, Recipe, Recommendation, Recommender, ReferencedByGenRel,
+ ReferencedByInline, ReferencedByParent, RelatedPrepopulated,
+ RelatedWithUUIDPKModel, Report, Reservation, Restaurant,
+ RowLevelChangePermissionModel, Section, ShortMessage, Simple, Sketch,
+ State, Story, StumpJoke, Subscriber, SuperVillain, Telegram, Thing,
+ Topping, UnchangeableObject, UndeletableObject, UnorderedObject,
+ UserMessenger, Villain, Vodcast, Whatsit, Widget, Worker, WorkHour,
)
@@ -970,6 +970,7 @@ site.register(Book, inlines=[ChapterInline])
site.register(Promo)
site.register(ChapterXtra1, ChapterXtra1Admin)
site.register(Pizza, PizzaAdmin)
+site.register(ReadablePizza)
site.register(Topping, ToppingAdmin)
site.register(Album, AlbumAdmin)
site.register(Question)
diff --git a/tests/admin_views/models.py b/tests/admin_views/models.py
index 2dd7f5efd3..dd4921d1ce 100644
--- a/tests/admin_views/models.py
+++ b/tests/admin_views/models.py
@@ -575,6 +575,13 @@ class Pizza(models.Model):
toppings = models.ManyToManyField('Topping', related_name='pizzas')
+# Pizza's ModelAdmin has readonly_fields = ['toppings'].
+# toppings is editable for this model's admin.
+class ReadablePizza(Pizza):
+ class Meta:
+ proxy = True
+
+
class Album(models.Model):
owner = models.ForeignKey(User, models.SET_NULL, null=True, blank=True)
title = models.CharField(max_length=30)
diff --git a/tests/admin_views/tests.py b/tests/admin_views/tests.py
index 16cc8d4b71..eee375e9f6 100644
--- a/tests/admin_views/tests.py
+++ b/tests/admin_views/tests.py
@@ -54,12 +54,13 @@ from .models import (
ModelWithStringPrimaryKey, OtherStory, Paper, Parent,
ParentWithDependentChildren, ParentWithUUIDPK, Person, Persona, Picture,
Pizza, Plot, PlotDetails, PluggableSearchPerson, Podcast, Post,
- PrePopulatedPost, Promo, Question, Recommendation, Recommender,
- RelatedPrepopulated, RelatedWithUUIDPKModel, Report, Restaurant,
- RowLevelChangePermissionModel, SecretHideout, Section, ShortMessage,
- Simple, State, Story, Subscriber, SuperSecretHideout, SuperVillain,
- Telegram, TitleTranslation, Topping, UnchangeableObject, UndeletableObject,
- UnorderedObject, Villain, Vodcast, Whatsit, Widget, Worker, WorkHour,
+ PrePopulatedPost, Promo, Question, ReadablePizza, Recommendation,
+ Recommender, RelatedPrepopulated, RelatedWithUUIDPKModel, Report,
+ Restaurant, RowLevelChangePermissionModel, SecretHideout, Section,
+ ShortMessage, Simple, State, Story, Subscriber, SuperSecretHideout,
+ SuperVillain, Telegram, TitleTranslation, Topping, UnchangeableObject,
+ UndeletableObject, UnorderedObject, Villain, Vodcast, Whatsit, Widget,
+ Worker, WorkHour,
)
@@ -876,6 +877,17 @@ class AdminViewBasicTest(AdminViewBasicTestCase):
response = self.client.get(reverse('admin:admin_views_undeletableobject_change', args=(instance.pk,)))
self.assertNotContains(response, 'deletelink')
+ def test_change_view_logs_m2m_field_changes(self):
+ """Changes to ManyToManyFields are included in the object's history."""
+ pizza = ReadablePizza.objects.create(name='Cheese')
+ cheese = Topping.objects.create(name='cheese')
+ post_data = {'name': pizza.name, 'toppings': [cheese.pk]}
+ response = self.client.post(reverse('admin:admin_views_readablepizza_change', args=(pizza.pk,)), post_data)
+ self.assertRedirects(response, reverse('admin:admin_views_readablepizza_changelist'))
+ pizza_ctype = ContentType.objects.get_for_model(ReadablePizza, for_concrete_model=False)
+ log = LogEntry.objects.filter(content_type=pizza_ctype, object_id=pizza.pk).first()
+ self.assertEqual(log.get_change_message(), 'Changed toppings.')
+
def test_allows_attributeerror_to_bubble_up(self):
"""
AttributeErrors are allowed to bubble when raised inside a change list