X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/efafa5271957fb54b356ec1c90e8613f14de40d4..8b41b80bff156c2b9cdebfa2b0fba75421fb228a:/test/bdd/environment.py diff --git a/test/bdd/environment.py b/test/bdd/environment.py index 0acc73b4..155b8d90 100644 --- a/test/bdd/environment.py +++ b/test/bdd/environment.py @@ -1,20 +1,22 @@ -# SPDX-License-Identifier: GPL-2.0-only +# SPDX-License-Identifier: GPL-3.0-or-later # # This file is part of Nominatim. (https://nominatim.org) # -# Copyright (C) 2022 by the Nominatim developer community. +# Copyright (C) 2024 by the Nominatim developer community. # For a full list of authors see the git log. from pathlib import Path +import sys from behave import * +sys.path.insert(1, str(Path(__file__, '..', '..', '..', 'src').resolve())) + from steps.geometry_factory import GeometryFactory from steps.nominatim_environment import NominatimEnvironment -TEST_BASE_DIR = Path(__file__) / '..' / '..' +TEST_BASE_DIR = Path(__file__, '..', '..').resolve() userconfig = { - 'BUILDDIR' : (TEST_BASE_DIR / '..' / 'build').resolve(), 'REMOVE_TEMPLATE' : False, 'KEEP_TEST_DB' : False, 'DB_HOST' : None, @@ -24,10 +26,11 @@ userconfig = { 'TEMPLATE_DB' : 'test_template_nominatim', 'TEST_DB' : 'test_nominatim', 'API_TEST_DB' : 'test_api_nominatim', - 'API_TEST_FILE' : (TEST_BASE_DIR / 'testdb' / 'apidb-test-data.pbf').resolve(), + 'API_TEST_FILE' : TEST_BASE_DIR / 'testdb' / 'apidb-test-data.pbf', 'SERVER_MODULE_PATH' : None, 'TOKENIZER' : None, # Test with a custom tokenizer - 'PHPCOV' : False, # set to output directory to enable code coverage + 'STYLE' : 'extratags', + 'API_ENGINE': 'falcon' } use_step_matcher("re") @@ -44,13 +47,15 @@ def before_all(context): def before_scenario(context, scenario): - if 'DB' in context.tags: + if not 'SQLITE' in context.tags \ + and context.config.userdata['API_TEST_DB'].startswith('sqlite:'): + context.scenario.skip("Not usable with Sqlite database.") + elif 'DB' in context.tags: context.nominatim.setup_db(context) elif 'APIDB' in context.tags: context.nominatim.setup_api_db() elif 'UNKNOWNDB' in context.tags: context.nominatim.setup_unknown_db() - context.scene = None def after_scenario(context, scenario): if 'DB' in context.tags: @@ -59,5 +64,11 @@ def after_scenario(context, scenario): def before_tag(context, tag): if tag == 'fail-legacy': - if context.config.userdata['TOKENIZER'] in (None, 'legacy'): + if context.config.userdata['TOKENIZER'] == 'legacy': context.scenario.skip("Not implemented in legacy tokenizer") + if tag == 'v1-api-php-only': + if context.config.userdata['API_ENGINE'] != 'php': + context.scenario.skip("Only valid with PHP version of v1 API.") + if tag == 'v1-api-python-only': + if context.config.userdata['API_ENGINE'] == 'php': + context.scenario.skip("Only valid with Python version of v1 API.")