/* testlogger.c generated by valac, the Vala compiler
 * generated from testlogger.vala, do not modify */


#include <glib.h>
#include <glib-object.h>
#include <fsobasics.h>
#include <glib/gstdio.h>
#include <gio/gio.h>
#include <stdlib.h>
#include <string.h>
#include <gobject/gvaluecollector.h>

#define _g_free0(var) (var = (g_free (var), NULL))
#define _g_object_unref0(var) ((var == NULL) ? NULL : (var = (g_object_unref (var), NULL)))

#define TYPE_REPR_DELEGATE_TESTER (repr_delegate_tester_get_type ())
#define REPR_DELEGATE_TESTER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_REPR_DELEGATE_TESTER, ReprDelegateTester))
#define REPR_DELEGATE_TESTER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_REPR_DELEGATE_TESTER, ReprDelegateTesterClass))
#define IS_REPR_DELEGATE_TESTER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_REPR_DELEGATE_TESTER))
#define IS_REPR_DELEGATE_TESTER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_REPR_DELEGATE_TESTER))
#define REPR_DELEGATE_TESTER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_REPR_DELEGATE_TESTER, ReprDelegateTesterClass))

typedef struct _ReprDelegateTester ReprDelegateTester;
typedef struct _ReprDelegateTesterClass ReprDelegateTesterClass;
typedef struct _ReprDelegateTesterPrivate ReprDelegateTesterPrivate;
typedef struct _ParamSpecReprDelegateTester ParamSpecReprDelegateTester;
#define _repr_delegate_tester_unref0(var) ((var == NULL) ? NULL : (var = (repr_delegate_tester_unref (var), NULL)))

struct _ReprDelegateTester {
	GTypeInstance parent_instance;
	volatile int ref_count;
	ReprDelegateTesterPrivate * priv;
	gboolean called;
};

struct _ReprDelegateTesterClass {
	GTypeClass parent_class;
	void (*finalize) (ReprDelegateTester *self);
};

struct _ParamSpecReprDelegateTester {
	GParamSpec parent_instance;
};


static gpointer repr_delegate_tester_parent_class = NULL;

#define TEST_FILE_NAME "/tmp/logfile.txt"
#define TEST_LOG_DOMAIN "my.logging.domain"
#define TEST_LOG_KEYFILE_NAME ".testlogger.ini"
#define TEST_LOG_KEYFILE ".testlogger.ini"
void test_logger_conversions (void);
void test_null_logger_new (void);
void test_file_logger_new (void);
gpointer repr_delegate_tester_ref (gpointer instance);
void repr_delegate_tester_unref (gpointer instance);
GParamSpec* param_spec_repr_delegate_tester (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags);
void value_set_repr_delegate_tester (GValue* value, gpointer v_object);
gpointer value_get_repr_delegate_tester (const GValue* value);
GType repr_delegate_tester_get_type (void);
enum  {
	REPR_DELEGATE_TESTER_DUMMY_PROPERTY
};
char* repr_delegate_tester_repr (ReprDelegateTester* self);
ReprDelegateTester* repr_delegate_tester_new (void);
ReprDelegateTester* repr_delegate_tester_construct (GType object_type);
static void repr_delegate_tester_finalize (ReprDelegateTester* obj);
static char* _repr_delegate_tester_repr_repr_delegate (gpointer self);
void test_logger_reprdelegate (void);
void test_syslog_logger_new (void);
void test_logger_create_from_keyfilename (void);
void test_logger_create_from_keyfile (void);
static void _test_logger_conversions_gcallback (void);
static void _test_logger_reprdelegate_gcallback (void);
static void _test_null_logger_new_gcallback (void);
static void _test_file_logger_new_gcallback (void);
static void _test_syslog_logger_new_gcallback (void);
static void _test_logger_create_from_keyfilename_gcallback (void);
static void _test_logger_create_from_keyfile_gcallback (void);
void _main (char** args, int args_length1);
static int _vala_strcmp0 (const char * str1, const char * str2);



void test_logger_conversions (void) {
	char* _tmp0_;
	char* _tmp1_;
	char* _tmp2_;
	char* _tmp3_;
	g_assert (_vala_strcmp0 (_tmp0_ = fso_framework_abstract_logger_levelToString (G_LOG_LEVEL_DEBUG), "DEBUG") == 0);
	_g_free0 (_tmp0_);
	g_assert (_vala_strcmp0 (_tmp1_ = fso_framework_abstract_logger_levelToString (G_LOG_LEVEL_INFO), "INFO") == 0);
	_g_free0 (_tmp1_);
	g_assert (_vala_strcmp0 (_tmp2_ = fso_framework_abstract_logger_levelToString (G_LOG_LEVEL_WARNING), "WARNING") == 0);
	_g_free0 (_tmp2_);
	g_assert (_vala_strcmp0 (_tmp3_ = fso_framework_abstract_logger_levelToString (G_LOG_LEVEL_ERROR), "ERROR") == 0);
	_g_free0 (_tmp3_);
	g_assert (fso_framework_abstract_logger_stringToLevel ("debug") == G_LOG_LEVEL_DEBUG);
	g_assert (fso_framework_abstract_logger_stringToLevel ("info") == G_LOG_LEVEL_INFO);
	g_assert (fso_framework_abstract_logger_stringToLevel ("warning") == G_LOG_LEVEL_WARNING);
	g_assert (fso_framework_abstract_logger_stringToLevel ("error") == G_LOG_LEVEL_ERROR);
	g_assert (fso_framework_abstract_logger_stringToLevel ("DEBUG") == G_LOG_LEVEL_DEBUG);
	g_assert (fso_framework_abstract_logger_stringToLevel ("INFO") == G_LOG_LEVEL_INFO);
	g_assert (fso_framework_abstract_logger_stringToLevel ("WARNING") == G_LOG_LEVEL_WARNING);
	g_assert (fso_framework_abstract_logger_stringToLevel ("ERROR") == G_LOG_LEVEL_ERROR);
}


void test_null_logger_new (void) {
	FsoFrameworkNullLogger* logger;
	logger = fso_framework_null_logger_new (TEST_LOG_DOMAIN);
	fso_framework_logger_setLevel ((FsoFrameworkLogger*) logger, G_LOG_LEVEL_DEBUG);
	fso_framework_logger_debug ((FsoFrameworkLogger*) logger, "foo");
	fso_framework_logger_info ((FsoFrameworkLogger*) logger, "bar");
	fso_framework_logger_warning ((FsoFrameworkLogger*) logger, "ham");
	fso_framework_logger_error ((FsoFrameworkLogger*) logger, "eggs");
	_g_object_unref0 (logger);
}


static gboolean string_contains (const char* self, const char* needle) {
	gboolean result;
	g_return_val_if_fail (self != NULL, FALSE);
	g_return_val_if_fail (needle != NULL, FALSE);
	result = strstr (self, needle) != NULL;
	return result;
}


void test_file_logger_new (void) {
	GError * _inner_error_;
	FsoFrameworkFileLogger* logger;
	GFile* file;
	GFileInputStream* _tmp0_;
	GFileInputStream* _tmp1_;
	GDataInputStream* _tmp2_;
	GDataInputStream* stream;
	char* line1;
	char* line2;
	char* line3;
	char* line4;
	_inner_error_ = NULL;
	g_remove (TEST_FILE_NAME);
	logger = fso_framework_file_logger_new (TEST_LOG_DOMAIN);
	fso_framework_file_logger_setFile (logger, TEST_FILE_NAME, FALSE);
	fso_framework_logger_setLevel ((FsoFrameworkLogger*) logger, G_LOG_LEVEL_DEBUG);
	fso_framework_logger_debug ((FsoFrameworkLogger*) logger, "foo");
	fso_framework_logger_info ((FsoFrameworkLogger*) logger, "bar");
	fso_framework_logger_warning ((FsoFrameworkLogger*) logger, "ham");
	fso_framework_logger_error ((FsoFrameworkLogger*) logger, "eggs");
	file = g_file_new_for_path (TEST_FILE_NAME);
	g_assert (g_file_query_exists (file, NULL));
	_tmp0_ = g_file_read (file, NULL, &_inner_error_);
	if (_inner_error_ != NULL) {
		_g_object_unref0 (logger);
		_g_object_unref0 (file);
		g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code);
		g_clear_error (&_inner_error_);
		return;
	}
	stream = (_tmp2_ = g_data_input_stream_new ((GInputStream*) (_tmp1_ = _tmp0_)), _g_object_unref0 (_tmp1_), _tmp2_);
	line1 = g_data_input_stream_read_line (stream, NULL, NULL, &_inner_error_);
	if (_inner_error_ != NULL) {
		_g_object_unref0 (logger);
		_g_object_unref0 (file);
		_g_object_unref0 (stream);
		g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code);
		g_clear_error (&_inner_error_);
		return;
	}
	g_assert (string_contains (line1, "DEBUG") && string_contains (line1, "foo"));
	line2 = g_data_input_stream_read_line (stream, NULL, NULL, &_inner_error_);
	if (_inner_error_ != NULL) {
		_g_object_unref0 (logger);
		_g_object_unref0 (file);
		_g_object_unref0 (stream);
		_g_free0 (line1);
		g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code);
		g_clear_error (&_inner_error_);
		return;
	}
	g_assert (string_contains (line2, "INFO") && string_contains (line2, "bar"));
	line3 = g_data_input_stream_read_line (stream, NULL, NULL, &_inner_error_);
	if (_inner_error_ != NULL) {
		_g_object_unref0 (logger);
		_g_object_unref0 (file);
		_g_object_unref0 (stream);
		_g_free0 (line1);
		_g_free0 (line2);
		g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code);
		g_clear_error (&_inner_error_);
		return;
	}
	g_assert (string_contains (line3, "WARNING") && string_contains (line3, "ham"));
	line4 = g_data_input_stream_read_line (stream, NULL, NULL, &_inner_error_);
	if (_inner_error_ != NULL) {
		_g_object_unref0 (logger);
		_g_object_unref0 (file);
		_g_object_unref0 (stream);
		_g_free0 (line1);
		_g_free0 (line2);
		_g_free0 (line3);
		g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code);
		g_clear_error (&_inner_error_);
		return;
	}
	g_assert (string_contains (line4, "ERROR") && string_contains (line4, "eggs"));
	_g_object_unref0 (logger);
	_g_object_unref0 (file);
	_g_object_unref0 (stream);
	_g_free0 (line1);
	_g_free0 (line2);
	_g_free0 (line3);
	_g_free0 (line4);
}


char* repr_delegate_tester_repr (ReprDelegateTester* self) {
	char* result;
	g_return_val_if_fail (self != NULL, NULL);
	self->called = TRUE;
	result = g_strdup ("<representation>");
	return result;
}


ReprDelegateTester* repr_delegate_tester_construct (GType object_type) {
	ReprDelegateTester* self;
	self = (ReprDelegateTester*) g_type_create_instance (object_type);
	return self;
}


ReprDelegateTester* repr_delegate_tester_new (void) {
	return repr_delegate_tester_construct (TYPE_REPR_DELEGATE_TESTER);
}


static void value_repr_delegate_tester_init (GValue* value) {
	value->data[0].v_pointer = NULL;
}


static void value_repr_delegate_tester_free_value (GValue* value) {
	if (value->data[0].v_pointer) {
		repr_delegate_tester_unref (value->data[0].v_pointer);
	}
}


static void value_repr_delegate_tester_copy_value (const GValue* src_value, GValue* dest_value) {
	if (src_value->data[0].v_pointer) {
		dest_value->data[0].v_pointer = repr_delegate_tester_ref (src_value->data[0].v_pointer);
	} else {
		dest_value->data[0].v_pointer = NULL;
	}
}


static gpointer value_repr_delegate_tester_peek_pointer (const GValue* value) {
	return value->data[0].v_pointer;
}


static gchar* value_repr_delegate_tester_collect_value (GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) {
	if (collect_values[0].v_pointer) {
		ReprDelegateTester* object;
		object = collect_values[0].v_pointer;
		if (object->parent_instance.g_class == NULL) {
			return g_strconcat ("invalid unclassed object pointer for value type `", G_VALUE_TYPE_NAME (value), "'", NULL);
		} else if (!g_value_type_compatible (G_TYPE_FROM_INSTANCE (object), G_VALUE_TYPE (value))) {
			return g_strconcat ("invalid object type `", g_type_name (G_TYPE_FROM_INSTANCE (object)), "' for value type `", G_VALUE_TYPE_NAME (value), "'", NULL);
		}
		value->data[0].v_pointer = repr_delegate_tester_ref (object);
	} else {
		value->data[0].v_pointer = NULL;
	}
	return NULL;
}


static gchar* value_repr_delegate_tester_lcopy_value (const GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) {
	ReprDelegateTester** object_p;
	object_p = collect_values[0].v_pointer;
	if (!object_p) {
		return g_strdup_printf ("value location for `%s' passed as NULL", G_VALUE_TYPE_NAME (value));
	}
	if (!value->data[0].v_pointer) {
		*object_p = NULL;
	} else if (collect_flags && G_VALUE_NOCOPY_CONTENTS) {
		*object_p = value->data[0].v_pointer;
	} else {
		*object_p = repr_delegate_tester_ref (value->data[0].v_pointer);
	}
	return NULL;
}


GParamSpec* param_spec_repr_delegate_tester (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags) {
	ParamSpecReprDelegateTester* spec;
	g_return_val_if_fail (g_type_is_a (object_type, TYPE_REPR_DELEGATE_TESTER), NULL);
	spec = g_param_spec_internal (G_TYPE_PARAM_OBJECT, name, nick, blurb, flags);
	G_PARAM_SPEC (spec)->value_type = object_type;
	return G_PARAM_SPEC (spec);
}


gpointer value_get_repr_delegate_tester (const GValue* value) {
	g_return_val_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_REPR_DELEGATE_TESTER), NULL);
	return value->data[0].v_pointer;
}


void value_set_repr_delegate_tester (GValue* value, gpointer v_object) {
	ReprDelegateTester* old;
	g_return_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_REPR_DELEGATE_TESTER));
	old = value->data[0].v_pointer;
	if (v_object) {
		g_return_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (v_object, TYPE_REPR_DELEGATE_TESTER));
		g_return_if_fail (g_value_type_compatible (G_TYPE_FROM_INSTANCE (v_object), G_VALUE_TYPE (value)));
		value->data[0].v_pointer = v_object;
		repr_delegate_tester_ref (value->data[0].v_pointer);
	} else {
		value->data[0].v_pointer = NULL;
	}
	if (old) {
		repr_delegate_tester_unref (old);
	}
}


static void repr_delegate_tester_class_init (ReprDelegateTesterClass * klass) {
	repr_delegate_tester_parent_class = g_type_class_peek_parent (klass);
	REPR_DELEGATE_TESTER_CLASS (klass)->finalize = repr_delegate_tester_finalize;
}


static void repr_delegate_tester_instance_init (ReprDelegateTester * self) {
	self->ref_count = 1;
}


static void repr_delegate_tester_finalize (ReprDelegateTester* obj) {
	ReprDelegateTester * self;
	self = REPR_DELEGATE_TESTER (obj);
}


GType repr_delegate_tester_get_type (void) {
	static GType repr_delegate_tester_type_id = 0;
	if (repr_delegate_tester_type_id == 0) {
		static const GTypeValueTable g_define_type_value_table = { value_repr_delegate_tester_init, value_repr_delegate_tester_free_value, value_repr_delegate_tester_copy_value, value_repr_delegate_tester_peek_pointer, "p", value_repr_delegate_tester_collect_value, "p", value_repr_delegate_tester_lcopy_value };
		static const GTypeInfo g_define_type_info = { sizeof (ReprDelegateTesterClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) repr_delegate_tester_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (ReprDelegateTester), 0, (GInstanceInitFunc) repr_delegate_tester_instance_init, &g_define_type_value_table };
		static const GTypeFundamentalInfo g_define_type_fundamental_info = { (G_TYPE_FLAG_CLASSED | G_TYPE_FLAG_INSTANTIATABLE | G_TYPE_FLAG_DERIVABLE | G_TYPE_FLAG_DEEP_DERIVABLE) };
		repr_delegate_tester_type_id = g_type_register_fundamental (g_type_fundamental_next (), "ReprDelegateTester", &g_define_type_info, &g_define_type_fundamental_info, 0);
	}
	return repr_delegate_tester_type_id;
}


gpointer repr_delegate_tester_ref (gpointer instance) {
	ReprDelegateTester* self;
	self = instance;
	g_atomic_int_inc (&self->ref_count);
	return instance;
}


void repr_delegate_tester_unref (gpointer instance) {
	ReprDelegateTester* self;
	self = instance;
	if (g_atomic_int_dec_and_test (&self->ref_count)) {
		REPR_DELEGATE_TESTER_GET_CLASS (self)->finalize (self);
		g_type_free_instance ((GTypeInstance *) self);
	}
}


static char* _repr_delegate_tester_repr_repr_delegate (gpointer self) {
	return repr_delegate_tester_repr (self);
}


void test_logger_reprdelegate (void) {
	FsoFrameworkFileLogger* logger;
	ReprDelegateTester* r;
	logger = fso_framework_file_logger_new (TEST_LOG_DOMAIN);
	fso_framework_file_logger_setFile (logger, "/dev/null", FALSE);
	r = repr_delegate_tester_new ();
	r->called = FALSE;
	fso_framework_logger_setReprDelegate ((FsoFrameworkLogger*) logger, _repr_delegate_tester_repr_repr_delegate, r);
	fso_framework_logger_warning ((FsoFrameworkLogger*) logger, "foo");
	g_assert (r->called);
	_g_object_unref0 (logger);
	_repr_delegate_tester_unref0 (r);
}


void test_syslog_logger_new (void) {
	FsoFrameworkSyslogLogger* logger;
	logger = fso_framework_syslog_logger_new (TEST_LOG_DOMAIN);
	fso_framework_logger_setLevel ((FsoFrameworkLogger*) logger, G_LOG_LEVEL_DEBUG);
	fso_framework_logger_debug ((FsoFrameworkLogger*) logger, "foo");
	_g_object_unref0 (logger);
}


void test_logger_create_from_keyfilename (void) {
	FsoFrameworkLogger* logger;
	FsoFrameworkLogger* _tmp0_;
	FsoFrameworkLogger* _tmp1_;
	FsoFrameworkLogger* _tmp2_;
	char* _tmp3_;
	logger = fso_framework_logger_createFromKeyFileName (TEST_LOG_KEYFILE_NAME, "nologger", TEST_LOG_DOMAIN);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_STD_ERR_LOGGER));
	logger = (_tmp0_ = fso_framework_logger_createFromKeyFileName (TEST_LOG_KEYFILE_NAME, "stderr", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp0_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_STD_ERR_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_DEBUG);
	logger = (_tmp1_ = fso_framework_logger_createFromKeyFileName (TEST_LOG_KEYFILE_NAME, "syslog", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp1_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_SYSLOG_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_INFO);
	logger = (_tmp2_ = fso_framework_logger_createFromKeyFileName (TEST_LOG_KEYFILE_NAME, "file", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp2_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_FILE_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_WARNING);
	g_assert (_vala_strcmp0 (_tmp3_ = fso_framework_logger_getDestination (logger), "log.txt") == 0);
	_g_free0 (_tmp3_);
	_g_object_unref0 (logger);
}


void test_logger_create_from_keyfile (void) {
	FsoFrameworkSmartKeyFile* smk;
	FsoFrameworkLogger* logger;
	FsoFrameworkLogger* _tmp0_;
	FsoFrameworkLogger* _tmp1_;
	FsoFrameworkLogger* _tmp2_;
	char* _tmp3_;
	smk = fso_framework_smart_key_file_new ();
	fso_framework_smart_key_file_loadFromFile (smk, TEST_LOG_KEYFILE);
	logger = fso_framework_logger_createFromKeyFile (smk, "nologger", TEST_LOG_DOMAIN);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_STD_ERR_LOGGER));
	logger = (_tmp0_ = fso_framework_logger_createFromKeyFile (smk, "stderr", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp0_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_STD_ERR_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_DEBUG);
	logger = (_tmp1_ = fso_framework_logger_createFromKeyFile (smk, "syslog", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp1_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_SYSLOG_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_INFO);
	logger = (_tmp2_ = fso_framework_logger_createFromKeyFile (smk, "file", TEST_LOG_DOMAIN), _g_object_unref0 (logger), _tmp2_);
	g_assert ((&G_TYPE_FROM_INSTANCE (logger)) == (&FSO_FRAMEWORK_TYPE_FILE_LOGGER));
	g_assert (fso_framework_logger_getLevel (logger) == G_LOG_LEVEL_WARNING);
	g_assert (_vala_strcmp0 (_tmp3_ = fso_framework_logger_getDestination (logger), "log.txt") == 0);
	_g_free0 (_tmp3_);
	_g_object_unref0 (smk);
	_g_object_unref0 (logger);
}


static void _test_logger_conversions_gcallback (void) {
	test_logger_conversions ();
}


static void _test_logger_reprdelegate_gcallback (void) {
	test_logger_reprdelegate ();
}


static void _test_null_logger_new_gcallback (void) {
	test_null_logger_new ();
}


static void _test_file_logger_new_gcallback (void) {
	test_file_logger_new ();
}


static void _test_syslog_logger_new_gcallback (void) {
	test_syslog_logger_new ();
}


static void _test_logger_create_from_keyfilename_gcallback (void) {
	test_logger_create_from_keyfilename ();
}


static void _test_logger_create_from_keyfile_gcallback (void) {
	test_logger_create_from_keyfile ();
}


void _main (char** args, int args_length1) {
	g_test_init (&args_length1, &args, NULL);
	g_test_add_func ("/Logger/Conversions", _test_logger_conversions_gcallback);
	g_test_add_func ("/Logger/ReprDelegate", _test_logger_reprdelegate_gcallback);
	g_test_add_func ("/NullLogger/New", _test_null_logger_new_gcallback);
	g_test_add_func ("/FileLogger/New", _test_file_logger_new_gcallback);
	g_test_add_func ("/SyslogLogger/New", _test_syslog_logger_new_gcallback);
	g_test_add_func ("/Logger/CreateFromKeyFileName", _test_logger_create_from_keyfilename_gcallback);
	g_test_add_func ("/Logger/CreateFromKeyFile", _test_logger_create_from_keyfile_gcallback);
	g_test_run ();
}


int main (int argc, char ** argv) {
	g_thread_init (NULL);
	g_type_init ();
	_main (argv, argc);
	return 0;
}


static int _vala_strcmp0 (const char * str1, const char * str2) {
	if (str1 == NULL) {
		return -(str1 != str2);
	}
	if (str2 == NULL) {
		return str1 != str2;
	}
	return strcmp (str1, str2);
}




