Fail if configuration is not found

If a configuration file is passed with a command line argument and the file is not found, Radicale shows a warning and continues with the default configuration.
There is no reason for doing this, Radicale should just fail.

Instead, this PR allows passing an empty string like ``--config ""``. Radicale will use the default configuration in this case, without trying to load the configuration from the common paths. Previously you had to do specify a path that doesn't exist like ``--config /does/not/exist``, which looks a bit ugly and showed a warning message.
This commit is contained in:
Unrud 2017-05-24 20:49:27 +02:00
parent 22d364729b
commit d2a17c36ae

View File

@ -74,9 +74,12 @@ def run():
group.add_argument(*args, **kwargs) group.add_argument(*args, **kwargs)
args = parser.parse_args() args = parser.parse_args()
if args.config: if args.config is not None:
configuration = config.load() configuration = config.load()
if args.config:
configuration_found = configuration.read(args.config) configuration_found = configuration.read(args.config)
else:
configuration_found = True
else: else:
configuration_paths = [ configuration_paths = [
"/etc/radicale/config", "/etc/radicale/config",
@ -101,7 +104,8 @@ def run():
# Log a warning if the configuration file of the command line is not found # Log a warning if the configuration file of the command line is not found
if not configuration_found: if not configuration_found:
logger.warning("Configuration file '%s' not found" % args.config) logger.error("Configuration file '%s' not found" % args.config)
exit(1)
try: try:
serve(configuration, logger) serve(configuration, logger)