/*
SSSD
System Database
Copyright (C) Stephen Gallagher <sgallagh@redhat.com> 2009
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <stdlib.h>
#include <check.h>
#include <talloc.h>
#include <tevent.h>
#include <ctype.h>
#include <popt.h>
#include "util/crypto/sss_crypto.h"
#include "db/sysdb_private.h"
#include "db/sysdb_services.h"
#include "db/sysdb_autofs.h"
struct sysdb_test_ctx {
};
{
char *conf_db;
int ret;
/* Create tests directory if it doesn't exist */
/* (relative to current dir) */
return EFAULT;
}
fail("Could not allocate memory for test context");
return ENOMEM;
}
/* Create an event context
* It will not be used except in confdb_init and sysdb_init
*/
fail("Could not create event context");
return EIO;
}
fail("Out of memory, aborting!");
return ENOMEM;
}
/* Connect to the conf db */
fail("Could not initialize connection to the confdb");
return ret;
}
val[0] = "LOCAL";
fail("Could not initialize domains placeholder");
return ret;
}
val[0] = "local";
fail("Could not initialize provider");
return ret;
}
fail("Could not initialize LOCAL domain");
return ret;
}
val[0] = "TRUE";
fail("Could not initialize LOCAL domain");
return ret;
}
return ret;
}
return EOK;
}
{
}
{
fail("NULL pointer leaked memory, was %zu, is %zu\n",
}
}
struct test_data {
const char *netgrname;
const char *autofsmapname;
const char *shell;
const char *orig_dn;
const char *sid_str;
bool finished;
int error;
const char **attrlist;
char **ghostlist;
};
{
return NULL;
}
return NULL;
}
return data;
}
struct sss_domain_info *dom,
const char *fmt,
...)
{
char *shortname;
char *fqname;
return NULL;
}
return NULL;
}
return fqname;
}
{
return NULL;
}
"testuser%d", uid);
return NULL;
}
return data;
}
{
return NULL;
}
"testgroup%d", gid);
return NULL;
}
return data;
}
{
char *homedir;
char *gecos;
int ret;
return ENOMEM;
}
return ENOMEM;
}
return ret;
}
{
char *homedir;
char *gecos;
int ret;
return ret;
}
{
int ret;
return EOK;
}
{
int ret;
return ret;
}
{
int ret;
return ret;
}
{
int ret;
return ret;
}
{
int ret;
return ret;
}
{
int ret;
return EOK;
}
{
int ret;
return ret;
}
{
int ret;
return ret;
}
{
int ret;
SYSDB_MEMBER_USER, false);
return ret;
}
{
int ret;
SYSDB_MEMBER_USER, false);
/* assert the member was removed */
return E2BIG;
}
return ret;
}
{
char *object_name;
int ret;
if (!object_name) {
return ENOMEM;
}
return ret;
}
{
int ret;
return ret;
}
{
int ret;
"LOCAL");
return ENOMEM;
}
return ret;
}
{
int ret;
"LOCAL");
if (!dn) {
return ENOMEM;
}
return ret;
}
{
int ret;
char *member;
int i;
if (!member) {
return ENOMEM;
}
return ret;
}
}
return test_store_group(data);
}
{
int ret;
char *member;
int i;
if (!attrs) {
return ENOMEM;
}
if (!member) {
return ENOMEM;
}
return ret;
}
}
return ret;
}
}
return ret;
}
{
const char *description;
int ret;
return ret;
}
{
int ret;
if (!netgroup_dn) return ENOMEM;
return ret;
}
{
int ret;
return ret;
}
{
int ret;
const char *description;
if (!attrs) {
return ENOMEM;
}
if (ret) {
return ret;
}
return ret;
}
{
int ret;
return NULL;
}
return res;
}
{
int ret;
return NULL;
}
return res;
}
{
int ret;
const char *fqname;
const char *desc;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
char *member_fqname;
int j;
/* Setup */
fail("Could not set up the test");
return;
}
for (j = MBO_GROUP_BASE; j < _i; j++) {
"testghost%d", j);
}
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
fail("Could not set up the test");
return;
}
20000, NULL,
"S-1-5-21-123-456-789-111",
NULL, true, 0);
"sysdb_add_incomplete_group error [%d][%s]",
/* Adding a group with the same GID and all the other characteristics uknown should fail */
/* A different SID should also trigger a failure */
20000, NULL,
"S-1-5-21-123-456-789-222",
NULL, true, 0);
/* But if we know based on a SID that the group is in fact the same,
* let's just change its name
*/
20000, NULL,
"S-1-5-21-123-456-789-111",
NULL, true, 0);
"Did not catch a legitimate rename",
}
{
int ret;
const char *username;
/* Setup */
fail("Could not set up the test");
return;
}
/* Check the user was found with the expected FQDN and UID */
/* Search for the user with the wrong case */
"TESTUSER%d", _i);
}
{
int ret;
const char *groupname;
/* Setup */
fail("Could not set up the test");
return;
}
NULL,
&msg);
}
{
const char *groupname;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Did not find the expected GID (found %d expected %d)",
/* Search for the group with the wrong case */
"TESTGROUP%d", _i);
}
{
const char *fqname;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (ret) {
fail("sysdb_getgrgid failed for gid %d (%d: %s)",
goto done;
}
"Did not find the expected groupname (found %s expected %s)",
done:
}
{
int ret;
char *filter;
/* Setup */
}
{
const char *fqname;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (ret) {
fail("sysdb_getpwuid failed for uid %d (%d: %s)",
goto done;
}
"Did not find the expected username (found %s expected %s)",
done:
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
&res);
"sysdb_enumgrent failed (%d: %s)",
/* 10 groups + 10 users (we're MPG) */
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
&res);
"sysdb_enumpwent failed (%d: %s)",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
fail("Could not create the changeset");
return;
}
fail("Could not create the changeset");
return;
}
}
{
int ret;
char *filter;
/* Setup */
_i);
}
{
int ret;
const char *shell;
}
{
const char *attrval;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
&res);
if (ret) {
goto done;
}
done:
}
{
const char *attrval;
const char *fq_name;
int ret;
/* Setup */
/* Create subdomain */
"(((?P<domain>[^\\\\]+)\\\\(?P<name>.+$))|" \
"((?P<name>[^@]+)@(?P<domain>.+$))|" \
"(^(?P<name>[^@\\\\]+)$))",
/* Create user */
-1, 0);
/* Test */
}
{
NULL };
const char *attrval;
const char *fq_name;
int ret;
/* Setup */
/* Create user */
/* Test */
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
&res);
/* result should contain 2 messages - user and his group */
/* check if it's the expected user and expected group */
"Did not find the expected UID (found %d expected %d)",
"Wrong username\n");
"Did not find the expected GID (found %d expected %d)",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
fail("Could not create attribute list");
return;
}
fail("Could not add attribute");
return;
}
}
{
int ret;
char *object_name;
/* Setup */
fail("Could not set up the test");
return;
}
&data->msgs_count,
"Wrong number of objects, expected [1] got [%d]",
data->msgs_count);
"Wrong number of results, expected [1] got [%d]",
"Wrong attribute name");
"Wrong number of attribute values");
"Wrong attribute value");
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
fail("Could not create attribute list");
return;
}
fail("Could not add attribute");
return;
}
fail("Could not add attribute");
return;
}
}
{
int ret;
char *object_name;
/* Setup */
fail("Could not set up the test");
return;
}
&data->msgs_count,
"Wrong number of objects, expected [1] got [%d]",
data->msgs_count);
"Wrong number of results, expected [2] got [%d]",
"Wrong attribute value");
"Wrong attribute value");
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
&data->msgs_count,
"Wrong number of objects, expected [10] got [%d]",
data->msgs_count);
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
}
{
int ret;
NULL };
int val;
/* Setup */
"Unexpected authtok type, found [%d], expected [%d].",
"Unexpected authtok type, found [%d], expected [%d].",
"Unexpected second factor length, found [%d], expected [%d].",
val, 12);
}
const char *password,
int expected_result)
{
int ret;
/* Setup */
val[0] = "0";
fail("Could not initialize provider");
return;
}
&expire_date, &delayed_until);
"return expected result [%d].",
0, expire_date);
-1, delayed_until);
}
const char *password,
int expected_result)
{
int ret;
/* Setup */
val[0] = "1";
fail("Could not initialize provider");
return;
}
"Setting SYSDB_LAST_ONLINE_AUTH to [%lld].\n", (long long) now);
&expire_date, &delayed_until);
"sysdb_cache_auth request does not return expected "
"Wrong expire date, expected [%d], got [%d]",
-1, delayed_until);
}
{
}
{
}
{
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
int i;
char *gid_str;
/* Setup */
fail("Could not set up the test");
return;
}
"found [%d] expected [10]", msgs_count);
for (i = 0; i < msgs_count; i++) {
"found [%d] expected [1]",
msgs[i]->num_elements);
"wrong number of values, found [%d] expected [1]",
"wrong value, found [%.*s] expected [%s]",
}
}
{
int ret;
int i;
int j;
/* Setup */
fail("Could not set up the test");
return;
}
"wrong number of results, found [%d] expected [10]",
data->msgs_count);
for (i = 0; i < data->msgs_count; i++) {
"wrong number of elements, found [%d] expected [1]",
"wrong number of values, found [%d] expected [1]",
for (j = 0; j < data->msgs_count; j++) {
break;
}
}
"wrong value, found [%.*s] expected [%s]",
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
"sysdb_attrs_replace overwrites existing attribute");
"Wrong number of values for attribute oof, "
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (_i == 0) {
} else {
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
} else {
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (_i == 0) {
} else {
}
}
{
char *ghostname;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"testghost%d", _i);
/* Before the add, the groups should not contain the ghost attribute */
/* The first group would have the ghost attribute gone completely */
"Ghost user %s unexpectedly found\n", ghostname);
} else {
}
}
/* Perform the add operation */
/* Before the delete, all groups with gid >= _i have the testuser%_i
* as a member
*/
}
}
{
char *ghostname_del;
char *ghostname_add;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* The test replaces the testuser%i attribute with testghost%i */
"testuser%d", _i);
"testuser%d", _i);
/* Before the replace, all groups with gid >= _i have the testuser%_i
* as a member
*/
}
/* Perform the replace operation */
/* After the replace, all groups with gid >= _i have the testghost%_i
* as a member
*/
}
}
{
char *ghostname_rep;
char *ghostname_del;
char *ghostname_check;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* The test replaces the attributes (testusera$gid, testuserb$gid) with
* just testusera$gid. The result should be not only testusera, but also
* all ghost users inherited from child groups
*/
/* Before the replace, all groups with gid >= _i have both testuser a
* and testuserb as a member
*/
/* inherited users must be there */
"testusera%d", iteruid);
/* Also check the B user if it hasn't been deleted yet */
"testuserb%d", iteruid);
}
}
}
/* Perform the replace operation */
/* After the replace, testusera should still be there, but we also need
* to keep ghost users inherited from other groups
*/
/* testusera must still be there */
/* testuserb must be gone */
/* inherited users must still be there */
"testusera%d", iteruid);
/* Also check the B user if it hasn't been deleted yet */
"testuserb%d", iteruid);
}
}
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (_i == 5) {
"sysdb_search_group_by_gid found "
"already deleted group");
} else {
"Wrong number of results, expected [1] got [%d]",
"Wrong attribute name");
"Wrong number of attribute values, "
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Wrong number of results, expected [1] got [%d]",
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Wrong number of results, expected [1] got [%d]",
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
if (_i == 5) {
"sysdb_search_group_by_gid_send found "
"already deleted group");
} else {
"Wrong number of results, expected [1] got [%d]",
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"Wrong attribute name");
/* Expect our own and our parent's */
"Wrong number of attribute values, expected [%d] got [%d]",
/* Remove the parent */
/* Check the parent again. The inherited ghost user should be gone. */
"Wrong attribute name");
/* Expect our own now only */
"Wrong number of attribute values, expected [%d] got [%d]",
}
{
char *ghostname;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* Before the delete, all groups with gid >= _i have the testuser%_i
* as a member
*/
}
/* Delete the attribute */
/* After the delete, we shouldn't be able to find the ghost attribute */
/* The first group would have the ghost attribute gone completely */
"Ghost user %s unexpectedly found\n", ghostname);
} else {
}
}
}
{
int ret, j;
char *expected;
/* Setup */
fail("Could not set up the test");
return;
}
if (_i > MBO_GROUP_BASE) {
/* After the previous test, the first group (gid == MBO_GROUP_BASE)
* has no ghost users. That's a legitimate test case we need to account
* for now.
*/
"Wrong number of results, expected [1] got [%d] for %d",
}
return;
}
"Wrong attribute name");
"Wrong number of attribute values, expected [%d] got [%d]",
for (j = MBO_GROUP_BASE; j < _i; j++) {
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
"testghost%d", _i);
}
{
int ret;
/* Explicitly disable enumeration during setup as converting the ghost
* users into real ones works only when enumeration is disabled
*/
fail("Could not set up the test");
return;
}
"Wrong number of results, expected [1] got [%d] for %d",
return;
}
}
if (exp_gh < 0) {
exp_gh = 0;
}
if (exp_gh) {
}
}
{
char *ghostname_del;
char *ghostname_add;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* The test replaces the testghost%i attribute with testuser%i */
/* Before the replace, the group has the testghost%_i as a member */
/* Perform the replace operation */
/* After the replace, the group has the testghost%_i as a member */
}
{
char *ghostname_del;
char *ghostname_add;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* The test replaces the testghost%i attribute with testuser%i */
/* Before the replace, the group has the testghost%_i as a member */
/* Perform the replace operation */
/* After the replace, the group has the testghost%_i as a member */
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
bool value;
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
/* attribute is not created yet */
&value);
"sysdb_get_bool returned %d:[%s], but ENOENT is expected",
/* add attribute */
attr_val, true);
/* successfully obtain attribute */
&value);
fail_unless(value == true);
/* use non-existing DN */
"non-existing domain");
&value);
"sysdb_get_bool returned %d:[%s], but ENOENT is expected",
/* free ctx */
}
{
char **list;
"test_attr", &list);
list[0]);
}
{
const char *str;
char *fq_alias;
char *realname;
"S-1-5-21-123-456-789-111");
"12345678-9012-3456-7890-123456789012");
/* Get real, uncanonicalized name as string */
"S-1-5-21-123-456-789-111", &str);
"12345678-9012-3456-7890-123456789012", &str);
}
{
const char *name;
char *fromname;
char *toname;
/* Setup */
/* Store and verify the first group */
goto done;
}
"Did not find the expected GID (found %llu expected %llu)",
"Did not find the expected name (found %s expected %s)",
/* Perform rename and check that GID is the same, but name changed */
goto done;
}
"Did not find the expected GID (found %llu expected %llu)",
"Did not find the expected GID (found %s expected %s)",
/* Verify the first name is gone */
done:
}
{
const char *name;
char *fromname;
char *toname;
/* Setup */
/* Store and verify the first user */
goto done;
}
"Did not find the expected UID (found %llu expected %llu)",
"Did not find the expected name (found %s expected %s)",
/* Perform rename and check that GID is the same, but name changed */
goto done;
}
"Did not find the expected UID (found %llu expected %llu)",
"Did not find the expected name (found %s expected %s)",
/* Verify the first name is gone */
done:
}
{
char **add_groups;
char **del_groups;
char *user_fqname;
const char *group_fqname;
const char *check_fqname;
/* Setup */
/* Add a user to two groups */
/* For later check */
(const char *const *)add_groups, NULL);
/* Remove a user from one group and add to another */
(const char *const *)add_groups,
(const char *const *)del_groups);
/* Remove a user from two groups */
NULL, (const char *const *)del_groups);
}
{
int ret;
char *parsed;
/* Setup */
fail("Could not set up the test");
return;
}
"Names don't match (got %s)", parsed);
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
const char *netgrname;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
const char *description;
const char *netgrname;
const char *attrval;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
const char *strdn;
"Malformed netgroup baseDN");
}
{
char *odd_username;
const char odd_username_orig_dn[] =
"\\2a\\28odd\\29\\5cuser,name,cn=users,dc=example,dc=com";
char *odd_groupname;
const char *received_user;
const char *received_group;
/* Setup */
fail("Could not set up the test");
return;
}
"*(odd\\*)\\group,name",
/* ===== Groups ===== */
/* Add */
/* Retrieve */
"Expected [%s], got [%s]",
/* ===== Users ===== */
/* Add */
10000, 10000,
"","","");
/* Retrieve */
"Expected [%s] got [%s]\n",
/* Add to the group */
SYSDB_MEMBER_USER, false);
"Expected [%s], got [%s]",
/* Attributes */
user_attrs, &res);
/* Delete User */
/* Delete non existing User */
/* Delete Group */
/* Add */
10000, 0,
"","","",
NULL, 5400, 0);
/* Delete User */
/* ===== Netgroups ===== */
/* Add */
odd_netgroupname, "No description",
/* Retrieve */
/* ===== Arbitrary Entries ===== */
}
{
const char *groupname;
const char *groupname_neg;
const char *received_group;
/* Setup */
fail("Could not set up the test");
return;
}
"test_group");
"non_existing_test_group");
/* Add */
/* Retrieve */
/* Empty filter */
NULL);
/* Non-empty filter */
/* Filter yielding no results */
"objectClass=nonExistingObjectClass");
/* Non-existing dn */
}
/* == SERVICE TESTS == */
bool by_name,
const char *primary_name,
int port,
const char **aliases,
const char **protocols)
{
unsigned int i, j;
bool matched;
const char *ret_name;
int ret_port;
if (by_name) {
/* Look up the service by name */
} else {
/* Look up the newly-added service by port */
&res);
}
/* Make sure the returned entry matches */
for (i = 0; i < el->num_values; i++) {
matched = false;
for (j = 0; aliases[j]; j++) {
matched = true;
}
}
}
for (i = 0; i < el->num_values; i++) {
matched = false;
for (j = 0; protocols[j]; j++) {
matched = true;
}
}
}
}
do { \
} while(0);
do { \
} while(0);
{
char *primary_name;
const char **aliases;
const char **protocols;
/* Setup */
NULL);
/* Search by name and make sure the results match */
/* Search by port and make sure the results match */
/* Clean up after ourselves (and test deleting by name)
*
* We have to do this after the transaction, because LDB
* doesn't like adding and deleting the same entry in a
* single transaction.
*/
}
{
const char **aliases;
const char **protocols;
/* Setup */
/* Store this group (which will add it) */
/* Search by name and make sure the results match */
/* Search by port and make sure the results match */
/* Change the service name */
/* Search by port and make sure the results match */
/* Change it back */
/* Change the port number */
/* Search by name and make sure the results match */
/* Search by port and make sure the results match */
/* TODO: Test changing aliases and protocols */
/* Clean up after ourselves (and test deleting by port)
*
* We have to do this after the transaction, because LDB
* doesn't like adding and deleting the same entry in a
* single transaction.
*/
}
const char *alias);
{
const char **aliases;
const char **protocols;
/* Setup */
NULL);
/* Search by name and make sure the results match */
/* Search by port and make sure the results match */
/* Now remove an alias */
/* Set aliases[1] to NULL to perform validation checks */
/* Search by name and make sure the results match */
/* Search by port and make sure the results match */
}
{
int ret;
const char *str;
"Unexpected value, expected [%s], got [%s]",
/* Add the same value a second time, it is not recommended to do this on
* purpose but the test should illustrate the different to
* sysdb_attrs_add_lc_name_alias_safe(). */
"Unexpected value, expected [%s], got [%s]",
"Unexpected value, expected [%s], got [%s]",
}
{
int ret;
const char *str;
"Unexpected value, expected [%s], got [%s]",
/* Adding the same value a second time should be ignored */
"Unexpected value, expected [%s], got [%s]",
/* Adding different value */
"2nd_" LC_NAME_ALIAS_TEST_VAL);
"Unexpected value, expected [%s], got [%s]",
"Unexpected value, expected [%s], got [%s]",
}
{
int ret;
const char **list;
/* This test relies on values keeping the same order. It is the case
* with LDB, but if we ever switch from LDB, we need to amend the test
*/
}
{
int ret;
sizeof(TEST_ATTR_VALUE) - 1};
"Unexpected attribute name.");
"Unexpected number of attribute values.");
TEST_ATTR_VALUE) == 0,
"Unexpected attribute value.");
TEST_ATTR_VALUE) == 0,
"Unexpected attribute value.");
}
{
int ret;
sizeof(TEST_ATTR_VALUE) - 1};
"Unexpected attribute name.");
"Unexpected number of attribute values.");
TEST_ATTR_VALUE) == 0,
"Unexpected attribute value.");
}
{
int ret;
"Unexpected attribute name.");
"Unexpected number of attribute values.");
TEST_ATTR_VALUE) == 0,
"Unexpected attribute value.");
}
{
int ret;
const char *val;
const char **array;
/* Make sure the same entry is not copied twice */
/* Add new value to existing attribute */
"Wrong attribute value.");
"Wrong attribute value.");
/* Add new attribute */
"Wrong attribute value.");
"Wrong attribute value.");
}
{
int ret;
/* Setup */
/* id mapping */
/* Search user */
/* General search */
/* SSS_LDB_SEARCH */
/* Search group */
/* Search netgroup */
&res);
/* Search object */
/* Search can return more results */
/* Search custom */
"(distinguishedName=nonexisting)",
"nonexisting",
/* TODO: test sysdb_search_selinux_config */
}
{
bool enumerated;
/* Setup */
"Error [%d][%s] checking enumeration ENOENT is expected",
/* Recheck enumeration status */
}
{
const char *filter;
char *c;
/* Setup */
"case_sensitive_group1");
/* different name and GID, original DN differs only by case */
"case_sensitive_group2");
while(*c != '\0') {
*c = toupper(*c);
c++;
}
/* Search by originalDN should yield 2 entries */
"case insensitive originalDN search");
}
{
/* Setup */
"sysdb_search_groups_by_orign_dn search");
}
{
/* Setup */
"sysdb_search_users_by_orign_dn search");
}
{
/* Setup */
/* Delete the group by SID */
/* Verify it's gone */
"sysdb_search_group_by_sid_str failed with [%d][%s].",
}
{
/* Setup */
/* test for missing entry */
&res);
/* test user search */
&res);
"sysdb_search_object_by_id failed with [%d][%s].",
/* test group search */
&res);
"sysdb_search_object_by_id failed with [%d][%s].",
/* test for bad search filter bug #3283 */
&res);
"sysdb_search_object_by_id failed with [%d][%s].",
}
{
const char *uuid;
/* Setup */
uuid = "11111111-2222-3333-4444-555555555555";
"11111111-2222-3333-4444-555555555556",
"Unexpected return code from sysdb_search_object_by_uuid for "
SYSDB_NAME, ""),
"expected [%s], got [%s].", "UUIDuser",
}
{
const char *returned_name;
/* Setup */
/* test for missing entry */
/* test user search */
"sysdb_search_object_by_name failed with [%d][%s].",
"Unexpected object found, expected [%s], got [%s].",
/* test group search */
"sysdb_search_object_by_name failed with [%d][%s].",
"Unexpected object found, expected [%s], got [%s].",
/* test case insensitive search */
"sysdb_search_object_by_name failed with [%d][%s].",
"Unexpected object found, expected [%s], got [%s].",
}
/* For simple searches the content of the certificate does not matter */
{
const char *name;
const char *name2;
/* Setup */
"Unexpected return code from sysdb_search_user_by_cert for "
SYSDB_NAME, ""),
/* Add a second user with the same certificate */
"Unexpected names found, expected [%s,%s], got [%s,%s].",
}
{
/* Setup */
/* Delete the group by SID */
"S-1-2-3-4-NON_EXISTING_SID");
}
{
char *alias;
"/home/subdomuser", "/bin/bash",
"expected [%d], got [%d]",
"Unexpected DN returned");
/* Subdomains are case-insensitive. Test that the lowercased name
* can be found, too */
"expected [%d], got [%d]",
}
{
const char *name;
char *short_check;
char *dom_check;
"/home/subdomuser", "/bin/bash",
&msg);
"Unexpected DN returned");
"Unexpected DN returned");
}
{
char *alias;
const char *name;
char *short_check;
char *dom_check;
&msg);
"Unexpected DN returned");
/* subdomains are case insensitive, so it should be possible to search
the group with a lowercase name version, too */
/* Fixme - lowercase this */
&msg);
"Unexpected DN returned");
"Unexpected DN returned");
}
#ifdef BUILD_AUTOFS
{
const char *autofsmapname;
autofsmapname, NULL, 0, 0);
}
{
const char *autofsmapname;
autofsmapname, &map);
}
{
const char *autofsmapname;
}
{
const char *autofsmapname;
autofsmapname, &map);
}
{
const char *autofsmapname;
const char *autofskey;
const char *autofsval;
int ii;
autofsmapname, ii);
}
}
{
const char *autofsmapname;
}
{
const char *autofsmapname;
const char *autofskey;
const char *autofsval;
}
{
const char *autofskey;
NULL };
const char *filter;
}
#endif /* BUILD_AUTOFS */
{
char *conf_db;
int ret;
/* Create tests directory if it doesn't exist */
/* (relative to current dir) */
return NULL;
}
/* Make sure the test domain does not interfere with our testing */
return NULL;
}
/* Connect to the conf db */
return confdb;
}
{
int ret;
char **names;
/* No domain */
}
{
int ret;
char **names;
/* One domain */
val[0] = "LOCAL";
val[0] = "local";
}
{
int ret;
const char *str;
/* Setup */
fail("Could not set up the test");
return;
}
UPN_USER_NAME, "x",
"sysdb_search_user_by_upn failed with non-existing UPN.");
/* check if input is sanitized */
"sysdb_search_user_by_upn failed with un-sanitized input.");
}
{
int ret;
const char *str;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
const char *str;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
const char *str;
/* Setup */
fail("Could not set up the test");
return;
}
}
{
int ret;
const char *str;
/* Setup */
fail("Could not set up the test");
return;
}
"sysdb_search_user_by_upn failed for duplicated UPN.");
}
{
const char *guid;
int version;
&result);
}
{
const char *guid;
int version;
/* Modify the version */
}
{
/* No result in cache */
/* Delete with no result object is a noop */
/* Store an allow value, triggering a new result object */
allow_key, "allow_val1");
/* Now both searches should succeed, but only allow_key should return
* a valid value
*/
/* Updating replaces the original value */
allow_key, "allow_val2");
/* NULL removes the value completely */
/* Delete the result */
/* No result in cache */
}
{
int ret;
char **names;
/* Two domains */
val[0] = "LOCAL";
val[0] = "local";
val[0] = "REMOTE";
val[0] = "local";
}
{
char *filter;
/* Add something to database to test against */
/* Expire entry */
/* Try to expire already expired entry. Should return EOK. */
}
{
/* test getting next id works */
/* Add a user with an automatic ID */
/* Create a new user */
/* Verify the users were added */
/* Since this is a local (mpg) domain, verify the user groups
* can be found. Regression test for ticket #3615
*/
/* Create a new group */
/* Verify the groups were added */
/* sysdb_group_dn_name returns the name of the group in question */
/* sysdb_store_user allows setting attributes for existing users */
/* test the change */
/* Add and remove users in a group with sysdb_update_members */
/* Remove the other half by gid */
28000, 28010);
/* Remove the other half by uid */
27000, 27010);
/* Create a new user */
/* Verify the users were added */
/* Verify the users can be queried by UID */
/* Enumerate the users */
/* Change their attribute */
/* Find the users by their new attribute */
/* Verify the change */
/* Remove the attribute */
/* Create a new group */
/* Verify the groups were added */
/* Verify the groups can be queried by GID */
/* Find the users by GID using a filter */
/* Enumerate the groups */
/* Add some members to the groups */
/* Test that sysdb_initgroups() works */
/* Authenticate with missing cached password */
27010, 27011);
/* Add a cached password */
/* Authenticate against cached password */
27010, 27011);
/* ASQ search test */
/* Test search with more than one result */
/* Remove the members from the groups */
/* Remove the users by name */
/* Remove the groups by name */
/* test the ignore_not_found parameter for users */
/* test the ignore_not_found parameter for groups */
/* Create incomplete groups - remove will fail if the LDB objects
* don't exist
*/
28000, 28010);
28000, 28010);
/* test custom operations */
/* test recursive delete */
/* Test unusual characters */
/* Test sysdb enumerated flag */
/* Test originalDN searches */
/* Test sysdb_search_groups_by_orig_dn */
/* Test sysdb_search_users_by_orig_dn */
/* Test SID string searches */
/* Test object by ID searches */
/* Test UUID string searches */
/* Test object by name */
/* Test user by certificate searches */
/* Test canonicalizing names */
/* Test user and group renames */
/* Test GetUserAttr with subdomain user */
/* Test adding a non-POSIX user */
/* ===== NETGROUP TESTS ===== */
/* Create a new netgroup */
/* Verify the netgroups were added */
/* Test setting attributes */
/* Verify they have been changed */
/* Remove half of them by name */
/* Remove the other half by DN */
/* ===== SERVICE TESTS ===== */
/* Create a new service */
/* ===== UTIL TESTS ===== */
/* ===== Test search return empty result ===== */
/* ===== Misc ===== */
/* Add all test cases to the test suite */
suite_add_tcase(s, tc_sysdb);
0, 10);
0, 10);
0, 10);
0, 10);
0, 10);
0, 10);
/* Ghost users tests */
/* Only one group should be left now */
/* ghost users - RFC2307 */
/* Add groups with ghost users */
/* Check the ghost user attribute */
/* Add user entries, converting the ghost attributes to member attributes */
/* We only convert half of the users and keep the ghost attributes for the
* other half as we also want to test if we don't delete any ghost users
* by accident
*/
/* Check the members and ghosts are there as appropriate */
/* Rename the other half */
/* Attempt to replace with the same data to check if noop works correctly */
/* Remove the real users */
/* ghost users - memberof mod_del */
/* ghost users - memberof mod_add */
/* Add groups without ghosts first */
/* Add ghosts to groups so that they propagate */
/* Check if the ghosts in fact propagated */
/* Clean up */
/* ghost users - replace */
/* ghost users - replace but retain inherited */
/* SSS_LDB_SEARCH */
/* This loop counts backwards so the indexing is a little odd */
1 , 11);
#ifdef BUILD_AUTOFS
suite_add_tcase(s, tc_autofs);
#endif
suite_add_tcase(s, tc_upn);
suite_add_tcase(s, tc_gpo);
/* ConfDB tests -- modify confdb, must always be last!! */
suite_add_tcase(s, tc_confdb);
return s;
}
int opt;
int failure_count;
int no_cleanup = 0;
_("Do not delete the test database after a test run"), NULL },
};
/* Set debug level to invalid value so we can decide if -d 0 was used. */
switch(opt) {
default:
return 1;
}
}
if (!ldb_modules_path_is_set()) {
"will use LDB plugins installed in system paths.\n");
}
/* If CK_VERBOSITY is set, use that, otherwise it defaults to CK_NORMAL */
if (failure_count == 0 && !no_cleanup) {
}
}