log__printf(NULL,MOSQ_LOG_INFO,"Creating default listener due to '%s' option.",option_name);
log__printf(NULL,MOSQ_LOG_INFO,"Creating default listener due to '%s' option.",option_name);
log__printf(NULL,MOSQ_LOG_INFO,"It is best practice to define a 'listener' first. Using the '%s' option without a listener will be disabled in the future.",option_name);
if(config__add_listener(config)){
if(config__add_listener(config)){
log__printf(NULL,MOSQ_LOG_ERR,"Error: Out of memory.");
log__printf(NULL,MOSQ_LOG_ERR,"Error: Out of memory.");
do_test("user \n",3,'Error: Empty user value in configuration.')# Empty string, single space
do_test("user \n",3,'Error: Empty user value in configuration.')# Empty string, double space
do_test("user\n",3,"Error: Empty 'user' value in configuration.")# Empty string, no space
do_test("pid_file /tmp/pid\npid_file /tmp/pid\n",3,'Error: Duplicate pid_file value in configuration.')# Duplicate string
do_test("user \n",3,"Error: Empty 'user' value in configuration.")# Empty string, single space
do_test("user \n",3,"Error: Empty 'user' value in configuration.")# Empty string, double space
do_test("memory_limit\n",3,'Empty memory_limit value in configuration.')# Empty ssize_t
do_test("pid_file /tmp/pid\npid_file /tmp/pid\n",3,"Error: Duplicate 'pid_file' value in configuration.")# Duplicate string
do_test("accept_protocol_versions 3\n",3,'Error: You must define a listener before using the accept_protocol_versions option.')# Missing listener
do_test("memory_limit\n",3,"Empty 'memory_limit' value in configuration.")# Empty ssize_t
do_test("listener 1888\naccept_protocol_versions\n",3,'Error: Empty accept_protocol_versions value in configuration.')# Empty value
do_test("accept_protocol_versions 3\n",3,"Error: The 'accept_protocol_versions' option requires a listener to be defined first.")# Missing listener
do_test("allow_anonymous\n",3,'Error: Empty allow_anonymous value in configuration.')# Empty bool
do_test(f"listener {port}\naccept_protocol_versions\n",3,"Error: Empty 'accept_protocol_versions' value in configuration.")# Empty value
do_test("allow_anonymous falst\n",3,'Error: Invalid allow_anonymous value (falst).')# Invalid bool
do_test("allow_anonymous\n",3,"Error: Empty 'allow_anonymous' value in configuration.")# Empty bool
do_test("autosave_interval\n",3,'Error: Empty autosave_interval value in configuration.')# Empty int
do_test("allow_anonymous falst\n",3,"Error: Invalid 'allow_anonymous' value (falst).")# Invalid bool
#do_test("autosave_interval string\n", 3, 'bla') # Invalid int
do_test("autosave_interval\n",3,"Error: Empty 'autosave_interval' value in configuration.")# Empty int
do_test("listener\n",3,'Error: Empty listener value in configuration.')# Empty listener
#do_test("autosave_interval string\n", 3, 'bla") # Invalid int
do_test("mount_point test/\n",3,'Error: You must use create a listener before using the mount_point option in the configuration file.')# Missing listener config
do_test("listener 1888\nmount_point test/+/\n",3,"Error: Invalid mount_point 'test/+/'. Does it contain a wildcard character?")# Wildcard in mount point.
do_test("listener\n",3,"Error: Empty 'listener port' value in configuration.")# Empty listener
do_test("listener 1888\nprotocol\n",3,'Error: Empty protocol value in configuration.')# Empty proto
do_test("mount_point test/\n",3,"Error: The 'mount_point' option requires a listener to be defined first.")# Missing listener config
do_test("listener 1888\nprotocol test\n",3,'Error: Invalid protocol value (test).')# Invalid proto
do_test(f"listener {port}\nmount_point test/+/\n",3,"Error: Invalid 'mount_point' value (test/+/). Does it contain a wildcard character?")# Wildcard in mount point.
do_test(f"listener {port}\nprotocol\n",3,"Error: Empty 'protocol' value in configuration.")# Empty proto
do_test("plugin_opt_inval string\n",3,'Error: A plugin_opt_ option exists in the config file without a plugin.')# plugin_opt_ without plugin
do_test(f"listener {port}\nprotocol test\n",3,"Error: Invalid 'protocol' value (test).")# Invalid proto
do_test("plugin c/auth_plugin.so\nplugin_opt_test\n",3,'Error: Empty test value in configuration.')# Empty plugin_opt_
do_test("plugin_opt_inval string\n",3,"Error: The 'plugin_opt_inval' option requires plugin/global_plugin/plugin_load to be defined first.")# plugin_opt_ without plugin
do_test("bridge_attempt_unsubscribe true\n",3,"Error: The 'bridge_attempt_unsubscribe' option requires a bridge to be defined first.")# Missing bridge config
do_test("bridge_protocol_version string\n",3,"Error: The 'bridge_protocol_version' option requires a bridge to be defined first.")# Missing bridge config
do_test("bridge_session_expiry_interval 10000\n",3,"Error: The 'bridge_session_expiry_interval' option requires a bridge to be defined first.")# Missing bridge config
do_test("bridge_tcp_user_timeout 10000\n",3,"Error: The 'bridge_tcp_user_timeout' option requires a bridge to be defined first.")# Missing bridge config
do_test("notifications_local_only true\n",3,"Error: The 'notifications_local_only' option requires a bridge to be defined first")# Missing bridge config