Django Haystack & Whoosh Search Working, But SearchQuerySet Retornar 0 resultados

Editar: mais informações na parte inferior da postagem ...

Pergunta original:

Parece que estou tendo o mesmo problema que nesta pergunta (não resolvida):django-haystack + Whoosh SearchQuerySet (). all () sempre Nenhum

Eu configurei o Haystack com Whoosh no meu projeto Django e tudo estava funcionando bem no início (o SearchQuerySet costumava retornar resultados), mas após uma tentativa abortada de criar um novo formulário de pesquisa personalizado (revertido do git), parece que a indexação e a página de pesquisa original ainda funciona bem, mas agora SearchQuerySet () sempre retorna 0 resultados!

Corrida:

manage.py rebuild_index --verbosity=2

Mostra corretamente:

Indexing 14 assets
    indexed 1 - 14 of 14 (worker PID: 1234).

Todos esses ativos indexados podem ser pesquisados corretamente no formulário de pesquisa original.

No entanto, abrindo um shell do Django e executando:

from haystack.query import SearchQuerySet
SearchQuerySet().all().count()

Retorna sempre0!

Relevantepip freeze:

Python 3.5.2Django 1.9.3django-haystack 2.5.0Whoosh 2.7.4

/myapp/search_indexes.py:

from haystack import indexes
from .models import Asset

class AssetIndex(indexes.SearchIndex, indexes.Indexable):
    text = indexes.NgramField(document=True, use_template=True)
    asset_description = indexes.CharField(model_attr='asset_description')
    manufacturer = indexes.CharField(model_attr='asset_manufacturer')

    def get_model(self):
        return Asset

    def no_query_found(self):
        return self.searchqueryset.exclude(content='foo')

    def index_queryset(self, using=None):
        return self.get_model().objects.all()

/myapp/templates/search/indexes/myapp/asset_text.txt:

{{ object.asset_description }}
{{ object.asset_details }}
{{ object.asset_manufacturer }}
{{ object.asset_model }}
... etc.

/myapp/urls.py:

urlpatterns = [
    ....
    url(r'^search/', include('haystack.urls')),
    ....
]

EDITAR:

Então, procurando no código-fonte do Haystack, descobri de onde vem o 0, mas não o porquê!

/myvenv/Lib/site-packages/hackstack/query.py

class SearchQuerySet(object):
    ...

    def __len__(self):
        if self._result_count is None:
            self._result_count = self.query.get_count()

        # Some backends give weird, false-y values here. Convert to zero.
        if not self._result_count:
            self._result_count = 0

    # This needs to return the actual number of hits, not what's in the cache.
    return self._result_count - self._ignored_result_count

    ....

Alterando a0 para qualquer int faz com que SearchQuerySet sempre retorne esse int, mas ainda não sei por queif not self._result_count seria verdade ...

questionAnswers(1)

yourAnswerToTheQuestion