mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #15661 - LogEntry objects have no unicode method
Thanks to Keryn Knight for the report and initial patch, and ShawnMilo for additional work on the patch. git-svn-id: http://code.djangoproject.com/svn/django/trunk@16120 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -33,6 +33,17 @@ class LogEntry(models.Model): | |||||||
|     def __repr__(self): |     def __repr__(self): | ||||||
|         return smart_unicode(self.action_time) |         return smart_unicode(self.action_time) | ||||||
|  |  | ||||||
|  |     def __unicode__(self): | ||||||
|  |  | ||||||
|  |         if self.action_flag == ADDITION: | ||||||
|  |             return _('Added "%(object)s".') % {'object': self.object_repr} | ||||||
|  |         elif self.action_flag == CHANGE: | ||||||
|  |             return _('Changed "%(object)s" - %(changes)s') % {'object': self.object_repr, 'changes': self.change_message} | ||||||
|  |         elif self.action_flag == DELETION: | ||||||
|  |             return _('Deleted "%(object)s."') % {'object': self.object_repr} | ||||||
|  |  | ||||||
|  |         return_value = _('LogEntry Object') | ||||||
|  |  | ||||||
|     def is_addition(self): |     def is_addition(self): | ||||||
|         return self.action_flag == ADDITION |         return self.action_flag == ADDITION | ||||||
|  |  | ||||||
| @@ -53,4 +64,4 @@ class LogEntry(models.Model): | |||||||
|         """ |         """ | ||||||
|         if self.content_type and self.object_id: |         if self.content_type and self.object_id: | ||||||
|             return mark_safe(u"%s/%s/%s/" % (self.content_type.app_label, self.content_type.model, quote(self.object_id))) |             return mark_safe(u"%s/%s/%s/" % (self.content_type.app_label, self.content_type.model, quote(self.object_id))) | ||||||
|         return None |         return None | ||||||
|   | |||||||
| @@ -235,3 +235,24 @@ class UtilTests(unittest.TestCase): | |||||||
|             label_for_field('guest', Event, return_attr=True), |             label_for_field('guest', Event, return_attr=True), | ||||||
|             ('awesome guest', None), |             ('awesome guest', None), | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def test_logentry_unicode(self): | ||||||
|  |         """ | ||||||
|  |         Regression test for #15661 | ||||||
|  |         """ | ||||||
|  |         log_entry = admin.models.LogEntry() | ||||||
|  |  | ||||||
|  |         log_entry.action_flag = admin.models.ADDITION | ||||||
|  |         self.assertTrue( | ||||||
|  |             unicode(log_entry).startswith('Added ') | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         log_entry.action_flag = admin.models.CHANGE | ||||||
|  |         self.assertTrue( | ||||||
|  |             unicode(log_entry).startswith('Changed ') | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         log_entry.action_flag = admin.models.DELETION | ||||||
|  |         self.assertTrue( | ||||||
|  |             unicode(log_entry).startswith('Deleted ') | ||||||
|  |         ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user