From: Sarah Hoffmann Date: Tue, 5 Jan 2021 14:17:46 +0000 (+0100) Subject: bdd: factor out reindexing on updates X-Git-Tag: v3.7.0~59^2~3 X-Git-Url: https://git.openstreetmap.org./nominatim.git/commitdiff_plain/25557e5f14734aa597dbe32293be25d2c539531c?hp=197870e67a82505d52fb2fd45db638435af956b0 bdd: factor out reindexing on updates --- diff --git a/test/bdd/steps/nominatim_environment.py b/test/bdd/steps/nominatim_environment.py index 2547bbe2..7013a20e 100644 --- a/test/bdd/steps/nominatim_environment.py +++ b/test/bdd/steps/nominatim_environment.py @@ -191,6 +191,20 @@ class NominatimEnvironment: if not self.keep_scenario_db: self.db_drop_database(self.test_db) + def reindex_placex(self, db): + """ Run the indexing step until all data in the placex has + been processed. Indexing during updates can produce more data + to index under some circumstances. That is why indexing may have + to be run multiple times. + """ + with db.cursor() as cur: + while True: + self.run_update_script('index') + + cur.execute("SELECT 'a' FROM placex WHERE indexed_status != 0 LIMIT 1") + if cur.rowcount == 0: + return + def run_setup_script(self, *args, **kwargs): """ Run the Nominatim setup script with the given arguments. """ diff --git a/test/bdd/steps/steps_db_ops.py b/test/bdd/steps/steps_db_ops.py index 8f20cdaa..6bee88c1 100644 --- a/test/bdd/steps/steps_db_ops.py +++ b/test/bdd/steps/steps_db_ops.py @@ -205,13 +205,7 @@ def update_place_table(context): for row in context.table: PlaceColumn(context).add_row(row, False).db_insert(cur) - while True: - context.nominatim.run_update_script('index') - - cur.execute("SELECT 'a' FROM placex WHERE indexed_status != 0 LIMIT 1") - if cur.rowcount == 0: - break - + context.nominatim.reindex_placex(context.db) check_database_integrity(context) @when("updating postcodes") @@ -227,13 +221,7 @@ def delete_places(context, oids): where, params = NominatimID(oid).table_select() cur.execute("DELETE FROM place WHERE " + where, params) - while True: - context.nominatim.run_update_script('index') - - with context.db.cursor() as cur: - cur.execute("SELECT 'a' FROM placex WHERE indexed_status != 0 LIMIT 1") - if cur.rowcount == 0: - break + context.nominatim.reindex_placex(context.db) ################################ THEN ##################################