diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2018-11-08 11:32:34 +0100 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2018-11-08 11:32:34 +0100 |
commit | 43ce28e0926e991a0b7e34e11cb943e640ae12b5 (patch) | |
tree | efe7dd2baf8c357eb7d7f9ee9d34345e08b506e2 | |
parent | 83f352f37c8f034ebeca188a9716aafec765dfdf (diff) | |
download | Ishtar-43ce28e0926e991a0b7e34e11cb943e640ae12b5.tar.bz2 Ishtar-43ce28e0926e991a0b7e34e11cb943e640ae12b5.zip |
Search: manage criteria + text search
-rw-r--r-- | archaeological_operations/tests.py | 15 | ||||
-rw-r--r-- | ishtar_common/views_item.py | 19 |
2 files changed, 27 insertions, 7 deletions
diff --git a/archaeological_operations/tests.py b/archaeological_operations/tests.py index 4edf62e22..f8925f610 100644 --- a/archaeological_operations/tests.py +++ b/archaeological_operations/tests.py @@ -1661,6 +1661,21 @@ class OperationSearchTest(TestCase, OperationInitTest): search_open_q = unicode(pgettext("key for text search", u"is-open")) self._test_search(c, search_open_q, u"Yes", 2, "Boolean") + def test_mixed_search_vector(self): + operation_1 = models.Operation.objects.get(pk=self.operations[0].pk) + operation_1.common_name = u"Opération : Château de Fougères" + operation_1.year = 2042 + operation_1.save() + + c = Client() + c.login(username=self.username, password=self.password) + + search_year_q = unicode(pgettext("key for text search", u"year")) + q = '"chateau fougere" {}="2042"'.format(search_year_q) + response = c.get(reverse('get-operation'), {'search_vector': q}) + result = json.loads(response.content) + self.assertEqual(result['recordsTotal'], 1) + def create_relations(self): rel1 = models.RelationType.objects.create( symmetrical=True, label='Include', txt_idx='include') diff --git a/ishtar_common/views_item.py b/ishtar_common/views_item.py index 7c6cbc24a..c14973bc3 100644 --- a/ishtar_common/views_item.py +++ b/ishtar_common/views_item.py @@ -391,7 +391,7 @@ def _parse_parentheses_groups(groups, request_keys, current_dct=None, SEP = u"?ç;?" # replace spaces inside quote with this characters previous_quote = None while found != -1: - if previous_quote: + if previous_quote is not None: string = string[0:previous_quote] + \ string[previous_quote:found].replace(u' ', SEP) + \ string[found:] @@ -448,17 +448,22 @@ def _search_manage_search_vector(model, dct, exc_dct, request_keys): search_query, extra_dct, extra_exc_dct = _parse_parentheses_groups( parentheses_groups, request_keys) dct.update(extra_dct) + exc_dct.update(extra_exc_dct) if search_query: # remove inside parenthesis search_query = \ search_query.replace(u'(', u'').replace(u')', u'').strip() - dct['extras'].append( - {'where': [model._meta.db_table + - ".search_vector @@ (to_tsquery(%s, %s)) = true"], - 'params': [settings.ISHTAR_SEARCH_LANGUAGE, - search_query]} - ) + # manage full quoted + if search_query.startswith(u'"') and search_query.endswith(u'"'): + search_query = search_query[1:-1].replace(u" ", u" & ").strip() + if search_query: + dct['extras'].append( + {'where': [model._meta.db_table + + ".search_vector @@ (to_tsquery(%s, %s)) = true"], + 'params': [settings.ISHTAR_SEARCH_LANGUAGE, + search_query]} + ) return dct, exc_dct |