From: Simon McVittie Date: Fri, 25 Jan 2019 11:49:56 +0000 (+0000) Subject: _dbus_test_main: Exercise NSS modules before running tests X-Git-Tag: dbus-1.13.10~17^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=02e3c4fdfa71cff414bd963866658733c8698074;p=thirdparty%2Fdbus.git _dbus_test_main: Exercise NSS modules before running tests Some NSS modules like those for sssd and LDAP might allocate fds on a one-per-process basis, for example a socket to talk to sssd. Make sure those have already been allocated before we enter the code under test, so that they don't show up as having been "leaked" by the first module of code under test that happens to do a NSS lookup. The call to _dbus_test_check_memleaks tears down libdbus' own memory allocations, but not any hidden state in libc or NSS. Signed-off-by: Simon McVittie --- diff --git a/test/test-utils.c b/test/test-utils.c index d36165042..51471db7c 100644 --- a/test/test-utils.c +++ b/test/test-utils.c @@ -519,6 +519,23 @@ _dbus_test_main (int argc, else specific_test = strdup0_or_die (_dbus_getenv ("DBUS_TEST_ONLY")); + /* Some NSS modules like those for sssd and LDAP might allocate fds + * on a one-per-process basis. Make sure those have already been + * allocated before we enter the code under test, so that they don't + * show up as having been "leaked" by the first module of code under + * test that happens to do a NSS lookup. */ + { + DBusString username; + dbus_uid_t ignored_uid = DBUS_UID_UNSET; + + _dbus_string_init_const (&username, "dbus-no-user-with-this-name"); + /* We use a username that almost certainly doesn't exist, because + * if we used something like root it might get handled early in the + * NSS search order, before we get as far as asking sssd or LDAP. */ + _dbus_parse_unix_user_from_config (&username, &ignored_uid); + _dbus_test_check_memleaks ("initial nss query"); + } + for (i = 0; i < n_tests; i++) { long before, after;