]> git.openstreetmap.org Git - nominatim.git/blobdiff - test/python/api/conftest.py
implement details endpoint in Python servers
[nominatim.git] / test / python / api / conftest.py
index 0164ee22cd5ea29c6d396097a513fd1f2e02c482..294240163140ec1d1e272b267d37034a28615d9e 100644 (file)
@@ -18,7 +18,7 @@ from nominatim.db.sql_preprocessor import SQLPreprocessor
 class APITester:
 
     def __init__(self):
-        self.api = napi.NominatimAPI(Path('/invalid'), {})
+        self.api = napi.NominatimAPI(Path('/invalid'))
         self.async_to_sync(self.api._async_api.setup_database())
 
 
@@ -93,6 +93,30 @@ class APITester:
                       'linegeo': 'SRID=4326;' + kw.get('geometry', 'LINESTRING(1.1 -0.2, 1.09 -0.22)')})
 
 
+    def add_tiger(self, **kw):
+        self.add_data('tiger',
+                     {'place_id': kw.get('place_id', 30000),
+                      'parent_place_id': kw.get('parent_place_id'),
+                      'startnumber': kw.get('startnumber', 2),
+                      'endnumber': kw.get('endnumber', 6),
+                      'step': kw.get('step', 2),
+                      'postcode': kw.get('postcode'),
+                      'linegeo': 'SRID=4326;' + kw.get('geometry', 'LINESTRING(1.1 -0.2, 1.09 -0.22)')})
+
+
+    def add_postcode(self, **kw):
+        self.add_data('postcode',
+                     {'place_id': kw.get('place_id', 1000),
+                      'parent_place_id': kw.get('parent_place_id'),
+                      'country_code': kw.get('country_code'),
+                      'postcode': kw.get('postcode'),
+                      'rank_search': kw.get('rank_search', 20),
+                      'rank_address': kw.get('rank_address', 22),
+                      'indexed_date': kw.get('indexed_date',
+                                             dt.datetime(2022, 12, 7, 14, 14, 46, 0)),
+                      'geometry': 'SRID=4326;' + kw.get('geometry', 'POINT(23 34)')})
+
+
     async def exec_async(self, sql, *args, **kwargs):
         async with self.api._async_api.begin() as conn:
             return await conn.execute(sql, *args, **kwargs)
@@ -104,9 +128,10 @@ class APITester:
 
 
 @pytest.fixture
-def apiobj(temp_db_with_extensions, temp_db_conn):
+def apiobj(temp_db_with_extensions, temp_db_conn, monkeypatch):
     """ Create an asynchronous SQLAlchemy engine for the test DB.
     """
+    monkeypatch.setenv('NOMINATIM_USE_US_TIGER_DATA', 'yes')
     testapi = APITester()
     testapi.async_to_sync(testapi.create_tables())