mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Improved model validator so that it validates admin.list_display values
git-svn-id: http://code.djangoproject.com/svn/django/trunk@650 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -537,8 +537,20 @@ def get_validation_errors(outfile): | |||||||
|                                 e.add(opts, '"%s" field: "choices" should be a sequence of two-tuples.' % f.name) |                                 e.add(opts, '"%s" field: "choices" should be a sequence of two-tuples.' % f.name) | ||||||
|  |  | ||||||
|             # Check admin attribute. |             # Check admin attribute. | ||||||
|             if opts.admin is not None and not isinstance(opts.admin, meta.Admin): |             if opts.admin is not None: | ||||||
|  |                 if not isinstance(opts.admin, meta.Admin): | ||||||
|                     e.add(opts, '"admin" attribute, if given, must be set to a meta.Admin() instance.') |                     e.add(opts, '"admin" attribute, if given, must be set to a meta.Admin() instance.') | ||||||
|  |                 else: | ||||||
|  |                     for fn in opts.admin.list_display: | ||||||
|  |                         try: | ||||||
|  |                             f = opts.get_field(fn) | ||||||
|  |                         except meta.FieldDoesNotExist: | ||||||
|  |                             klass = opts.get_model_module().Klass | ||||||
|  |                             if not hasattr(klass, fn) or not callable(getattr(klass, fn)): | ||||||
|  |                                 e.add(opts, '"admin.list_display" refers to %r, which isn\'t a field or method.' % fn) | ||||||
|  |                         else: | ||||||
|  |                             if isinstance(f, meta.ManyToManyField): | ||||||
|  |                                 e.add(opts, '"admin.list_display" doesn\'t support ManyToManyFields (%r).' % fn) | ||||||
|  |  | ||||||
|             # Check ordering attribute. |             # Check ordering attribute. | ||||||
|             if opts.ordering: |             if opts.ordering: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user