mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #23956 -- Fixed migration creation for multiple table inheritance
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							38fc463fbf
						
					
				
				
					commit
					44927ba817
				
			| @@ -463,7 +463,7 @@ class MigrationAutodetector(object): | |||||||
|                     if field.rel.to: |                     if field.rel.to: | ||||||
|                         if field.primary_key: |                         if field.primary_key: | ||||||
|                             primary_key_rel = field.rel.to |                             primary_key_rel = field.rel.to | ||||||
|                         else: |                         elif not field.rel.parent_link: | ||||||
|                             related_fields[field.name] = field |                             related_fields[field.name] = field | ||||||
|                     # through will be none on M2Ms on swapped-out models; |                     # through will be none on M2Ms on swapped-out models; | ||||||
|                     # we can treat lack of through as auto_created=True, though. |                     # we can treat lack of through as auto_created=True, though. | ||||||
|   | |||||||
| @@ -115,3 +115,7 @@ Bugfixes | |||||||
| * Fixed index creation by the migration infrastructure, particularly when | * Fixed index creation by the migration infrastructure, particularly when | ||||||
|   dealing with PostgreSQL specific {text|varchar}_pattern_ops indexes |   dealing with PostgreSQL specific {text|varchar}_pattern_ops indexes | ||||||
|   (:ticket:`23954`). |   (:ticket:`23954`). | ||||||
|  |  | ||||||
|  | * Fixed bug in ``makemigrations`` that created broken migration files when | ||||||
|  |   dealing with multiple table inheritance and inheriting from more than one | ||||||
|  |   model (:ticket:`23956`). | ||||||
|   | |||||||
| @@ -1446,6 +1446,29 @@ class AutodetectorTests(TestCase): | |||||||
|         self.assertOperationAttributes(changes, 'testapp', 0, 0, name="Author") |         self.assertOperationAttributes(changes, 'testapp', 0, 0, name="Author") | ||||||
|         self.assertOperationAttributes(changes, 'testapp', 0, 1, name="Aardvark") |         self.assertOperationAttributes(changes, 'testapp', 0, 1, name="Aardvark") | ||||||
|  |  | ||||||
|  |     def test_multiple_bases(self): | ||||||
|  |         """#23956 - Tests that inheriting models doesn't move *_ptr fields into AddField operations.""" | ||||||
|  |         A = ModelState("app", "A", [("a_id", models.AutoField(primary_key=True))]) | ||||||
|  |         B = ModelState("app", "B", [("b_id", models.AutoField(primary_key=True))]) | ||||||
|  |         C = ModelState("app", "C", [], bases=("app.A", "app.B")) | ||||||
|  |         D = ModelState("app", "D", [], bases=("app.A", "app.B")) | ||||||
|  |         E = ModelState("app", "E", [], bases=("app.A", "app.B")) | ||||||
|  |         # Make state | ||||||
|  |         before = self.make_project_state([]) | ||||||
|  |         after = self.make_project_state([A, B, C, D, E]) | ||||||
|  |         autodetector = MigrationAutodetector(before, after) | ||||||
|  |         changes = autodetector._detect_changes() | ||||||
|  |         # Right number/type of migrations? | ||||||
|  |         self.assertNumberMigrations(changes, "app", 1) | ||||||
|  |         self.assertOperationTypes(changes, "app", 0, [ | ||||||
|  |             "CreateModel", "CreateModel", "CreateModel", "CreateModel", "CreateModel" | ||||||
|  |         ]) | ||||||
|  |         self.assertOperationAttributes(changes, "app", 0, 0, name="A") | ||||||
|  |         self.assertOperationAttributes(changes, "app", 0, 1, name="B") | ||||||
|  |         self.assertOperationAttributes(changes, "app", 0, 2, name="C") | ||||||
|  |         self.assertOperationAttributes(changes, "app", 0, 3, name="D") | ||||||
|  |         self.assertOperationAttributes(changes, "app", 0, 4, name="E") | ||||||
|  |  | ||||||
|     def test_proxy_bases_first(self): |     def test_proxy_bases_first(self): | ||||||
|         """Tests that bases of proxies come first.""" |         """Tests that bases of proxies come first.""" | ||||||
|         # Make state |         # Make state | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user