From: Darkshredder Date: Fri, 12 Mar 2021 12:53:20 +0000 (+0530) Subject: refactored tests and made changes to code for easy readibility X-Git-Tag: v3.7.0~17^2~2 X-Git-Url: https://git.openstreetmap.org./nominatim.git/commitdiff_plain/077a8c1f95d2c0a18722f705df4b98d83d6f9385 refactored tests and made changes to code for easy readibility --- diff --git a/nominatim/tools/database_import.py b/nominatim/tools/database_import.py index 9d4cad16..4ba4493c 100644 --- a/nominatim/tools/database_import.py +++ b/nominatim/tools/database_import.py @@ -312,32 +312,29 @@ def create_country_names(conn, config): """ with conn.cursor() as cur: - cur.execute("""select - getorcreate_country(make_standard_name('uk') - , 'gb')""") - cur.execute("""select getorcreate_country(make_standard_name('united states'), 'us')""") - cur.execute("""select count(*) from - (select getorcreate_country(make_standard_name(country_code), - country_code) from country_name where country_code is not null) as x""") - cur.execute("""select count(*) from - (select getorcreate_country(make_standard_name(name->'name'), - country_code) from country_name where name ? 'name') as x""") - sql_statement = """select count(*) from (select getorcreate_country(make_standard_name(v) - , country_code) from (select country_code, skeys(name) - as k, svals(name) as v from country_name) x where k """ + cur.execute("""SELECT getorcreate_country(make_standard_name('uk'), 'gb')""") + cur.execute("""SELECT getorcreate_country(make_standard_name('united states'), 'us')""") + cur.execute("""SELECT COUNT(*) FROM + (SELECT getorcreate_country(make_standard_name(country_code), + country_code) FROM country_name WHERE country_code is not null) AS x""") + cur.execute("""SELECT COUNT(*) FROM + (SELECT getorcreate_country(make_standard_name(name->'name'), country_code) + FROM country_name WHERE name ? 'name') AS x""") + sql_statement = """SELECT COUNT(*) FROM (SELECT getorcreate_country(make_standard_name(v), + country_code) FROM (SELECT country_code, skeys(name) + AS k, svals(name) AS v FROM country_name) x WHERE k""" languages = config.LANGUAGES if languages: - sql_statement += 'in ' - delim = '(' + sql_statement = "{} IN (".format(sql_statement) + delim = '' for language in languages.split(','): - sql_statement += delim + "'name:" + language + "'" - delim = ',' - - sql_statement += ')' + sql_statement = "{}{}'name:{}'".format(sql_statement,delim,language) + delim = ', ' + sql_statement = '{})'.format(sql_statement) else: - sql_statement += "like 'name:%'" - sql_statement += ') v' + sql_statement = "{} LIKE 'name:%'".format(sql_statement) + sql_statement = "{}) v".format(sql_statement) cur.execute(sql_statement) conn.commit() diff --git a/test/python/test_tools_database_import.py b/test/python/test_tools_database_import.py index 2e76f5c5..e2852acb 100644 --- a/test/python/test_tools_database_import.py +++ b/test/python/test_tools_database_import.py @@ -209,17 +209,23 @@ def test_create_country_names(temp_db_conn, temp_db_cursor, def_config, 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)) + lookup_country_code varchar(2)) RETURNS INTEGER AS $$ BEGIN - INSERT INTO country_name VALUES (5, lookup_word); + INSERT INTO word VALUES (lookup_country_code); RETURN 5; END; $$ LANGUAGE plpgsql; """) - temp_db_cursor.execute('CREATE TABLE country_name (id int, country_code varchar(2), name hstore)') database_import.create_country_names(temp_db_conn, def_config) - assert temp_db_cursor.table_rows('country_name') == 4 + if languages: + assert temp_db_cursor.table_rows('word') == 4 + else: + assert temp_db_cursor.table_rows('word') == 5