mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #29529 -- Allowed models.fields.FilePathField to accept a callable path.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							11971cd87c
						
					
				
				
					commit
					ef082ebb84
				
			| @@ -1709,7 +1709,7 @@ class FilePathField(Field): | |||||||
|  |  | ||||||
|     def formfield(self, **kwargs): |     def formfield(self, **kwargs): | ||||||
|         return super().formfield(**{ |         return super().formfield(**{ | ||||||
|             'path': self.path, |             'path': self.path() if callable(self.path) else self.path, | ||||||
|             'match': self.match, |             'match': self.match, | ||||||
|             'recursive': self.recursive, |             'recursive': self.recursive, | ||||||
|             'form_class': forms.FilePathField, |             'form_class': forms.FilePathField, | ||||||
|   | |||||||
| @@ -868,6 +868,23 @@ directory on the filesystem. Has three special arguments, of which the first is | |||||||
|     Required. The absolute filesystem path to a directory from which this |     Required. The absolute filesystem path to a directory from which this | ||||||
|     :class:`FilePathField` should get its choices. Example: ``"/home/images"``. |     :class:`FilePathField` should get its choices. Example: ``"/home/images"``. | ||||||
|  |  | ||||||
|  |     ``path`` may also be a callable, such as a function to dynamically set the | ||||||
|  |     path at runtime. Example:: | ||||||
|  |  | ||||||
|  |         import os | ||||||
|  |         from django.conf import settings | ||||||
|  |         from django.db import models | ||||||
|  |  | ||||||
|  |         def images_path(): | ||||||
|  |             return os.path.join(settings.LOCAL_FILE_DIR, 'images') | ||||||
|  |  | ||||||
|  |         class MyModel(models.Model): | ||||||
|  |             file = models.FilePathField(path=images_path) | ||||||
|  |  | ||||||
|  |     .. versionchanged:: 3.0 | ||||||
|  |  | ||||||
|  |         ``path`` can now be a callable. | ||||||
|  |  | ||||||
| .. attribute:: FilePathField.match | .. attribute:: FilePathField.match | ||||||
|  |  | ||||||
|     Optional. A regular expression, as a string, that :class:`FilePathField` |     Optional. A regular expression, as a string, that :class:`FilePathField` | ||||||
|   | |||||||
| @@ -206,6 +206,8 @@ Models | |||||||
|  |  | ||||||
| * ``connection.queries`` now shows ``COPY … TO`` statements on PostgreSQL. | * ``connection.queries`` now shows ``COPY … TO`` statements on PostgreSQL. | ||||||
|  |  | ||||||
|  | * :class:`~django.db.models.FilePathField` now accepts a callable ``path``. | ||||||
|  |  | ||||||
| Requests and Responses | Requests and Responses | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -10,3 +10,13 @@ class FilePathFieldTests(SimpleTestCase): | |||||||
|         field = FilePathField(path=path) |         field = FilePathField(path=path) | ||||||
|         self.assertEqual(field.path, path) |         self.assertEqual(field.path, path) | ||||||
|         self.assertEqual(field.formfield().path, path) |         self.assertEqual(field.formfield().path, path) | ||||||
|  |  | ||||||
|  |     def test_callable_path(self): | ||||||
|  |         path = os.path.dirname(__file__) | ||||||
|  |  | ||||||
|  |         def generate_path(): | ||||||
|  |             return path | ||||||
|  |  | ||||||
|  |         field = FilePathField(path=generate_path) | ||||||
|  |         self.assertEqual(field.path(), path) | ||||||
|  |         self.assertEqual(field.formfield().path, path) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user