mirror of
https://github.com/Hopiu/wagtail.git
synced 2026-05-26 15:44:01 +00:00
Support for foreign related objects for Elasticsearch backend search.
See pull request #2547.
This commit is contained in:
parent
4bd8ebb85f
commit
90a62523d1
5 changed files with 69 additions and 4 deletions
22
wagtail/tests/search/migrations/0003_subobject.py
Normal file
22
wagtail/tests/search/migrations/0003_subobject.py
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
from __future__ import unicode_literals
|
||||
from django.db import models, migrations
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('searchtests', '0002_anothersearchtestchild'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='SearchTestSubObject',
|
||||
fields=[
|
||||
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('parent', models.ForeignKey(to='searchtests.SearchTest', related_name='subobjects', on_delete=models.deletion.CASCADE)),
|
||||
('name', models.CharField(max_length=255)),
|
||||
],
|
||||
bases=(models.Model,),
|
||||
),
|
||||
]
|
||||
|
|
@ -19,6 +19,9 @@ class SearchTest(index.Indexed, models.Model):
|
|||
index.SearchField('name', partial_match=True),
|
||||
index.FilterField('slug'),
|
||||
]),
|
||||
index.RelatedFields('subobjects', [
|
||||
index.SearchField('name', partial_match=True),
|
||||
]),
|
||||
index.SearchField('content'),
|
||||
index.SearchField('callable_indexed_field'),
|
||||
index.FilterField('title'),
|
||||
|
|
@ -79,3 +82,11 @@ class AnotherSearchTestChild(SearchTest):
|
|||
search_fields = SearchTest.search_fields + [
|
||||
index.SearchField('subtitle', boost=10),
|
||||
]
|
||||
|
||||
|
||||
class SearchTestSubObject(models.Model):
|
||||
parent = models.ForeignKey(SearchTest, related_name='subobjects')
|
||||
name = models.CharField(max_length=255)
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
|
|
|||
|
|
@ -245,6 +245,9 @@ class RelatedFields(object):
|
|||
if isinstance(field, RelatedField):
|
||||
return getattr(obj, self.field_name)
|
||||
|
||||
if isinstance(field, ForeignObjectRel):
|
||||
return getattr(obj, self.field_name)
|
||||
|
||||
def select_on_queryset(self, queryset):
|
||||
"""
|
||||
This method runs either prefetch_related or select_related on the queryset
|
||||
|
|
|
|||
|
|
@ -55,6 +55,7 @@ class BackendTests(WagtailTestUtils):
|
|||
testa = models.SearchTest()
|
||||
testa.title = "Hello World"
|
||||
testa.save()
|
||||
testa.subobjects.create(name='A subobject')
|
||||
self.backend.add(testa)
|
||||
self.testa = testa
|
||||
|
||||
|
|
|
|||
|
|
@ -90,6 +90,10 @@ class TestElasticsearchSearchBackend(BackendTests, TestCase):
|
|||
self.assertEqual(len(results), 1)
|
||||
self.assertEqual(results[0].id, obj.id)
|
||||
|
||||
def test_related_objects_search(self):
|
||||
results = self.backend.search("A subobject", models.SearchTest)
|
||||
self.assertEqual(set(results), {self.testa})
|
||||
|
||||
def test_ascii_folding(self):
|
||||
# Reset the index
|
||||
self.reset_index()
|
||||
|
|
@ -754,6 +758,7 @@ class TestElasticsearchMapping(TestCase):
|
|||
self.obj = models.SearchTest(title="Hello")
|
||||
self.obj.save()
|
||||
self.obj.tags.add("a tag")
|
||||
self.obj.subobjects.create(name="A subobject")
|
||||
|
||||
def test_get_document_type(self):
|
||||
self.assertEqual(self.es_mapping.get_document_type(), 'searchtests_searchtest')
|
||||
|
|
@ -780,7 +785,13 @@ class TestElasticsearchMapping(TestCase):
|
|||
'properties': {
|
||||
'name': {'type': 'string', 'include_in_all': True, 'index_analyzer': 'edgengram_analyzer'},
|
||||
'slug_filter': {'index': 'not_analyzed', 'type': 'string', 'include_in_all': False},
|
||||
}
|
||||
},
|
||||
},
|
||||
'subobjects': {
|
||||
'type': 'nested',
|
||||
'properties': {
|
||||
'name': {'type': 'string', 'include_in_all': True, 'index_analyzer': 'edgengram_analyzer'},
|
||||
},
|
||||
},
|
||||
}
|
||||
}
|
||||
|
|
@ -803,7 +814,7 @@ class TestElasticsearchMapping(TestCase):
|
|||
expected_result = {
|
||||
'pk': str(self.obj.pk),
|
||||
'content_type': 'searchtests_searchtest',
|
||||
'_partials': ['Hello', 'a tag'],
|
||||
'_partials': ['A subobject', 'Hello', 'a tag'],
|
||||
'live_filter': False,
|
||||
'published_date_filter': None,
|
||||
'title': 'Hello',
|
||||
|
|
@ -816,6 +827,11 @@ class TestElasticsearchMapping(TestCase):
|
|||
'slug_filter': 'a-tag',
|
||||
}
|
||||
],
|
||||
'subobjects': [
|
||||
{
|
||||
'name': 'A subobject'
|
||||
}
|
||||
],
|
||||
}
|
||||
|
||||
self.assertDictEqual(document, expected_result)
|
||||
|
|
@ -836,6 +852,7 @@ class TestElasticsearchMappingInheritance(TestCase):
|
|||
self.obj = models.SearchTestChild(title="Hello", subtitle="World", page_id=1)
|
||||
self.obj.save()
|
||||
self.obj.tags.add("a tag")
|
||||
self.obj.subobjects.create(name="A subobject")
|
||||
|
||||
def test_get_document_type(self):
|
||||
self.assertEqual(self.es_mapping.get_document_type(), 'searchtests_searchtest_searchtests_searchtestchild')
|
||||
|
|
@ -875,7 +892,13 @@ class TestElasticsearchMappingInheritance(TestCase):
|
|||
'properties': {
|
||||
'name': {'type': 'string', 'include_in_all': True, 'index_analyzer': 'edgengram_analyzer'},
|
||||
'slug_filter': {'index': 'not_analyzed', 'type': 'string', 'include_in_all': False},
|
||||
}
|
||||
},
|
||||
},
|
||||
'subobjects': {
|
||||
'type': 'nested',
|
||||
'properties': {
|
||||
'name': {'type': 'string', 'include_in_all': True, 'index_analyzer': 'edgengram_analyzer'},
|
||||
},
|
||||
},
|
||||
}
|
||||
}
|
||||
|
|
@ -913,7 +936,7 @@ class TestElasticsearchMappingInheritance(TestCase):
|
|||
|
||||
# Inherited
|
||||
'pk': str(self.obj.pk),
|
||||
'_partials': ['Hello', 'Root', 'World', 'a tag'],
|
||||
'_partials': ['A subobject', 'Hello', 'Root', 'World', 'a tag'],
|
||||
'live_filter': False,
|
||||
'published_date_filter': None,
|
||||
'title': 'Hello',
|
||||
|
|
@ -926,6 +949,11 @@ class TestElasticsearchMappingInheritance(TestCase):
|
|||
'slug_filter': 'a-tag',
|
||||
}
|
||||
],
|
||||
'subobjects': [
|
||||
{
|
||||
'name': 'A subobject',
|
||||
}
|
||||
],
|
||||
}
|
||||
|
||||
self.assertDictEqual(document, expected_result)
|
||||
|
|
|
|||
Loading…
Reference in a new issue