After upgrading django to 1.7, I cannot execute the update_index control command.
Traceback (most recent call last): File "/opt/pycharm-3.4.1/helpers/pydev/pydevd.py", line 1733, in <module> debugger.run(setup['file'], None, None) File "/opt/pycharm-3.4.1/helpers/pydev/pydevd.py", line 1226, in run pydev_imports.execfile(file, globals, locals) # execute the script File "/home/tochium/projects/povary/manage.py", line 10, in <module> execute_from_command_line(sys.argv) File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line utility.execute() File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 377, in execute self.fetch_command(subcommand).run_from_argv(self.argv) File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 288, in run_from_argv self.execute(*args, **options.__dict__) File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 338, in execute output = self.handle(*args, **options) File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 184, in handle return super(Command, self).handle(*items, **options) File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 503, in handle label_output = self.handle_label(label, **options) File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 189, in handle_label self.update_backend(label, using) File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 234, in update_backend do_update(backend, index, qs, start, end, total, self.verbosity) File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 89, in do_update backend.update(index, current_qs) File "/home/tochium/projects/povary/src/xapian-haystack/xapian_backend.py", line 355, in update data = index.full_prepare(obj) File "/home/tochium/projects/povary/src/django-haystack/haystack/indexes.py", line 207, in full_prepare self.prepared_data = self.prepare(obj) File "/home/tochium/projects/povary/src/django-haystack/haystack/indexes.py", line 198, in prepare self.prepared_data[field.index_fieldname] = field.prepare(obj) File "/home/tochium/projects/povary/src/django-haystack/haystack/fields.py", line 159, in prepare return self.convert(super(CharField, self).prepare(obj)) File "/home/tochium/projects/povary/src/django-haystack/haystack/fields.py", line 106, in prepare return current_object() File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/db/models/fields/related.py", line 839, in __call__ manager = getattr(self.model, kwargs.pop('manager')) KeyError: u'manager'
I am using python2.7.6, django 1.7, django-haystack 2.3.1, search engine: xapian
I think the problem arises because django from 1.7 adds a call () method to ManyRelatedManager and now this condition occurs in the /haystack/fields.py file.
if callable(current_object): return current_object()
But in the call device_name must be defined, as we can see in the corresponding method
def __call__(self, **kwargs):
Thanks.