mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.7.x] Fixed #23880 -- Added missing index_together handling for SQLite
Backport of d2202ec2d4 from master
			
			
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							d62e16fe46
						
					
				
				
					commit
					ba3e976186
				
			| @@ -43,7 +43,8 @@ class DatabaseSchemaEditor(BaseDatabaseSchemaEditor): | |||||||
|         else: |         else: | ||||||
|             raise ValueError("Cannot quote parameter value %r of type %s" % (value, type(value))) |             raise ValueError("Cannot quote parameter value %r of type %s" % (value, type(value))) | ||||||
|  |  | ||||||
|     def _remake_table(self, model, create_fields=[], delete_fields=[], alter_fields=[], override_uniques=None): |     def _remake_table(self, model, create_fields=[], delete_fields=[], alter_fields=[], override_uniques=None, | ||||||
|  |                       override_indexes=None): | ||||||
|         """ |         """ | ||||||
|         Shortcut to transform a model from old_model into new_model |         Shortcut to transform a model from old_model into new_model | ||||||
|         """ |         """ | ||||||
| @@ -110,11 +111,20 @@ class DatabaseSchemaEditor(BaseDatabaseSchemaEditor): | |||||||
|                 for unique in model._meta.unique_together |                 for unique in model._meta.unique_together | ||||||
|             ] |             ] | ||||||
|  |  | ||||||
|  |         # Work out the new value for index_together, taking renames into | ||||||
|  |         # account | ||||||
|  |         if override_indexes is None: | ||||||
|  |             override_indexes = [ | ||||||
|  |                 [rename_mapping.get(n, n) for n in index] | ||||||
|  |                 for index in model._meta.index_together | ||||||
|  |             ] | ||||||
|  |  | ||||||
|         # Construct a new model for the new state |         # Construct a new model for the new state | ||||||
|         meta_contents = { |         meta_contents = { | ||||||
|             'app_label': model._meta.app_label, |             'app_label': model._meta.app_label, | ||||||
|             'db_table': model._meta.db_table + "__new", |             'db_table': model._meta.db_table + "__new", | ||||||
|             'unique_together': override_uniques, |             'unique_together': override_uniques, | ||||||
|  |             'index_together': override_indexes, | ||||||
|             'apps': apps, |             'apps': apps, | ||||||
|         } |         } | ||||||
|         meta = type("Meta", tuple(), meta_contents) |         meta = type("Meta", tuple(), meta_contents) | ||||||
| @@ -189,6 +199,14 @@ class DatabaseSchemaEditor(BaseDatabaseSchemaEditor): | |||||||
|         # Alter by remaking table |         # Alter by remaking table | ||||||
|         self._remake_table(model, alter_fields=[(old_field, new_field)]) |         self._remake_table(model, alter_fields=[(old_field, new_field)]) | ||||||
|  |  | ||||||
|  |     def alter_index_together(self, model, old_index_together, new_index_together): | ||||||
|  |         """ | ||||||
|  |         Deals with a model changing its index_together. | ||||||
|  |         Note: The input index_togethers must be doubly-nested, not the single- | ||||||
|  |         nested ["foo", "bar"] format. | ||||||
|  |         """ | ||||||
|  |         self._remake_table(model, override_indexes=new_index_together) | ||||||
|  |  | ||||||
|     def alter_unique_together(self, model, old_unique_together, new_unique_together): |     def alter_unique_together(self, model, old_unique_together, new_unique_together): | ||||||
|         """ |         """ | ||||||
|         Deals with a model changing its unique_together. |         Deals with a model changing its unique_together. | ||||||
|   | |||||||
| @@ -89,3 +89,5 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed an infinite loop bug for certain cyclic migration dependencies, and made | * Fixed an infinite loop bug for certain cyclic migration dependencies, and made | ||||||
|   the error message for cyclic dependencies much more helpful. |   the error message for cyclic dependencies much more helpful. | ||||||
|  |  | ||||||
|  | * Added missing ``index_together`` handling for SQLite (:ticket:`23880`). | ||||||
|   | |||||||
| @@ -1012,16 +1012,14 @@ class OperationTests(OperationTestBase): | |||||||
|                     cursor.execute("INSERT INTO test_rnfl_pony (blue, weight) VALUES (1, 1)") |                     cursor.execute("INSERT INTO test_rnfl_pony (blue, weight) VALUES (1, 1)") | ||||||
|             cursor.execute("DELETE FROM test_rnfl_pony") |             cursor.execute("DELETE FROM test_rnfl_pony") | ||||||
|         # Ensure the index constraint has been ported over |         # Ensure the index constraint has been ported over | ||||||
|         # TODO: Uncomment assert when #23880 is fixed |         self.assertIndexExists("test_rnfl_pony", ["weight", "blue"]) | ||||||
|         # self.assertIndexExists("test_rnfl_pony", ["weight", "blue"]) |  | ||||||
|         # And test reversal |         # And test reversal | ||||||
|         with connection.schema_editor() as editor: |         with connection.schema_editor() as editor: | ||||||
|             operation.database_backwards("test_rnfl", editor, new_state, project_state) |             operation.database_backwards("test_rnfl", editor, new_state, project_state) | ||||||
|         self.assertColumnExists("test_rnfl_pony", "pink") |         self.assertColumnExists("test_rnfl_pony", "pink") | ||||||
|         self.assertColumnNotExists("test_rnfl_pony", "blue") |         self.assertColumnNotExists("test_rnfl_pony", "blue") | ||||||
|         # Ensure the index constraint has been reset |         # Ensure the index constraint has been reset | ||||||
|         # TODO: Uncomment assert when #23880 is fixed |         self.assertIndexExists("test_rnfl_pony", ["weight", "pink"]) | ||||||
|         # self.assertIndexExists("test_rnfl_pony", ["weight", "pink"]) |  | ||||||
|  |  | ||||||
|     def test_alter_unique_together(self): |     def test_alter_unique_together(self): | ||||||
|         """ |         """ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user