diff options
| -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 | 
