Blob Blame History Raw
/*
 * Lasso library C unit tests
 *
 * Copyright (C) 2004-2007 Entr'ouvert
 * http://lasso.entrouvert.org
 *
 * Authors: See AUTHORS file in top-level directory.
 *
 * 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 2 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 <string.h>
#include <config.h>
#include <stdio.h>

#include <check.h>
#include <glib.h>
#include <tests.h>
#include "../lasso/lasso.h"
#include "../lasso/lasso_config.h"

extern Suite* basic_suite();
extern Suite* login_suite();
extern Suite* login_saml2_suite();
extern Suite* random_suite();
extern Suite* metadata_suite();
extern Suite* assertion_query_suite();
extern Suite* non_regression_suite();
#ifdef LASSO_WSF_ENABLED
extern Suite* idwsf2_suite();
#endif

typedef Suite* (*SuiteFunction) ();

SuiteFunction suites[] = {
	basic_suite,
	login_suite,
	login_saml2_suite,
	random_suite,
	metadata_suite,
	assertion_query_suite,
	non_regression_suite,
#ifdef LASSO_WSF_ENABLED
	idwsf2_suite,
#endif
	NULL
};


void
mute_logger(G_GNUC_UNUSED const gchar *domain,
		G_GNUC_UNUSED GLogLevelFlags log_level, G_GNUC_UNUSED const gchar *message,
		G_GNUC_UNUSED gpointer user_data) {
}

int dontfork = 0;
int log_failed = 0;

void set_mute_logger() {
     g_log_set_default_handler(mute_logger, NULL);
     if (log_failed) {
         log_failed = 0;
         fail("There were logs, there should not");
     }
}

void
fail_logger(const gchar *log_domain G_GNUC_UNUSED, GLogLevelFlags log_level,
		const gchar *message G_GNUC_UNUSED, G_GNUC_UNUSED gpointer user_data)
{
	const char *level_name G_GNUC_UNUSED = NULL;

	if (strncmp(message, "libxmlsec", 9) == 0) {
		return;
	}

	switch (log_level) {
		case G_LOG_LEVEL_ERROR:
			level_name = "ERROR";
			break;
		case G_LOG_LEVEL_CRITICAL:
			level_name = "CRITICAL";
			break;
		case G_LOG_LEVEL_WARNING:
			level_name = "WARNING";
			break;
		case G_LOG_LEVEL_INFO:
			level_name = "INFO";
			break;
		case G_LOG_LEVEL_MESSAGE:
			level_name = "MESSAGE";
			break;
		case G_LOG_LEVEL_DEBUG:
			level_name = "DEBUG";
			break;
		default:
			g_assert_not_reached();
	}
        if (! dontfork) {
		fail("No logging output expected: message «%s» was emitted for domain «%s» at the level «%s»", message, log_domain, level_name);
	}
	printf("No logging output expected: message «%s» was emitted for domain «%s» at the level «%s»", message, log_domain, level_name);
        log_failed = 1;
        G_BREAKPOINT();
}

static xmlFreeFunc free_func;
static xmlMallocFunc malloc_func;
static xmlReallocFunc realloc_func;
static xmlStrdupFunc strdup_func;

void *
my_malloc(size_t size)
{
	void *ptr = malloc_func(size);
	if (! ptr) {
		fail("xmlMalloc failed");
	}
	return ptr;
}

void *
my_realloc(void *mem, size_t size)
{
	void *ptr = realloc_func(mem, size);
	if (! ptr) {
		fail("xmlRealloc failed");
	}
	return ptr;
}

void
setup_xml_mem_allocation()
{
	xmlMemGet(&free_func, &malloc_func, &realloc_func, &strdup_func);
	xmlMemSetup(free_func, my_malloc, my_realloc, strdup_func);
}

int
main(int argc, char *argv[])
{
	int rc = 0;
	SRunner *sr;
	int i;
	int dont_fork = 0;

	setup_xml_mem_allocation();
	for (i=1; i<argc; i++) {
		if (strcmp(argv[i], "--dontfork") == 0) {
			dont_fork = 1;
		}
	}

	lasso_init();
	unblock_lasso_logs;

	sr = srunner_create(suites[0]());

	i = 1;
	while (suites[i]) {
		srunner_add_suite(sr, suites[i]());
		i++;
	}

	if (dont_fork) {
		srunner_set_fork_status(sr, CK_NOFORK);
	}
        dontfork = srunner_fork_status(sr) == CK_NOFORK;
#ifdef CHECK_IS_XML
	srunner_set_xml(sr, "result.xml");
#endif
	srunner_run_all (sr, CK_VERBOSE);
	rc = srunner_ntests_failed(sr);

	srunner_free(sr);
	/*suite_free(s);  */
	/* no longer available in check 0.9.0; it will leak a
	 * bit with previous versions */
	lasso_shutdown();

	return (rc == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
}