projects
/
nominatim.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge pull request #3338 from lonvia/remove-nested-cli-groups
[nominatim.git]
/
test
/
python
/
api
/
search
/
test_search_postcode.py
diff --git
a/test/python/api/search/test_search_postcode.py
b/test/python/api/search/test_search_postcode.py
index e7153f38bf8b6147a268d5b051422d0d8d415680..6976b6a592ac5921fbb283c84c411065500793bb 100644
(file)
--- a/
test/python/api/search/test_search_postcode.py
+++ b/
test/python/api/search/test_search_postcode.py
@@
-15,7
+15,7
@@
from nominatim.api.search.db_searches import PostcodeSearch
from nominatim.api.search.db_search_fields import WeightedStrings, FieldLookup, \
FieldRanking, RankedTokens
from nominatim.api.search.db_search_fields import WeightedStrings, FieldLookup, \
FieldRanking, RankedTokens
-def run_search(apiobj, global_penalty, pcs, pc_penalties=None,
+def run_search(apiobj,
frontend,
global_penalty, pcs, pc_penalties=None,
ccodes=[], lookup=[], ranking=[], details=SearchDetails()):
if pc_penalties is None:
pc_penalties = [0.0] * len(pcs)
ccodes=[], lookup=[], ranking=[], details=SearchDetails()):
if pc_penalties is None:
pc_penalties = [0.0] * len(pcs)
@@
-29,28
+29,30
@@
def run_search(apiobj, global_penalty, pcs, pc_penalties=None,
search = PostcodeSearch(0.0, MySearchData())
search = PostcodeSearch(0.0, MySearchData())
+ api = frontend(apiobj, options=['search'])
+
async def run():
async def run():
- async with api
obj.api
._async_api.begin() as conn:
+ async with api._async_api.begin() as conn:
return await search.lookup(conn, details)
return await search.lookup(conn, details)
- return api
obj.async_to_sync
(run())
+ return api
._loop.run_until_complete
(run())
-def test_postcode_only_search(apiobj):
+def test_postcode_only_search(apiobj
, frontend
):
apiobj.add_postcode(place_id=100, country_code='ch', postcode='12345')
apiobj.add_postcode(place_id=101, country_code='pl', postcode='12 345')
apiobj.add_postcode(place_id=100, country_code='ch', postcode='12345')
apiobj.add_postcode(place_id=101, country_code='pl', postcode='12 345')
- results = run_search(apiobj, 0.3, ['12345', '12 345'], [0.0, 0.1])
+ results = run_search(apiobj,
frontend,
0.3, ['12345', '12 345'], [0.0, 0.1])
assert len(results) == 2
assert [r.place_id for r in results] == [100, 101]
assert len(results) == 2
assert [r.place_id for r in results] == [100, 101]
-def test_postcode_with_country(apiobj):
+def test_postcode_with_country(apiobj
, frontend
):
apiobj.add_postcode(place_id=100, country_code='ch', postcode='12345')
apiobj.add_postcode(place_id=101, country_code='pl', postcode='12 345')
apiobj.add_postcode(place_id=100, country_code='ch', postcode='12345')
apiobj.add_postcode(place_id=101, country_code='pl', postcode='12 345')
- results = run_search(apiobj, 0.3, ['12345', '12 345'], [0.0, 0.1],
+ results = run_search(apiobj,
frontend,
0.3, ['12345', '12 345'], [0.0, 0.1],
ccodes=['de', 'pl'])
assert len(results) == 1
ccodes=['de', 'pl'])
assert len(results) == 1
@@
-81,30
+83,30
@@
class TestPostcodeSearchWithAddress:
country_code='pl')
country_code='pl')
- def test_lookup_both(self, apiobj):
+ def test_lookup_both(self, apiobj
, frontend
):
lookup = FieldLookup('name_vector', [1,2], 'restrict')
ranking = FieldRanking('name_vector', 0.3, [RankedTokens(0.0, [10])])
lookup = FieldLookup('name_vector', [1,2], 'restrict')
ranking = FieldRanking('name_vector', 0.3, [RankedTokens(0.0, [10])])
- results = run_search(apiobj, 0.1, ['12345'], lookup=[lookup], ranking=[ranking])
+ results = run_search(apiobj,
frontend,
0.1, ['12345'], lookup=[lookup], ranking=[ranking])
assert [r.place_id for r in results] == [100, 101]
assert [r.place_id for r in results] == [100, 101]
- def test_restrict_by_name(self, apiobj):
+ def test_restrict_by_name(self, apiobj
, frontend
):
lookup = FieldLookup('name_vector', [10], 'restrict')
lookup = FieldLookup('name_vector', [10], 'restrict')
- results = run_search(apiobj, 0.1, ['12345'], lookup=[lookup])
+ results = run_search(apiobj,
frontend,
0.1, ['12345'], lookup=[lookup])
assert [r.place_id for r in results] == [100]
@pytest.mark.parametrize('coord,place_id', [((16.5, 5), 100),
((-45.1, 7.004), 101)])
assert [r.place_id for r in results] == [100]
@pytest.mark.parametrize('coord,place_id', [((16.5, 5), 100),
((-45.1, 7.004), 101)])
- def test_lookup_near(self, apiobj, coord, place_id):
+ def test_lookup_near(self, apiobj,
frontend,
coord, place_id):
lookup = FieldLookup('name_vector', [1,2], 'restrict')
ranking = FieldRanking('name_vector', 0.3, [RankedTokens(0.0, [10])])
lookup = FieldLookup('name_vector', [1,2], 'restrict')
ranking = FieldRanking('name_vector', 0.3, [RankedTokens(0.0, [10])])
- results = run_search(apiobj, 0.1, ['12345'],
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
lookup=[lookup], ranking=[ranking],
details=SearchDetails(near=napi.Point(*coord),
near_radius=0.6))
lookup=[lookup], ranking=[ranking],
details=SearchDetails(near=napi.Point(*coord),
near_radius=0.6))
@@
-116,8
+118,8
@@
class TestPostcodeSearchWithAddress:
napi.GeometryFormat.KML,
napi.GeometryFormat.SVG,
napi.GeometryFormat.TEXT])
napi.GeometryFormat.KML,
napi.GeometryFormat.SVG,
napi.GeometryFormat.TEXT])
- def test_return_geometries(self, apiobj, geom):
- results = run_search(apiobj, 0.1, ['12345'],
+ def test_return_geometries(self, apiobj,
frontend,
geom):
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
details=SearchDetails(geometry_output=geom))
assert results
details=SearchDetails(geometry_output=geom))
assert results
@@
-126,8
+128,8
@@
class TestPostcodeSearchWithAddress:
@pytest.mark.parametrize('viewbox, rids', [('-46,6,-44,8', [101,100]),
('16,4,18,6', [100,101])])
@pytest.mark.parametrize('viewbox, rids', [('-46,6,-44,8', [101,100]),
('16,4,18,6', [100,101])])
- def test_prefer_viewbox(self, apiobj, viewbox, rids):
- results = run_search(apiobj, 0.1, ['12345'],
+ def test_prefer_viewbox(self, apiobj,
frontend,
viewbox, rids):
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
details=SearchDetails.from_kwargs({'viewbox': viewbox}))
assert [r.place_id for r in results] == rids
details=SearchDetails.from_kwargs({'viewbox': viewbox}))
assert [r.place_id for r in results] == rids
@@
-135,8
+137,8
@@
class TestPostcodeSearchWithAddress:
@pytest.mark.parametrize('viewbox, rid', [('-46,6,-44,8', 101),
('16,4,18,6', 100)])
@pytest.mark.parametrize('viewbox, rid', [('-46,6,-44,8', 101),
('16,4,18,6', 100)])
- def test_restrict_to_viewbox(self, apiobj, viewbox, rid):
- results = run_search(apiobj, 0.1, ['12345'],
+ def test_restrict_to_viewbox(self, apiobj,
frontend,
viewbox, rid):
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
details=SearchDetails.from_kwargs({'viewbox': viewbox,
'bounded_viewbox': True}))
details=SearchDetails.from_kwargs({'viewbox': viewbox,
'bounded_viewbox': True}))
@@
-145,16
+147,16
@@
class TestPostcodeSearchWithAddress:
@pytest.mark.parametrize('coord,rids', [((17.05, 5), [100, 101]),
((-45, 7.1), [101, 100])])
@pytest.mark.parametrize('coord,rids', [((17.05, 5), [100, 101]),
((-45, 7.1), [101, 100])])
- def test_prefer_near(self, apiobj, coord, rids):
- results = run_search(apiobj, 0.1, ['12345'],
+ def test_prefer_near(self, apiobj,
frontend,
coord, rids):
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
details=SearchDetails(near=napi.Point(*coord)))
assert [r.place_id for r in results] == rids
@pytest.mark.parametrize('pid,rid', [(100, 101), (101, 100)])
details=SearchDetails(near=napi.Point(*coord)))
assert [r.place_id for r in results] == rids
@pytest.mark.parametrize('pid,rid', [(100, 101), (101, 100)])
- def test_exclude(self, apiobj, pid, rid):
- results = run_search(apiobj, 0.1, ['12345'],
+ def test_exclude(self, apiobj,
frontend,
pid, rid):
+ results = run_search(apiobj,
frontend,
0.1, ['12345'],
details=SearchDetails(excluded=[pid]))
assert [r.place_id for r in results] == [rid]
details=SearchDetails(excluded=[pid]))
assert [r.place_id for r in results] == [rid]