mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Co-authored-by: Valz <ahmadahussein0@gmail.com> Co-authored-by: Nick Pope <nick@nickpope.me.uk>
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from datetime import date
 | |
| 
 | |
| from django.test import modify_settings
 | |
| 
 | |
| from . import PostgreSQLTestCase
 | |
| from .models import (
 | |
|     HStoreModel,
 | |
|     IntegerArrayModel,
 | |
|     NestedIntegerArrayModel,
 | |
|     NullableIntegerArrayModel,
 | |
|     OtherTypesArrayModel,
 | |
|     RangesModel,
 | |
| )
 | |
| 
 | |
| try:
 | |
|     from psycopg2.extras import DateRange, NumericRange
 | |
| except ImportError:
 | |
|     pass  # psycopg2 isn't installed.
 | |
| 
 | |
| 
 | |
| @modify_settings(INSTALLED_APPS={"append": "django.contrib.postgres"})
 | |
| class BulkSaveTests(PostgreSQLTestCase):
 | |
|     def test_bulk_update(self):
 | |
|         test_data = [
 | |
|             (IntegerArrayModel, "field", [], [1, 2, 3]),
 | |
|             (NullableIntegerArrayModel, "field", [1, 2, 3], None),
 | |
|             (NestedIntegerArrayModel, "field", [], [[1, 2, 3]]),
 | |
|             (HStoreModel, "field", {}, {1: 2}),
 | |
|             (RangesModel, "ints", None, NumericRange(lower=1, upper=10)),
 | |
|             (
 | |
|                 RangesModel,
 | |
|                 "dates",
 | |
|                 None,
 | |
|                 DateRange(lower=date.today(), upper=date.today()),
 | |
|             ),
 | |
|             (OtherTypesArrayModel, "ips", [], ["1.2.3.4"]),
 | |
|             (OtherTypesArrayModel, "json", [], [{"a": "b"}]),
 | |
|         ]
 | |
|         for Model, field, initial, new in test_data:
 | |
|             with self.subTest(model=Model, field=field):
 | |
|                 instances = Model.objects.bulk_create(
 | |
|                     Model(**{field: initial}) for _ in range(20)
 | |
|                 )
 | |
|                 for instance in instances:
 | |
|                     setattr(instance, field, new)
 | |
|                 Model.objects.bulk_update(instances, [field])
 | |
|                 self.assertSequenceEqual(
 | |
|                     Model.objects.filter(**{field: new}), instances
 | |
|                 )
 |