integration/test_lib.sh: Copy binaries from $TOP_SRCDIR.
D'oh!
D'oh!
integration tests: Run all invocations through valgrind's memcheck.
… covering, both, sysdb and sysdbd. For that to work, copy the binaries and
libraries to the temp directory and change the rpath to point to the temp
directory. This ensures the test is independent of any configure flags and
installation directories.
Let the tests fail if a leak (or other error) was detected by valgrind.
… covering, both, sysdb and sysdbd. For that to work, copy the binaries and
libraries to the temp directory and change the rpath to point to the temp
directory. This ensures the test is independent of any configure flags and
installation directories.
Let the tests fail if a leak (or other error) was detected by valgrind.
simple_query.sh: Store output in a variable before analyzing it.
This ensures that we actually get and check the right exit code.
This ensures that we actually get and check the right exit code.
integration tests: Kill the right process when shutting down sysdbd.
Also, wait for it to terminate.
Also, wait for it to terminate.
sysdbd: Don't leak memory when aborting from the main loop.
client: Fixed a memory leak in case connection setup fails.
t/integration/: Added variables for sysdbd/sysdb/sysdb.conf.
t/coverage.sh: Don't use --disable-shared.
Else, mock_plugin.so won't be available during 'make test'.
Else, mock_plugin.so won't be available during 'make test'.
t/Makefile: Added integration test script to EXTRA_DIST.
t/integration/simple_query: Added test doing a simple query.
t/integration/mock_plugin: Added plugin for integration tests.
t/integration: Added simple framework for integration tests.
Added a test using very simple configuration snippets.
Added a test using very simple configuration snippets.
sysdbd: Return with status=1 in case of an initialization or config error.
frontend: Make UNIX sockets the default listener implementation.
sysdbd: Improved startup logging.
Don't log success until all initialization is actually done. Also, don't
enable the connection logger until before entering the frontend main loop.
Don't log success until all initialization is actually done. Also, don't
enable the connection logger until before entering the frontend main loop.
sysdbd.conf: Added 'PluginDir' config option.
core: Make the plugin directory configurable.
dbi utils: Added compat layer for DBI < 0.9.
.gitignore: Ignore test-suite.log.
dbi utils: Use the new _r interface.
Moved unit tests into t/unit/ subdirectory.
Merged branch 'master' of git://git.tokkee.org/sysdb.
frontend: Added destructors for dynamically allocated objects in the parser.
This will make sure that the memory is freed in case of parse errors.
This will make sure that the memory is freed in case of parse errors.
frontend: Fixed deprecated %name-prefix syntax.
frontend: FETCH, LIST, LOOKUP are untyped tokens.
core: Don't leak memory upon an error in the collector loop.
core: Don't leak memory when shutting down the collector loop.
Instead, put the current collector object back into the list in oder to keep a
reference to it.
Instead, put the current collector object back into the list in oder to keep a
reference to it.
connection_test: Added a simple test for sdb_connection_accept().
connection_test: Added first test for frontend connection handling.
For now, testing a simple session startup.
For now, testing a simple session startup.
frontend: Reset the current command length on CONNECTION_IDLE.
frontend: Clear the error buffer when initializing a new command.
utils strbuf: Don't copy more than needed in sdb_strbuf_skip().
strbuf_test: Added some more test-cases for sdb_strbuf_skip().
frontend: Always store errors in the error buffer.
This allows to access the error from other parts of the code.
This allows to access the error from other parts of the code.
frontend: Always reset the current command after handling it.
That is, also reset it after an authentication error.
That is, also reset it after an authentication error.
frontend: Clear current command on authentication error.
store_lookup_test: Dereference objects returned from the store.
parser: Don't leak memory when building nested matchers.
backends: Destroy dbi/unixsock clients on shutdown.
This would also be cleaned up when destroying the registered user data objects
but doing so on shutdown in much cleaner.
This would also be cleaned up when destroying the registered user data objects
but doing so on shutdown in much cleaner.
store: Free old attribute values before storing an updated value.
collectd::unixsock plugin: Free temporarily allocated memory.
frontend: Free strdup()'ed username when destroying a connection.
sysdbd: Free up the config item returned from the parser as well.
oconfig_free() does not do that because it does not correctly keep track of
what the top-level config item is and it cannot free items which are the child
of another.
oconfig_free() does not do that because it does not correctly keep track of
what the top-level config item is and it cannot free items which are the child
of another.
sysdbd: Shut down all plugins before exiting.
plugin: Added sdb_plugin_shutdown_all().
This function calls all registered "shutdown" callbacks.
This function calls all registered "shutdown" callbacks.
Make clang-analyze happy in two irrelevant cases.
sysdbd: Keep connections open during reconfiguration.
By using the new sdb_fe_sock_clear_listeners(), the list of active listeners
may be reconfigured without affecting any open connections.
By using the new sdb_fe_sock_clear_listeners(), the list of active listeners
may be reconfigured without affecting any open connections.
frontend: Added sdb_fe_sock_clear_listeners().
This function may be used to shut down and clear all listeners associated with
a socket object without affecting any open connections.
This function may be used to shut down and clear all listeners associated with
a socket object without affecting any open connections.
sysdbd: Free the config parse tree after finishing config work.
sysdbd: Reconfigure the daemon on SIGHUP.
The current approach shuts down the backend collector thread and the frontend.
Then, the config file is parsed again and libsysdb's reconfiguration mechanism
is used to reconfigure all plugins.
The current approach shuts down the backend collector thread and the frontend.
Then, the config file is parsed again and libsysdb's reconfiguration mechanism
is used to reconfigure all plugins.
sysdbd: Added daemon_free_listen_addresses().
This is a helper function for handling config settings.
This is a helper function for handling config settings.
Make all plugins ready for reconfiguration support.
That is, handle NULL arguments passed to the config and module init functions
during reconfiguration.
That is, handle NULL arguments passed to the config and module init functions
during reconfiguration.
plugin: Added support for reconfiguring the system on the fly.
Reconfiguring all plugins happens in multiple steps:
First, call sdb_plugin_reconfigure_init() to deconfigure all plugins by
calling their config callbacks with a NULL config tree and unregistering all
registered callbacks.
Then, sdb_plugin_configure() and other functions may be used to provide the
new configuration or load new plugins. For all plugins which were already
loaded before, sdb_module_init() will be called with a NULL argument when
reloading them.
Finally, sdb_plugin_reconfigure_finish() will clean up leftover pieces, like
unloading plugins which are no longer in use.
Reconfiguring all plugins happens in multiple steps:
First, call sdb_plugin_reconfigure_init() to deconfigure all plugins by
calling their config callbacks with a NULL config tree and unregistering all
registered callbacks.
Then, sdb_plugin_configure() and other functions may be used to provide the
new configuration or load new plugins. For all plugins which were already
loaded before, sdb_module_init() will be called with a NULL argument when
reloading them.
Finally, sdb_plugin_reconfigure_finish() will clean up leftover pieces, like
unloading plugins which are no longer in use.
utils llist: Added sdb_llist_clear().
This function clears the list by removing all elements and releasing the
included objects. It's similar to destroy() but does not actually release the
list object itself.
This function clears the list by removing all elements and releasing the
included objects. It's similar to destroy() but does not actually release the
list object itself.
utils llist: Removed sdb_ prefix from private functions.
For consistency!
For consistency!
plugin: Do not expect all callbacks to have a plugin context assigned.
For callbacks not registered from a plugin, we don't have a context. For
example, the frontend's connection logger callback does not have a context.
For callbacks not registered from a plugin, we don't have a context. For
example, the frontend's connection logger callback does not have a context.
plugin: Unset the plugin context before unregistering a plugin.
Else, the context is still considered to be in use and, thus, won't be removed
from the global plugin (context) list.
Else, the context is still considered to be in use and, thus, won't be removed
from the global plugin (context) list.
plugin: Log to stderr if no logger has been registered.
Check the length of the list rather than replying on it being uninitialized.
Check the length of the list rather than replying on it being uninitialized.
plugin: Let ctx_create() use ctx_set().
This ensures consistent handling of reference counts.
This ensures consistent handling of reference counts.
plugin: Split sdb_plugin_load() into multiple functions.
… to make it easier to reuse parts of the function.
… to make it easier to reuse parts of the function.
plugin: Fixed detection of plugins loaded twice.
This was missing in commit fdfe2a68ba1838cdb1c34d3275d129fb217fbd9d.
This was missing in commit fdfe2a68ba1838cdb1c34d3275d129fb217fbd9d.
plugin: Keep a global reference of a plugin context if it's still in use.
D'oh!
D'oh!
plugin: Increment ref-count for a context stored in the TSD.
… and release it when removing it from the TSD. While this shouldn't matter
when everything is done right, this ensures that memory management is done
right.
… and release it when removing it from the TSD. While this shouldn't matter
when everything is done right, this ensures that memory management is done
right.
plugin: Only log a message when actually unloading a module.
plugin: Unload (dlclose) a plugin when it's no longer used.
Do so, if the init callback failed.
Do so, if the init callback failed.
plugin: Name the plugin context after the actual module name.
That is, the name as specified by the user without '::' replaced by '/'.
The latter is only used for loading the shared object by file-name.
That is, the name as specified by the user without '::' replaced by '/'.
The latter is only used for loading the shared object by file-name.
sysdbd: Fixed a config parser error message.
plugin: Keep a usage counter for each plugin.
Also, let plugin_load return early if the plugin is already loaded.
This is mostly in preparation for future improvements around plugin handling.
Also, let plugin_load return early if the plugin is already loaded.
This is mostly in preparation for future improvements around plugin handling.
sysdbd: Moved main loop handling into a separate function.
This will allow for easier restart of the main loop.
This will allow for easier restart of the main loop.
llist_test: Removed "llist" from all test names.
No need to use overly long names.
No need to use overly long names.
llist utils: Added sdb_llist_remove_by_name().
This function removes the first entry with the specified name.
This function removes the first entry with the specified name.
llist_test: Removed "sdb" from test names.
frontend: Force-close the connection in sdb_connection_close().
Previously, it would still be kept open if someone else referenced the object.
Previously, it would still be kept open if someone else referenced the object.
Frontend: Improve debug log when destroying a connection.
The file-descriptor associated with the connection might not be open any more
and, thus, be -1. Instead of using that in the message, use the connection's
object name which includes the file-descriptor as used when accepting the
connection.
The file-descriptor associated with the connection might not be open any more
and, thus, be -1. Instead of using that in the message, use the connection's
object name which includes the file-descriptor as used when accepting the
connection.
frontend: Fixed a memory leak in the connection context handler.
Previously, the ownership was not taken away from the thread-specific data
aftter removing the connection from the current context, thus leaking each
connection object.
Previously, the ownership was not taken away from the thread-specific data
aftter removing the connection from the current context, thus leaking each
connection object.
Merged branch 'master' of git://git.tokkee.org/sysdb.
sysdbd: Ignore SIGPIPE (e.g. when a client connection was aborted).
frontend: Be more robust in case of failed connections.
Make sure not to write to a failed connection, most notably, don't try to log
to a failed connection.
Make sure not to write to a failed connection, most notably, don't try to log
to a failed connection.
frontend: Close a connection when receiving an exception of the fd.
sysdb: Added support for the -c <cmd> option.
This option (which may be specified multiple times) may be used to send
commands to the server in a non-interactive way. After handling the reply from
the last command, the process exits.
This option (which may be specified multiple times) may be used to send
commands to the server in a non-interactive way. After handling the reply from
the last command, the process exits.
sock.h: Fixed documentation of sdb_client_send() return values.
core: Allow objects to have the same size as sdb_object_t.
That is, allow minimalistic objects which only have a name.
That is, allow minimalistic objects which only have a name.
sysdb: Let sdb_command_print_reply() accept client instead of input objects.
This is more flexible.
This is more flexible.
Travis: Only run coveralls when using gcc.
We don't have any gcov information in any other case.
We don't have any gcov information in any other case.
Travis: Don't use 'coveralls --verbose'.
coveralls reports work fine now, so we don't need this anymore.
coveralls reports work fine now, so we don't need this anymore.
README: Added links to travis-ci and coveralls.
sysdbd(1): Fixed typo.
Added sysdb(1) manpage and updated sysdb help output.
Travis: Don't use --use-mirrors with pip.
It's been deprecated and I think we don't need it ;-)
It's been deprecated and I think we don't need it ;-)
Travis; Pass --build-root to coveralls.
Else, it cannot find the right source files.
Else, it cannot find the right source files.
Travis: Display information about cpp-coveralls after installing it.
t/coverage.sh: Restore t/cibuild.sh in the temp directory.
This is to avoid the version being marked as dirty.
This is to avoid the version being marked as dirty.
store_lookup_test: Added a more complex parser/lookup test.
store_lookup: Added "tostring" methods for matcher objects.
This is meant for logging and debugging. For now, it's used in tests to check
parsed and compiled matchers.
This is meant for logging and debugging. For now, it's used in tests to check
parsed and compiled matchers.
store_lookup_test: Fixed user-data passed to the lookup callback.
parser: Make sure that each comparator matcher is a host matcher.
So far, 'NOT (service|attribute).<attr> <cmp> <value>' matches did not work
correctly, because the object matcher was not correctly wrapped into a host
matcher. Since we do not currently support querying any object types besides
hosts, this was wrong.
The respective code has been moved into sdb_store_matcher_parse_cmp() which
also implements and checks the restriction on matching host objects only.
A new set of tests has been introduced which exposed this problem and which
(roughly) verifies the result of a lookup using a parsed matcher.
So far, 'NOT (service|attribute).<attr> <cmp> <value>' matches did not work
correctly, because the object matcher was not correctly wrapped into a host
matcher. Since we do not currently support querying any object types besides
hosts, this was wrong.
The respective code has been moved into sdb_store_matcher_parse_cmp() which
also implements and checks the restriction on matching host objects only.
A new set of tests has been introduced which exposed this problem and which
(roughly) verifies the result of a lookup using a parsed matcher.
frontend/parser_test: Cover more basic expressions.
plugin: Removed obsolete TODO note.
frontend: Actually implement support for the NOT operator.
core, frontend: Added !=, !~, and NOT operators.
![[tokkee]](http://tokkee.org/images/avatar.png)
