X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/afabbeb546b94bfcdc1b5fbba37c04b5e07b54ed..b88b952f56d6ac1eec46202ba05a04fcd12575d9:/test/python/test_tools_database_import.py diff --git a/test/python/test_tools_database_import.py b/test/python/test_tools_database_import.py index 45324834..1311ef5d 100644 --- a/test/python/test_tools_database_import.py +++ b/test/python/test_tools_database_import.py @@ -187,7 +187,7 @@ def test_truncate_database_tables(temp_db_conn, temp_db_cursor, table_factory): @pytest.mark.parametrize("threads", (1, 5)) def test_load_data(dsn, src_dir, place_row, placex_table, osmline_table, word_table, temp_db_cursor, threads): - for func in ('make_keywords', 'getorcreate_housenumber_id', 'make_standard_name'): + for func in ('precompute_words', 'getorcreate_housenumber_id', 'make_standard_name'): temp_db_cursor.execute("""CREATE FUNCTION {} (src TEXT) RETURNS TEXT AS $$ SELECT 'a'::TEXT $$ LANGUAGE SQL """.format(func)) @@ -200,3 +200,32 @@ def test_load_data(dsn, src_dir, place_row, placex_table, osmline_table, word_ta assert temp_db_cursor.table_rows('placex') == 30 assert temp_db_cursor.table_rows('location_property_osmline') == 1 + +@pytest.mark.parametrize("languages", (False, True)) +def test_create_country_names(temp_db_conn, temp_db_cursor, def_config, + temp_db_with_extensions, monkeypatch, languages): + if languages: + monkeypatch.setenv('NOMINATIM_LANGUAGES', 'fr,en') + temp_db_cursor.execute("""CREATE FUNCTION make_standard_name (name TEXT) + RETURNS TEXT AS $$ SELECT 'a'::TEXT $$ LANGUAGE SQL + """) + temp_db_cursor.execute('CREATE TABLE country_name (country_code varchar(2), name hstore)') + temp_db_cursor.execute('CREATE TABLE word (code varchar(2))') + temp_db_cursor.execute("""INSERT INTO country_name VALUES ('us', + '"name"=>"us","name:af"=>"us"')""") + temp_db_cursor.execute("""CREATE OR REPLACE FUNCTION getorcreate_country(lookup_word TEXT, + lookup_country_code varchar(2)) + RETURNS INTEGER + AS $$ + BEGIN + INSERT INTO word VALUES (lookup_country_code); + RETURN 5; + END; + $$ + LANGUAGE plpgsql; + """) + database_import.create_country_names(temp_db_conn, def_config) + if languages: + assert temp_db_cursor.table_rows('word') == 4 + else: + assert temp_db_cursor.table_rows('word') == 5