diff options
| author | Charles Cabergs <me@cacharle.xyz> | 2021-02-27 16:12:34 +0100 |
|---|---|---|
| committer | Charles Cabergs <me@cacharle.xyz> | 2021-02-27 16:12:34 +0100 |
| commit | 820d1ee00975d2e7859e4b2aded88dbf56a3b347 (patch) | |
| tree | 014ded3157acdd145b8eaff8c635b33a7740dfa7 /minishell_test/config.py | |
| parent | 0cf5f137f886bd4e80868dcf2cf74b3f3b2c28d3 (diff) | |
| download | minishell_test-820d1ee00975d2e7859e4b2aded88dbf56a3b347.tar.gz minishell_test-820d1ee00975d2e7859e4b2aded88dbf56a3b347.tar.bz2 minishell_test-820d1ee00975d2e7859e4b2aded88dbf56a3b347.zip | |
Added configuration file section/key names check
Diffstat (limited to 'minishell_test/config.py')
| -rw-r--r-- | minishell_test/config.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/minishell_test/config.py b/minishell_test/config.py index 5a45e8b..1368740 100644 --- a/minishell_test/config.py +++ b/minishell_test/config.py @@ -6,7 +6,7 @@ # By: cacharle <me@cacharle.xyz> +#+ +:+ +#+ # # +#+#+#+#+#+ +#+ # # Created: 2021/02/26 09:40:36 by cacharle #+# #+# # -# Updated: 2021/02/27 15:13:19 by cacharle ### ########.fr # +# Updated: 2021/02/27 16:11:46 by cacharle ### ########.fr # # # # ############################################################################ # @@ -49,12 +49,17 @@ CONFIG_FILENAME = Path('minishell_test.cfg') config = ConfigParser() config.read(DATA_DIR / 'default.cfg') - -# TODO check user_config for unkown stuff user_config = ConfigParser() user_config.read(MINISHELL_DIR / CONFIG_FILENAME) -config.read_dict({**config, **user_config}) +for section in user_config: + if section not in config: + raise RuntimeError(f"Unknown section name: {section}") + for key in user_config[section]: + if key not in config[section]: + raise RuntimeError(f"Unknown key name: {key}") + +config.read_dict({**config, **user_config}) BONUS = config.getboolean('minishell_test', 'bonus') EXEC_NAME = config.get('minishell_test', 'exec_name') @@ -68,6 +73,7 @@ CHECK_ERROR_MESSAGES = config.getboolean('minishell_test', 'check_error_mess SHELL_AVAILABLE_COMMANDS = config.getmultiline('shell', 'available_commands') SHELL_PATH_VARIABLE = config.get('shell', 'path_variable') + SHELL_REFERENCE_PATH = config.getpath('shell:reference', 'path') SHELL_REFERENCE_ARGS = config.getargs('shell:reference', 'args') |
