from django.contrib.admin.models import LogEntry from django.contrib.auth.models import User from django.test import TestCase, override_settings from django.urls import reverse from .models import City, State @override_settings(ROOT_URLCONF='admin_views.urls') class AdminHistoryViewTests(TestCase): @classmethod def setUpTestData(cls): cls.superuser = User.objects.create_superuser( username='super', password='secret', email='super@example.com', ) def setUp(self): self.client.force_login(self.superuser) def test_changed_message_uses_form_lables(self): """ Admin's model history change messages use form labels instead of field names. """ state = State.objects.create(name='My State Name') city = City.objects.create(name='My City Name', state=state) change_dict = { 'name': 'My State Name 2', 'nolabel_form_field': True, 'city_set-0-name': 'My City name 2', 'city_set-0-id': city.pk, 'city_set-TOTAL_FORMS': '3', 'city_set-INITIAL_FORMS': '1', 'city_set-MAX_NUM_FORMS': '0', } state_change_url = reverse('admin:admin_views_state_change', args=(state.pk,)) self.client.post(state_change_url, change_dict) logentry = LogEntry.objects.filter(content_type__model__iexact='state').latest('id') self.assertEqual( logentry.get_change_message(), 'Changed State name (from form\'s Meta.labels), ' 'nolabel_form_field and not_a_form_field. ' 'Changed City verbose_name for city "%s".' % city )