]> git.openstreetmap.org Git - nominatim.git/blob - test/python/test_tokenizer_legacy.py
introduce external processing in indexer
[nominatim.git] / test / python / test_tokenizer_legacy.py
1 """
2 Test for legacy tokenizer.
3 """
4 import shutil
5
6 import pytest
7
8 from nominatim.tokenizer import legacy_tokenizer
9 from nominatim.db import properties
10 from nominatim.errors import UsageError
11
12 @pytest.fixture
13 def test_config(def_config, tmp_path):
14     def_config.project_dir = tmp_path / 'project'
15     def_config.project_dir.mkdir()
16
17     module_dir = tmp_path / 'module_src'
18     module_dir.mkdir()
19     (module_dir / 'nominatim.so').write_text('TEST nomiantim.so')
20
21     def_config.lib_dir.module = module_dir
22
23     sqldir = tmp_path / 'sql'
24     sqldir.mkdir()
25     (sqldir / 'tokenizer').mkdir()
26     (sqldir / 'tokenizer' / 'legacy_tokenizer.sql').write_text("SELECT 'a'")
27     (sqldir / 'words.sql').write_text("SELECT 'a'")
28     shutil.copy(str(def_config.lib_dir.sql / 'tokenizer' / 'legacy_tokenizer_tables.sql'),
29                 str(sqldir / 'tokenizer' / 'legacy_tokenizer_tables.sql'))
30
31     def_config.lib_dir.sql = sqldir
32     def_config.lib_dir.data = sqldir
33
34
35     return def_config
36
37
38 @pytest.fixture
39 def tokenizer_factory(dsn, tmp_path, monkeypatch):
40
41     def _maker():
42         return legacy_tokenizer.create(dsn, tmp_path / 'tokenizer')
43
44     return _maker
45
46 @pytest.fixture
47 def tokenizer_setup(tokenizer_factory, test_config, property_table,
48                     monkeypatch, sql_preprocessor):
49     monkeypatch.setattr(legacy_tokenizer, '_check_module' , lambda m, c: None)
50     tok = tokenizer_factory()
51     tok.init_new_db(test_config)
52
53
54 def test_init_new(tokenizer_factory, test_config, property_table, monkeypatch,
55                   temp_db_conn, sql_preprocessor):
56     monkeypatch.setenv('NOMINATIM_TERM_NORMALIZATION', 'xxvv')
57     monkeypatch.setattr(legacy_tokenizer, '_check_module' , lambda m, c: None)
58
59     tok = tokenizer_factory()
60     tok.init_new_db(test_config)
61
62     assert properties.get_property(temp_db_conn, legacy_tokenizer.DBCFG_NORMALIZATION) == 'xxvv'
63
64     outfile = test_config.project_dir / 'module' / 'nominatim.so'
65
66     assert outfile.exists()
67     assert outfile.read_text() == 'TEST nomiantim.so'
68     assert outfile.stat().st_mode == 33261
69
70
71 def test_init_module_load_failed(tokenizer_factory, test_config, property_table,
72                                  monkeypatch, temp_db_conn):
73     tok = tokenizer_factory()
74
75     with pytest.raises(UsageError):
76         tok.init_new_db(test_config)
77
78
79 def test_init_module_custom(tokenizer_factory, test_config, property_table,
80                             monkeypatch, tmp_path, sql_preprocessor):
81     module_dir = (tmp_path / 'custom').resolve()
82     module_dir.mkdir()
83     (module_dir/ 'nominatim.so').write_text('CUSTOM nomiantim.so')
84
85     monkeypatch.setenv('NOMINATIM_DATABASE_MODULE_PATH', str(module_dir))
86     monkeypatch.setattr(legacy_tokenizer, '_check_module' , lambda m, c: None)
87
88     tok = tokenizer_factory()
89     tok.init_new_db(test_config)
90
91     assert not (test_config.project_dir / 'module').exists()
92
93
94 def test_init_from_project(tokenizer_setup, tokenizer_factory):
95     tok = tokenizer_factory()
96
97     tok.init_from_project()
98
99     assert tok.normalization is not None