Django Haystack & Whoosh Búsqueda de trabajo, pero SearchQuerySet Volver 0 resultados

Editar: Más información al final de la publicación ...

Pregunta original:

Parece que tengo el mismo problema que en esta pregunta (sin resolver):django-haystack + Whoosh SearchQuerySet (). all () siempre Ninguno

Configuré Haystack con Whoosh en mi proyecto Django y todo funcionaba bien al principio (SearchQuerySet solía devolver resultados), pero después de un intento abortado de crear un nuevo formulario de búsqueda personalizado (revertido de git) parece que la indexación y la página de búsqueda original todavía funciona bien, ¡pero ahora SearchQuerySet () siempre devuelve 0 resultados!

Corriendo:

manage.py rebuild_index --verbosity=2

Muestra correctamente:

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

Estos activos indexados se pueden buscar correctamente desde el formulario de búsqueda original.

Sin embargo, abrir un shell de Django y ejecutar:

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

Siempre vuelve0!

Pertinentepip 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:

Entonces, al buscar el código fuente de Haystack, descubrí de dónde viene el 0, ¡pero no por qué!

/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

    ....

Cambiando el0 a cualquier int hace que SearchQuerySet siempre devuelva ese int, pero todavía no sé por quéif not self._result_count sería cierto ...