from nominatim.db import properties
@pytest.fixture
-def prop_table(table_factory):
- table_factory('nominatim_properties', 'property TEXT, value TEXT')
+def property_factory(property_table, temp_db_cursor):
+ """ A function fixture that adds a property into the property table.
+ """
+ def _add_property(name, value):
+ temp_db_cursor.execute("INSERT INTO nominatim_properties VALUES(%s, %s)",
+ (name, value))
+ return _add_property
-def test_get_property_existing(prop_table, temp_db_conn, temp_db_cursor):
- temp_db_cursor.execute("INSERT INTO nominatim_properties VALUES('foo', 'bar')")
+
+def test_get_property_existing(property_factory, temp_db_conn):
+ property_factory('foo', 'bar')
assert properties.get_property(temp_db_conn, 'foo') == 'bar'
-def test_get_property_unknown(prop_table, temp_db_conn, temp_db_cursor):
- temp_db_cursor.execute("INSERT INTO nominatim_properties VALUES('other', 'bar')")
+def test_get_property_unknown(property_factory, temp_db_conn):
+ property_factory('other', 'bar')
assert properties.get_property(temp_db_conn, 'foo') is None
@pytest.mark.parametrize("prefill", (True, False))
-def test_set_property_new(prop_table, temp_db_conn, temp_db_cursor, prefill):
+def test_set_property_new(property_factory, temp_db_conn, temp_db_cursor, prefill):
if prefill:
- temp_db_cursor.execute("INSERT INTO nominatim_properties VALUES('something', 'bar')")
+ property_factory('something', 'bar')
properties.set_property(temp_db_conn, 'something', 'else')