aboutsummaryrefslogtreecommitdiff
path: root/minishell_test/config.py
diff options
context:
space:
mode:
authorCharles Cabergs <me@cacharle.xyz>2021-02-27 16:12:34 +0100
committerCharles Cabergs <me@cacharle.xyz>2021-02-27 16:12:34 +0100
commit820d1ee00975d2e7859e4b2aded88dbf56a3b347 (patch)
tree014ded3157acdd145b8eaff8c635b33a7740dfa7 /minishell_test/config.py
parent0cf5f137f886bd4e80868dcf2cf74b3f3b2c28d3 (diff)
downloadminishell_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.py14
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')