]> git.openstreetmap.org Git - nominatim.git/blob - test/python/api/search/test_query.py
enable flake for Python tests
[nominatim.git] / test / python / api / search / test_query.py
1 # SPDX-License-Identifier: GPL-3.0-or-later
2 #
3 # This file is part of Nominatim. (https://nominatim.org)
4 #
5 # Copyright (C) 2025 by the Nominatim developer community.
6 # For a full list of authors see the git log.
7 """
8 Test data types for search queries.
9 """
10 import pytest
11
12 import nominatim_api.search.query as nq
13
14
15 def test_token_range_equal():
16     assert nq.TokenRange(2, 3) == nq.TokenRange(2, 3)
17     assert not (nq.TokenRange(2, 3) != nq.TokenRange(2, 3))
18
19
20 @pytest.mark.parametrize('lop,rop', [((1, 2), (3, 4)),
21                                      ((3, 4), (3, 5)),
22                                      ((10, 12), (11, 12))])
23 def test_token_range_unequal(lop, rop):
24     assert not (nq.TokenRange(*lop) == nq.TokenRange(*rop))
25     assert nq.TokenRange(*lop) != nq.TokenRange(*rop)
26
27
28 def test_token_range_lt():
29     assert nq.TokenRange(1, 3) < nq.TokenRange(10, 12)
30     assert nq.TokenRange(5, 6) < nq.TokenRange(7, 8)
31     assert nq.TokenRange(1, 4) < nq.TokenRange(4, 5)
32     assert not (nq.TokenRange(5, 6) < nq.TokenRange(5, 6))
33     assert not (nq.TokenRange(10, 11) < nq.TokenRange(4, 5))
34
35
36 def test_token_rankge_gt():
37     assert nq.TokenRange(3, 4) > nq.TokenRange(1, 2)
38     assert nq.TokenRange(100, 200) > nq.TokenRange(10, 11)
39     assert nq.TokenRange(10, 11) > nq.TokenRange(4, 10)
40     assert not (nq.TokenRange(5, 6) > nq.TokenRange(5, 6))
41     assert not (nq.TokenRange(1, 2) > nq.TokenRange(3, 4))
42     assert not (nq.TokenRange(4, 10) > nq.TokenRange(3, 5))
43
44
45 def test_token_range_unimplemented_ops():
46     with pytest.raises(TypeError):
47         nq.TokenRange(1, 3) <= nq.TokenRange(10, 12)
48     with pytest.raises(TypeError):
49         nq.TokenRange(1, 3) >= nq.TokenRange(10, 12)
50
51
52 def test_query_extract_words():
53     q = nq.QueryStruct([])
54     q.add_node(nq.BREAK_WORD, nq.PHRASE_ANY, 0.1, '12', '')
55     q.add_node(nq.BREAK_TOKEN, nq.PHRASE_ANY, 0.0, 'ab', '')
56     q.add_node(nq.BREAK_PHRASE, nq.PHRASE_ANY, 0.0, '12', '')
57     q.add_node(nq.BREAK_END, nq.PHRASE_ANY, 0.5, 'hallo', '')
58
59     words = q.extract_words(base_penalty=1.0)
60
61     assert set(words.keys()) \
62         == {'12', 'ab', 'hallo', '12 ab', 'ab 12', '12 ab 12'}
63     assert sorted(words['12']) == [nq.TokenRange(0, 1, 1.0), nq.TokenRange(2, 3, 1.0)]
64     assert words['12 ab'] == [nq.TokenRange(0, 2, 1.1)]
65     assert words['hallo'] == [nq.TokenRange(3, 4, 1.0)]