mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #28152 -- Made migrations serialize sets as set literals rather than set().
This commit is contained in:
		| @@ -26,7 +26,7 @@ class Migration(migrations.Migration): | ||||
|             ], | ||||
|             options={ | ||||
|                 'ordering': ('content_type__app_label', 'content_type__model', 'codename'), | ||||
|                 'unique_together': set([('content_type', 'codename')]), | ||||
|                 'unique_together': {('content_type', 'codename')}, | ||||
|                 'verbose_name': 'permission', | ||||
|                 'verbose_name_plural': 'permissions', | ||||
|             }, | ||||
|   | ||||
| @@ -29,6 +29,6 @@ class Migration(migrations.Migration): | ||||
|         ), | ||||
|         migrations.AlterUniqueTogether( | ||||
|             name='contenttype', | ||||
|             unique_together=set([('app_label', 'model')]), | ||||
|             unique_together={('app_label', 'model')}, | ||||
|         ), | ||||
|     ] | ||||
|   | ||||
| @@ -30,7 +30,7 @@ class Migration(migrations.Migration): | ||||
|             ], | ||||
|             options={ | ||||
|                 'ordering': ('old_path',), | ||||
|                 'unique_together': set([('site', 'old_path')]), | ||||
|                 'unique_together': {('site', 'old_path')}, | ||||
|                 'db_table': 'django_redirect', | ||||
|                 'verbose_name': 'redirect', | ||||
|                 'verbose_name_plural': 'redirects', | ||||
|   | ||||
| @@ -244,8 +244,9 @@ class SequenceSerializer(BaseSequenceSerializer): | ||||
|  | ||||
| class SetSerializer(BaseSequenceSerializer): | ||||
|     def _format(self): | ||||
|         # Don't use the literal "{%s}" as it doesn't support empty set | ||||
|         return "set([%s])" | ||||
|         # Serialize as a set literal except when value is empty because {} | ||||
|         # is an empty dict. | ||||
|         return '{%s}' if self.value else 'set(%s)' | ||||
|  | ||||
|  | ||||
| class SettingsReferenceSerializer(BaseSerializer): | ||||
|   | ||||
| @@ -30,6 +30,6 @@ class Migration(migrations.Migration): | ||||
|         ), | ||||
|         migrations.AlterUniqueTogether( | ||||
|             name='author', | ||||
|             unique_together=set([('name', 'slug')]), | ||||
|             unique_together={('name', 'slug')}, | ||||
|         ), | ||||
|     ] | ||||
|   | ||||
| @@ -25,6 +25,6 @@ class Migration(migrations.Migration): | ||||
|         ), | ||||
|         migrations.AlterUniqueTogether( | ||||
|             name='author', | ||||
|             unique_together=set([('name', 'slug')]), | ||||
|             unique_together={('name', 'slug')}, | ||||
|         ), | ||||
|     ] | ||||
|   | ||||
| @@ -25,6 +25,6 @@ class Migration(migrations.Migration): | ||||
|         ), | ||||
|         migrations.AlterUniqueTogether( | ||||
|             name='author', | ||||
|             unique_together=set([('name', 'slug')]), | ||||
|             unique_together={('name', 'slug')}, | ||||
|         ), | ||||
|     ] | ||||
|   | ||||
| @@ -505,6 +505,12 @@ class WriterTests(SimpleTestCase): | ||||
|         self.assertSerializedEqual(frozenset()) | ||||
|         self.assertSerializedEqual(frozenset("let it go")) | ||||
|  | ||||
|     def test_serialize_set(self): | ||||
|         self.assertSerializedEqual(set()) | ||||
|         self.assertSerializedResultEqual(set(), ('set()', set())) | ||||
|         self.assertSerializedEqual({'a'}) | ||||
|         self.assertSerializedResultEqual({'a'}, ("{'a'}", set())) | ||||
|  | ||||
|     def test_serialize_timedelta(self): | ||||
|         self.assertSerializedEqual(datetime.timedelta()) | ||||
|         self.assertSerializedEqual(datetime.timedelta(minutes=42)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user