summaryrefslogtreecommitdiff
path: root/server/tests
diff options
context:
space:
mode:
Diffstat (limited to 'server/tests')
-rw-r--r--server/tests/infopipe-privileged-tests.c615
-rw-r--r--server/tests/infopipe-tests.c405
2 files changed, 0 insertions, 1020 deletions
diff --git a/server/tests/infopipe-privileged-tests.c b/server/tests/infopipe-privileged-tests.c
deleted file mode 100644
index d5c40662..00000000
--- a/server/tests/infopipe-privileged-tests.c
+++ /dev/null
@@ -1,615 +0,0 @@
-/*
- SSSD
-
- InfoPipe
-
- Copyright (C) Jakub Hrozek <jhrozek@redhat.com> 2009
-
- This program is free software; you can redistribute it and/or modify
- 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 <popt.h>
-#include <dbus/dbus.h>
-#include "util/util.h"
-#include "confdb/confdb.h"
-#include "sbus/sssd_dbus.h"
-#include "infopipe/infopipe.h"
-#include "db/sysdb.h"
-
-#define INFP_TEST_DBUS_NAME "org.freedesktop.sssd.infopipe1.test"
-#define TEST_TIMEOUT 30000 /* 30 seconds */
-
-static int setup_infp_tests(DBusConnection **bus)
-{
- DBusError error;
- int ret;
-
- /* Connect to the system bus */
- dbus_error_init(&error);
- *bus = dbus_bus_get(DBUS_BUS_SYSTEM, &error);
- if (*bus == NULL) {
- fail("Could not connect to the system bus. %s:%s", error.name, error.message);
- dbus_error_free(&error);
- return EIO;
- }
-
- /* Abort the tests if disconnect occurs */
- dbus_connection_set_exit_on_disconnect(*bus, TRUE);
-
- ret = dbus_bus_request_name(*bus,
- INFP_TEST_DBUS_NAME,
- /* We want exclusive access */
- DBUS_NAME_FLAG_DO_NOT_QUEUE,
- &error);
- if (ret != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER) {
- /* We were unable to register on the system bus */
- fail("Unable to request name on the system bus. Error: %s:%s\n", error.name, error.message);
- dbus_error_free(&error);
- return EIO;
- }
- return EOK;
-}
-
-static int teardown_infp_tests(DBusConnection *bus)
-{
- dbus_connection_unref(bus);
- return EOK;
-}
-
-START_TEST(test_infp_users_delete)
-{
- DBusConnection *bus;
- DBusMessage *delete_req;
- DBusMessageIter iter;
- DBusError error;
- DBusMessage *reply;
- const char *username = "testuser1";
- const char *domain = "LOCAL";
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- delete_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_USERS_DELETE);
- if (!delete_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(delete_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &username);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- delete_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_users_set_uid)
-{
- DBusConnection *bus;
- DBusMessage *setuid_req;
- DBusMessageIter iter;
- DBusError error;
- DBusMessage *reply;
- const char *username = "testuser1";
- const char *domain = "LOCAL";
- u_int32_t new_id = 1666;
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- setuid_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_USERS_SET_UID);
- if (!setuid_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(setuid_req, &iter);
-
- dbus_message_iter_init_append(setuid_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &username);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_UINT32, &new_id);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- setuid_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_users_get_attr)
-{
- DBusConnection *bus;
- DBusMessage *get_attr_req;
- DBusMessageIter iter, user_iter, attr_iter;
- DBusError error;
- DBusMessage *reply;
- const char *username = "testuser1";
- const char *domain = "LOCAL";
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- get_attr_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_USERS_GET_ATTR);
- if (!get_attr_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(get_attr_req, &iter);
-
- /* append the username */
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "s",
- &user_iter); /* Array of usernames */
- dbus_message_iter_append_basic(&user_iter, DBUS_TYPE_STRING, &username);
- dbus_message_iter_close_container(&iter, &user_iter);
-
- /* append the domain */
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- /* no attributes specified means retrieve all possible */
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "s",
- &attr_iter); /* Array of attributes */
- dbus_message_iter_close_container(&iter, &attr_iter);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- get_attr_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* Retreive the result */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_users_create)
-{
- DBusConnection *bus;
- DBusMessage *create_req;
- const char *username = "testuser1";
- const char *fullname = "test create user";
- const char *domain = "LOCAL";
- const char *homedir = "/home/test_create_user";
- const char *shell = "/bin/sh";
- DBusMessageIter iter;
- DBusError error;
- DBusMessage *reply;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- create_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_USERS_CREATE);
- if (!create_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(create_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &username);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &fullname);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &homedir);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &shell);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- create_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_groups_create)
-{
- DBusConnection *bus;
- DBusMessage *create_req;
- const char *groupname = "testgroup1";
- const char *domain = "LOCAL";
- DBusMessageIter iter, group_iter;
- DBusError error;
- DBusMessage *reply;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- create_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_GROUPS_CREATE);
- if (!create_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(create_req, &iter);
-
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "s",
- &group_iter); /* Array of groupnames */
- dbus_message_iter_append_basic(&group_iter, DBUS_TYPE_STRING, &groupname);
- dbus_message_iter_close_container(&iter, &group_iter);
-
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- create_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_groups_set_gid)
-{
- DBusConnection *bus;
- DBusMessage *setgid_req;
- DBusMessageIter iter;
- DBusError error;
- DBusMessage *reply;
- const char *groupname = "testgroup1";
- const char *domain = "LOCAL";
- u_int32_t new_id = 1666;
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- setgid_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_GROUPS_SET_GID);
- if (!setgid_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(setgid_req, &iter);
-
- dbus_message_iter_init_append(setgid_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &groupname);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_UINT32, &new_id);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- setgid_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_groups_add_members)
-{
- DBusConnection *bus;
- DBusMessage *add_member_req;
- const char *groupname = "testgroup1";
- const char *membername = "testuser1";
- const char *domain = "LOCAL";
- DBusMessageIter iter, array_iter;
- DBusError error;
- DBusMessage *reply;
- int type;
- int membertype = 0;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- add_member_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_GROUPS_ADD_MEMBERS);
- if (!add_member_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- /* Add the parameters */
- dbus_message_iter_init_append(add_member_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &groupname);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "(ss)", /* Array of members */
- &array_iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &membername);
- dbus_message_iter_close_container(&iter, &array_iter);
-
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_BYTE, &membertype);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- add_member_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_groups_del_members)
-{
- DBusConnection *bus;
- DBusMessage *del_member_req;
- DBusError error;
- DBusMessage *reply;
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- del_member_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_GROUPS_REMOVE_MEMBERS);
- if (!del_member_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- del_member_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_groups_delete)
-{
- DBusConnection *bus;
- DBusMessage *delete_req;
- const char *groupname = "testgroup1";
- const char *domain = "LOCAL";
- DBusMessageIter iter;
- DBusError error;
- DBusMessage *reply;
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- delete_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_GROUPS_DELETE);
- if (!delete_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- dbus_message_iter_init_append(delete_req, &iter);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &groupname);
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- delete_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- /* assert that the reply is an empty return message */
- type = dbus_message_get_type(reply);
- fail_unless(type == DBUS_MESSAGE_TYPE_METHOD_RETURN,
- "Method call returned %d instead of METHOD_RETURN", type);
-
-done:
- teardown_infp_tests(bus);
-}
-END_TEST
-
-Suite *create_infopipe_suite(void)
-{
- Suite *s = suite_create("infopipe");
-
- TCase *tc_infp = tcase_create("InfoPipe Privileged Tests");
-
- /* Test user methods */
- tcase_add_test(tc_infp, test_infp_users_create);
- tcase_add_test(tc_infp, test_infp_users_set_uid);
- tcase_add_test(tc_infp, test_infp_users_get_attr);
-
- /* Test group methods */
- tcase_add_test(tc_infp, test_infp_groups_create);
- tcase_add_test(tc_infp, test_infp_groups_set_gid);
-
- /* Clean up */
- tcase_add_test(tc_infp, test_infp_users_delete);
- tcase_add_test(tc_infp, test_infp_groups_delete);
-
-/* Add all test cases to the test suite */
- suite_add_tcase(s, tc_infp);
-
- return s;
-}
-
-int main(int argc, const char *argv[]) {
- int opt;
- poptContext pc;
- int failure_count;
- Suite *infopipe_suite;
- SRunner *sr;
-
- struct poptOption long_options[] = {
- POPT_AUTOHELP
- SSSD_MAIN_OPTS
- { NULL }
- };
-
- pc = poptGetContext(argv[0], argc, argv, long_options, 0);
- while((opt = poptGetNextOpt(pc)) != -1) {
- switch(opt) {
- default:
- fprintf(stderr, "\nInvalid option %s: %s\n\n",
- poptBadOption(pc, 0), poptStrerror(opt));
- poptPrintUsage(pc, stderr, 0);
- return 1;
- }
- }
- poptFreeContext(pc);
-
- infopipe_suite = create_infopipe_suite();
- sr = srunner_create(infopipe_suite);
- srunner_run_all(sr, CK_VERBOSE);
- failure_count = srunner_ntests_failed(sr);
- srunner_free(sr);
- return (failure_count==0 ? EXIT_SUCCESS : EXIT_FAILURE);
-}
diff --git a/server/tests/infopipe-tests.c b/server/tests/infopipe-tests.c
deleted file mode 100644
index 171e58d4..00000000
--- a/server/tests/infopipe-tests.c
+++ /dev/null
@@ -1,405 +0,0 @@
-/*
- SSSD
-
- InfoPipe
-
- Copyright (C) Stephen Gallagher <sgallagh@redhat.com> 2009
-
- This program is free software; you can redistribute it and/or modify
- 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 <popt.h>
-#include <dbus/dbus.h>
-#include "util/util.h"
-#include "confdb/confdb.h"
-#include "sbus/sssd_dbus.h"
-#include "infopipe/infopipe.h"
-#include "db/sysdb.h"
-
-#define INFP_TEST_DBUS_NAME "org.freedesktop.sssd.infopipe1.test"
-#define TEST_TIMEOUT 30000 /* 30 seconds */
-
-static int setup_infp_tests(DBusConnection **bus)
-{
- DBusError error;
- int ret;
-
- /* Connect to the system bus */
- dbus_error_init(&error);
- *bus = dbus_bus_get(DBUS_BUS_SYSTEM, &error);
- if (*bus == NULL) {
- fail("Could not connect to the system bus. %s:%s", error.name, error.message);
- dbus_error_free(&error);
- return EIO;
- }
-
- /* Abort the tests if disconnect occurs */
- dbus_connection_set_exit_on_disconnect(*bus, TRUE);
-
- ret = dbus_bus_request_name(*bus,
- INFP_TEST_DBUS_NAME,
- /* We want exclusive access */
- DBUS_NAME_FLAG_DO_NOT_QUEUE,
- &error);
- if (ret != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER) {
- /* We were unable to register on the system bus */
- fail("Unable to request name on the system bus. Error: %s:%s\n", error.name, error.message);
- dbus_error_free(&error);
- return EIO;
- }
- return EOK;
-}
-
-static int teardown_infp_tests(DBusConnection *bus)
-{
- dbus_connection_unref(bus);
- return EOK;
-}
-
-#define INTROSPECT_CHUNK_SIZE 4096
-START_TEST(test_infp_introspect)
-{
- TALLOC_CTX *tmp_ctx;
- DBusConnection *bus;
- DBusError error;
- DBusMessage *introspect_req;
- DBusMessage *reply;
- FILE *xml_stream;
- char *chunk;
- char *introspect_xml;
- char *returned_xml;
- unsigned long xml_size;
- size_t chunk_size;
- int type;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- tmp_ctx = talloc_new(NULL);
- if (!tmp_ctx) {
- fail("Could not create temporary talloc context");
- goto done;
- }
-
- /* Create introspection method call */
- introspect_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- DBUS_INTROSPECT_INTERFACE,
- DBUS_INTROSPECT_METHOD);
- if(!introspect_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- introspect_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- type = dbus_message_get_type(reply);
- switch (type) {
- case DBUS_MESSAGE_TYPE_METHOD_RETURN:
- /* Read in the reference Introspection XML */
- xml_stream = fopen("introspect.ref", "r");
- if(xml_stream == NULL) {
- DEBUG(0, ("Could not open the introspection XML for reading: [%d].\n", errno));
- return;
- }
-
- chunk = talloc_size(tmp_ctx, INTROSPECT_CHUNK_SIZE);
- if (chunk == NULL) goto done;
-
- xml_size = 0;
- introspect_xml = NULL;
- do {
- chunk_size = fread(chunk, 1, INTROSPECT_CHUNK_SIZE, xml_stream);
- introspect_xml = talloc_realloc_size(tmp_ctx, introspect_xml, xml_size+chunk_size+1);
- if (introspect_xml == NULL) goto done;
-
- memcpy(introspect_xml+xml_size, chunk, chunk_size);
- xml_size += chunk_size;
- } while(chunk_size == INTROSPECT_CHUNK_SIZE);
- introspect_xml[xml_size] = '\0';
- talloc_free(chunk);
-
- /* Get the XML from the message */
- dbus_message_get_args(reply, &error,
- DBUS_TYPE_STRING, &returned_xml,
- DBUS_TYPE_INVALID);
-
- /* Verify that the reply matches the reference file */
- int c;
- if ((c = strcmp(introspect_xml, returned_xml)) != 0) {
- DEBUG(0, ("Verify Introspection XML: FAILED %d\nstrlen: %d, %d\n", c, strlen(introspect_xml), strlen(returned_xml)));
- fail("");//"Verify Introspection XML: FAILED %d\n %s\nstrlen: %d", c, returned_xml, strlen(returned_xml));
- }
- break;
- case DBUS_MESSAGE_TYPE_ERROR:
- fail("Error: %s\n", dbus_message_get_error_name(reply));
- goto done;
- }
-
-done:
- talloc_free(tmp_ctx);
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_check_permissions)
-{
- TALLOC_CTX *tmp_ctx;
- DBusConnection *bus;
- DBusError error;
- DBusMessage *permission_req;
- DBusMessage *reply;
- DBusMessageIter msg_iter;
- DBusMessageIter array_iter;
- DBusMessageIter struct_iter;
- dbus_bool_t *permission_array;
- int permission_count;
- char *domain;
- char *object;
- char *instance;
- char *action;
- char *attribute;
- int type, i;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- tmp_ctx = talloc_new(NULL);
- if (!tmp_ctx) {
- fail("Could not create temporary talloc context");
- goto done;
- }
-
- /* Create permission request message */
- permission_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_CHECK_PERMISSIONS);
- if(!permission_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- /* Add arguments */
- domain = talloc_strdup(tmp_ctx, "LOCAL");
- object = talloc_strdup(tmp_ctx, "user");
- instance = talloc_strdup(tmp_ctx, "testuser1");
- action = talloc_strdup(tmp_ctx, "modify");
- attribute = talloc_strdup(tmp_ctx, "userpic");
-
- dbus_message_append_args(permission_req,
- DBUS_TYPE_STRING, &domain,
- DBUS_TYPE_STRING, &object,
- DBUS_TYPE_STRING, &instance,
- DBUS_TYPE_INVALID);
-
- dbus_message_iter_init_append(permission_req, &msg_iter);
- dbus_message_iter_open_container(&msg_iter,
- DBUS_TYPE_ARRAY, "(ss)", /* Array of structs */
- &array_iter);
- dbus_message_iter_open_container(&array_iter,
- DBUS_TYPE_STRUCT, NULL,
- &struct_iter);
- dbus_message_iter_append_basic(&struct_iter, DBUS_TYPE_STRING, &action);
- dbus_message_iter_append_basic(&struct_iter, DBUS_TYPE_STRING, &attribute);
- dbus_message_iter_close_container(&array_iter, &struct_iter);
- dbus_message_iter_close_container(&msg_iter, &array_iter);
-
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- permission_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
- type = dbus_message_get_type(reply);
- switch (type) {
- case DBUS_MESSAGE_TYPE_ERROR:
- fail("Error: %s\n", dbus_message_get_error_name(reply));
- goto done;
- case DBUS_MESSAGE_TYPE_METHOD_RETURN:
- dbus_message_get_args(reply, &error,
- DBUS_TYPE_ARRAY, DBUS_TYPE_BOOLEAN, &permission_array, &permission_count,
- DBUS_TYPE_INVALID);
- }
-
- i = 0;
- while(i < permission_count) {
- if (permission_array[i] == true) {
- fail("User was granted permission unexpectedly");
- goto done;
- }
- i++;
- }
-
-done:
- talloc_free(tmp_ctx);
- teardown_infp_tests(bus);
-}
-END_TEST
-
-START_TEST(test_infp_set_user_attrs)
-{
- TALLOC_CTX *tmp_ctx;
- DBusConnection *bus;
- DBusMessage *setattr_req;
- const char *username = "testuser1";
- const char *domain = "LOCAL";
- const char *shell_attr = SYSDB_SHELL;
- const char *shell_value = "/usr/bin/testshell";
- DBusMessageIter iter, array_iter, dict_array_iter, dict_iter, variant_iter;
- DBusError error;
- DBusMessage *reply;
-
- if (setup_infp_tests(&bus) != EOK) {
- fail("Could not set up the tests");
- return;
- }
-
- tmp_ctx = talloc_new(NULL);
- if (!tmp_ctx) {
- fail("Could not create temporary talloc context");
- goto done;
- }
-
- setattr_req = dbus_message_new_method_call(INFOPIPE_DBUS_NAME,
- INFOPIPE_PATH,
- INFOPIPE_INTERFACE,
- INFP_USERS_SET_ATTR);
- if (!setattr_req) {
- fail("Could not create new method call message");
- goto done;
- }
-
- /* Usernames */
- dbus_message_iter_init_append(setattr_req, &iter);
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "s",
- &array_iter); /* Array of dict array of string->variant pairs */
- dbus_message_iter_append_basic(&array_iter, DBUS_TYPE_STRING, &username);
- dbus_message_iter_close_container(&iter, &array_iter);
-
- /* Domain */
- dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &domain);
-
- dbus_message_iter_open_container(&iter,
- DBUS_TYPE_ARRAY, "a{sv}",
- &array_iter); /* Array of dict array of string->variant pairs */
- dbus_message_iter_open_container(&array_iter,
- DBUS_TYPE_ARRAY, "{sv}",
- &dict_array_iter); /* Array of dict of string->variant pairs */
- dbus_message_iter_open_container(&dict_array_iter,
- DBUS_TYPE_DICT_ENTRY, NULL,
- &dict_iter); /* Dict entry of string->variant pair */
- dbus_message_iter_append_basic(&dict_iter, DBUS_TYPE_STRING, &shell_attr);
- dbus_message_iter_open_container(&dict_iter,
- DBUS_TYPE_VARIANT, "s",
- &variant_iter); /* Variant */
- dbus_message_iter_append_basic(&variant_iter, DBUS_TYPE_STRING, &shell_value);
- dbus_message_iter_close_container(&dict_iter, &variant_iter);
- dbus_message_iter_close_container(&dict_array_iter, &dict_iter);
- dbus_message_iter_close_container(&array_iter, &dict_array_iter);
- dbus_message_iter_close_container(&iter, &array_iter);
-
- /* Send the message */
- dbus_error_init(&error);
- reply = dbus_connection_send_with_reply_and_block(bus,
- setattr_req,
- TEST_TIMEOUT,
- &error);
- if(!reply) {
- fail("Could not send message. Error: %s:%s", error.name, error.message);
- dbus_error_free(&error);
- goto done;
- }
-
-done:
- talloc_free(tmp_ctx);
- teardown_infp_tests(bus);
-}
-END_TEST
-
-Suite *create_infopipe_suite(void)
-{
- Suite *s = suite_create("infopipe");
-
- TCase *tc_infp = tcase_create("InfoPipe Tests");
-
- /* Test the Introspection XML */
- tcase_add_test(tc_infp, test_infp_introspect);
- tcase_add_test(tc_infp, test_infp_check_permissions);
- tcase_add_test(tc_infp, test_infp_set_user_attrs);
-
-/* Add all test cases to the test suite */
- suite_add_tcase(s, tc_infp);
-
- return s;
-}
-
-int main(int argc, const char *argv[]) {
- int opt;
- poptContext pc;
- int failure_count;
- Suite *infopipe_suite;
- SRunner *sr;
-
- struct poptOption long_options[] = {
- POPT_AUTOHELP
- SSSD_MAIN_OPTS
- { NULL }
- };
-
- pc = poptGetContext(argv[0], argc, argv, long_options, 0);
- while((opt = poptGetNextOpt(pc)) != -1) {
- switch(opt) {
- default:
- fprintf(stderr, "\nInvalid option %s: %s\n\n",
- poptBadOption(pc, 0), poptStrerror(opt));
- poptPrintUsage(pc, stderr, 0);
- return 1;
- }
- }
- poptFreeContext(pc);
-
- infopipe_suite = create_infopipe_suite();
- sr = srunner_create(infopipe_suite);
- srunner_run_all(sr, CK_VERBOSE);
- failure_count = srunner_ntests_failed(sr);
- srunner_free(sr);
- return (failure_count==0 ? EXIT_SUCCESS : EXIT_FAILURE);
-}