]> git.openstreetmap.org Git - nominatim.git/blob - test/python/test_config.py
Merge pull request #2142 from lonvia/update-bdd-api-tests
[nominatim.git] / test / python / test_config.py
1 """
2 Test for loading dotenv configuration.
3 """
4 from pathlib import Path
5 import tempfile
6 import os
7
8 import pytest
9
10 from nominatim.config import Configuration
11
12 DEFCFG_DIR = Path(__file__) / '..' / '..' / '..' / 'settings'
13
14 def test_no_project_dir():
15     config = Configuration(None, DEFCFG_DIR)
16
17     assert config.DATABASE_WEBUSER == 'www-data'
18
19 def test_prefer_project_setting_over_default():
20     with tempfile.TemporaryDirectory() as project_dir:
21         with open(project_dir + '/.env', 'w') as envfile:
22             envfile.write('NOMINATIM_DATABASE_WEBUSER=apache\n')
23
24         config = Configuration(Path(project_dir), DEFCFG_DIR)
25
26         assert config.DATABASE_WEBUSER == 'apache'
27
28 def test_prefer_os_environ_over_project_setting():
29     with tempfile.TemporaryDirectory() as project_dir:
30         with open(project_dir + '/.env', 'w') as envfile:
31             envfile.write('NOMINATIM_DATABASE_WEBUSER=apache\n')
32
33         os.environ['NOMINATIM_DATABASE_WEBUSER'] = 'nobody'
34
35         config = Configuration(Path(project_dir), DEFCFG_DIR)
36
37         assert config.DATABASE_WEBUSER == 'nobody'
38
39         del os.environ['NOMINATIM_DATABASE_WEBUSER']
40
41 def test_get_os_env_add_defaults():
42     config = Configuration(None, DEFCFG_DIR)
43
44     if 'NOMINATIM_DATABASE_WEBUSER' in os.environ:
45         del os.environ['NOMINATIM_DATABASE_WEBUSER']
46
47     assert config.get_os_env()['NOMINATIM_DATABASE_WEBUSER'] == 'www-data'
48
49 def test_get_os_env_prefer_os_environ():
50     config = Configuration(None, DEFCFG_DIR)
51
52     os.environ['NOMINATIM_DATABASE_WEBUSER'] = 'nobody'
53
54     assert config.get_os_env()['NOMINATIM_DATABASE_WEBUSER'] == 'nobody'
55
56     del os.environ['NOMINATIM_DATABASE_WEBUSER']