2013-03-27 22:23:24 +01:00
|
|
|
#include "test-common.h"
|
|
|
|
|
|
|
|
|
|
SignalData *
|
2013-06-19 16:18:29 -05:00
|
|
|
add_signal_full (const char *name, GCallback callback, int ifindex, const char *ifname)
|
2013-03-27 22:23:24 +01:00
|
|
|
{
|
|
|
|
|
SignalData *data = g_new0 (SignalData, 1);
|
|
|
|
|
|
|
|
|
|
data->name = name;
|
|
|
|
|
data->received = FALSE;
|
|
|
|
|
data->handler_id = g_signal_connect (nm_platform_get (), name, callback, data);
|
|
|
|
|
data->ifindex = ifindex;
|
2013-06-19 16:18:29 -05:00
|
|
|
data->ifname = ifname;
|
2013-03-27 22:23:24 +01:00
|
|
|
|
|
|
|
|
g_assert (data->handler_id >= 0);
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
accept_signal (SignalData *data)
|
|
|
|
|
{
|
2013-07-26 14:25:47 +02:00
|
|
|
debug ("Accepting signal '%s' ifindex %d ifname %s.", data->name, data->ifindex, data->ifname);
|
2013-03-27 22:23:24 +01:00
|
|
|
if (!data->received)
|
|
|
|
|
g_error ("Attemted to accept a non-received signal '%s'.", data->name);
|
|
|
|
|
|
|
|
|
|
data->received = FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
wait_signal (SignalData *data)
|
|
|
|
|
{
|
|
|
|
|
data->loop = g_main_loop_new (NULL, FALSE);
|
|
|
|
|
g_main_loop_run (data->loop);
|
2013-07-26 14:50:38 +02:00
|
|
|
g_clear_pointer (&data->loop, g_main_loop_unref);
|
2013-03-27 22:23:24 +01:00
|
|
|
|
|
|
|
|
accept_signal (data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
free_signal (SignalData *data)
|
|
|
|
|
{
|
|
|
|
|
if (data->received)
|
|
|
|
|
g_error ("Attempted to free received but not accepted signal '%s'.", data->name);
|
|
|
|
|
|
|
|
|
|
g_signal_handler_disconnect (nm_platform_get (), data->handler_id);
|
|
|
|
|
g_free (data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
run_command (const char *format, ...)
|
|
|
|
|
{
|
|
|
|
|
char *command;
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
|
|
va_start (ap, format);
|
|
|
|
|
|
|
|
|
|
command = g_strdup_vprintf (format, ap);
|
2013-07-26 14:25:47 +02:00
|
|
|
debug ("Running command: %s", command);
|
2013-03-27 22:23:24 +01:00
|
|
|
g_assert (!system (command));
|
2013-07-26 14:25:47 +02:00
|
|
|
debug ("Command finished.");
|
2013-03-27 22:23:24 +01:00
|
|
|
g_free (command);
|
|
|
|
|
}
|
|
|
|
|
|
2013-06-21 04:01:44 +02:00
|
|
|
int
|
|
|
|
|
main (int argc, char **argv)
|
|
|
|
|
{
|
|
|
|
|
int result;
|
|
|
|
|
|
|
|
|
|
openlog (G_LOG_DOMAIN, LOG_CONS | LOG_PERROR, LOG_DAEMON);
|
|
|
|
|
g_type_init ();
|
|
|
|
|
g_test_init (&argc, &argv, NULL);
|
|
|
|
|
/* Enable debug messages if called with --debug */
|
|
|
|
|
for (; *argv; argv++) {
|
|
|
|
|
if (!g_strcmp0 (*argv, "--debug")) {
|
|
|
|
|
nm_logging_setup ("debug", NULL, NULL);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SETUP ();
|
|
|
|
|
|
|
|
|
|
setup_tests ();
|
|
|
|
|
|
|
|
|
|
result = g_test_run ();
|
|
|
|
|
|
|
|
|
|
nm_platform_free ();
|
|
|
|
|
return result;
|
|
|
|
|
}
|