mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #31286 -- Made database specific fields checks databases aware.
Follow up to 0b83c8cc4d.
			
			
This commit is contained in:
		| @@ -335,12 +335,15 @@ class Field(RegisterLookupMixin): | |||||||
|         else: |         else: | ||||||
|             return [] |             return [] | ||||||
|  |  | ||||||
|     def _check_backend_specific_checks(self, **kwargs): |     def _check_backend_specific_checks(self, databases=None, **kwargs): | ||||||
|         app_label = self.model._meta.app_label |         if databases is None: | ||||||
|         for db in connections: |  | ||||||
|             if router.allow_migrate(db, app_label, model_name=self.model._meta.model_name): |  | ||||||
|                 return connections[db].validation.check_field(self, **kwargs) |  | ||||||
|             return [] |             return [] | ||||||
|  |         app_label = self.model._meta.app_label | ||||||
|  |         errors = [] | ||||||
|  |         for alias in databases: | ||||||
|  |             if router.allow_migrate(alias, app_label, model_name=self.model._meta.model_name): | ||||||
|  |                 errors.extend(connections[alias].validation.check_field(self, **kwargs)) | ||||||
|  |         return errors | ||||||
|  |  | ||||||
|     def _check_validators(self): |     def _check_validators(self): | ||||||
|         errors = [] |         errors = [] | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ class TestMultiDBChecks(SimpleTestCase): | |||||||
|         model = Model() |         model = Model() | ||||||
|         with self._patch_check_field_on('default') as mock_check_field_default: |         with self._patch_check_field_on('default') as mock_check_field_default: | ||||||
|             with self._patch_check_field_on('other') as mock_check_field_other: |             with self._patch_check_field_on('other') as mock_check_field_other: | ||||||
|                 model.check() |                 model.check(databases={'default', 'other'}) | ||||||
|                 self.assertTrue(mock_check_field_default.called) |                 self.assertTrue(mock_check_field_default.called) | ||||||
|                 self.assertFalse(mock_check_field_other.called) |                 self.assertFalse(mock_check_field_other.called) | ||||||
|  |  | ||||||
| @@ -38,6 +38,6 @@ class TestMultiDBChecks(SimpleTestCase): | |||||||
|         model = OtherModel() |         model = OtherModel() | ||||||
|         with self._patch_check_field_on('other') as mock_check_field_other: |         with self._patch_check_field_on('other') as mock_check_field_other: | ||||||
|             with self._patch_check_field_on('default') as mock_check_field_default: |             with self._patch_check_field_on('default') as mock_check_field_default: | ||||||
|                 model.check() |                 model.check(databases={'default', 'other'}) | ||||||
|                 self.assertTrue(mock_check_field_other.called) |                 self.assertTrue(mock_check_field_other.called) | ||||||
|                 self.assertFalse(mock_check_field_default.called) |                 self.assertFalse(mock_check_field_default.called) | ||||||
|   | |||||||
| @@ -25,4 +25,4 @@ class BackendSpecificChecksTests(SimpleTestCase): | |||||||
|  |  | ||||||
|         field = Model._meta.get_field('field') |         field = Model._meta.get_field('field') | ||||||
|         with mock.patch.object(connections['default'].validation, 'check_field', return_value=[error]): |         with mock.patch.object(connections['default'].validation, 'check_field', return_value=[error]): | ||||||
|             self.assertEqual(field.check(), [error]) |             self.assertEqual(field.check(databases={'default'}), [error]) | ||||||
|   | |||||||
| @@ -758,7 +758,7 @@ class TextFieldTests(TestCase): | |||||||
|             value = models.TextField(db_index=True) |             value = models.TextField(db_index=True) | ||||||
|         field = Model._meta.get_field('value') |         field = Model._meta.get_field('value') | ||||||
|         field_type = field.db_type(connection) |         field_type = field.db_type(connection) | ||||||
|         self.assertEqual(field.check(), [ |         self.assertEqual(field.check(databases=self.databases), [ | ||||||
|             DjangoWarning( |             DjangoWarning( | ||||||
|                 '%s does not support a database index on %s columns.' |                 '%s does not support a database index on %s columns.' | ||||||
|                 % (connection.display_name, field_type), |                 % (connection.display_name, field_type), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user