mirror of
https://gitlab.gnome.org/GNOME/calls.git
synced 2025-01-07 12:25:31 +00:00
test: sip: Connect to state-changed signal
instead of relying so much on g_timeout_add()
This commit is contained in:
parent
95bde23f2e
commit
0d467244b2
1 changed files with 55 additions and 50 deletions
105
tests/test-sip.c
105
tests/test-sip.c
|
@ -132,35 +132,6 @@ test_sip_origin_call_lists (SipFixture *fixture,
|
||||||
g_assert_null (calls_offline);
|
g_assert_null (calls_offline);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
|
||||||
on_check_call_disconnected_cb (gpointer user_data)
|
|
||||||
{
|
|
||||||
CallsCall *call = CALLS_CALL (user_data);
|
|
||||||
CallsCallState state = calls_call_get_state (call);
|
|
||||||
|
|
||||||
g_assert_cmpint (state, ==, CALLS_CALL_STATE_DISCONNECTED);
|
|
||||||
|
|
||||||
g_object_unref (call);
|
|
||||||
|
|
||||||
if (is_call_test_done)
|
|
||||||
are_call_tests_done = TRUE;
|
|
||||||
|
|
||||||
is_call_test_done = TRUE;
|
|
||||||
|
|
||||||
return G_SOURCE_REMOVE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
on_check_call_active_cb (gpointer user_data)
|
|
||||||
{
|
|
||||||
CallsCall *call = CALLS_CALL (user_data);
|
|
||||||
CallsCallState state = calls_call_get_state (call);
|
|
||||||
|
|
||||||
g_assert_cmpint (state, ==, CALLS_CALL_STATE_ACTIVE);
|
|
||||||
|
|
||||||
return G_SOURCE_REMOVE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
on_call_hangup_cb (gpointer user_data)
|
on_call_hangup_cb (gpointer user_data)
|
||||||
{
|
{
|
||||||
|
@ -183,30 +154,68 @@ on_call_answer_cb (gpointer user_data)
|
||||||
return G_SOURCE_REMOVE;
|
return G_SOURCE_REMOVE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
static void
|
||||||
* TODO the calling tests are all g_timeout_add based and should be reworked
|
on_autoreject_state_changed_cb (CallsCall *call,
|
||||||
* using g_idle_add and/or using the "state-changed" signal of CallsCall
|
CallsCallState new_state,
|
||||||
*/
|
CallsCallState old_state,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
g_assert_cmpint (old_state, ==, CALLS_CALL_STATE_INCOMING);
|
||||||
|
g_assert_cmpint (new_state, ==, CALLS_CALL_STATE_DISCONNECTED);
|
||||||
|
|
||||||
|
g_object_unref (call);
|
||||||
|
|
||||||
|
is_call_test_done = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_state_changed_cb (CallsCall *call,
|
||||||
|
CallsCallState new_state,
|
||||||
|
CallsCallState old_state,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
gboolean schedule_hangup = GPOINTER_TO_INT (user_data);
|
||||||
|
|
||||||
|
switch (old_state) {
|
||||||
|
case CALLS_CALL_STATE_INCOMING:
|
||||||
|
case CALLS_CALL_STATE_DIALING:
|
||||||
|
g_assert_cmpint (new_state, ==, CALLS_CALL_STATE_ACTIVE);
|
||||||
|
|
||||||
|
if (schedule_hangup)
|
||||||
|
g_idle_add ((GSourceFunc) on_call_hangup_cb, call);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CALLS_CALL_STATE_ACTIVE:
|
||||||
|
g_assert_cmpint (new_state, ==, CALLS_CALL_STATE_DISCONNECTED);
|
||||||
|
|
||||||
|
g_object_unref (call);
|
||||||
|
|
||||||
|
if (is_call_test_done)
|
||||||
|
are_call_tests_done = TRUE;
|
||||||
|
|
||||||
|
is_call_test_done = TRUE;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
g_assert_not_reached ();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
on_incoming_call_autoaccept_cb (CallsOrigin *origin,
|
on_incoming_call_autoaccept_cb (CallsOrigin *origin,
|
||||||
CallsCall *call,
|
CallsCall *call,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
CallsCallState state = calls_call_get_state (call);
|
CallsCallState state = calls_call_get_state (call);
|
||||||
gboolean schedule_hangup = GPOINTER_TO_INT (user_data);
|
|
||||||
|
|
||||||
g_assert_cmpint (state, ==, CALLS_CALL_STATE_INCOMING);
|
g_assert_cmpint (state, ==, CALLS_CALL_STATE_INCOMING);
|
||||||
|
|
||||||
g_object_ref (call);
|
g_object_ref (call);
|
||||||
|
|
||||||
g_timeout_add (50, (GSourceFunc) on_call_answer_cb, call);
|
g_idle_add ((GSourceFunc) on_call_answer_cb, call);
|
||||||
|
|
||||||
g_timeout_add (500, (GSourceFunc) on_check_call_active_cb, call);
|
g_signal_connect (call, "state-changed",
|
||||||
|
(GCallback) on_state_changed_cb, user_data);
|
||||||
if (schedule_hangup)
|
|
||||||
g_timeout_add (1500, (GSourceFunc) on_call_hangup_cb, call);
|
|
||||||
|
|
||||||
g_timeout_add (2000, (GSourceFunc) on_check_call_disconnected_cb, call);
|
|
||||||
|
|
||||||
return G_SOURCE_REMOVE;
|
return G_SOURCE_REMOVE;
|
||||||
}
|
}
|
||||||
|
@ -221,9 +230,10 @@ on_incoming_call_autoreject_cb (CallsOrigin *origin,
|
||||||
g_assert_cmpint (state, ==, CALLS_CALL_STATE_INCOMING);
|
g_assert_cmpint (state, ==, CALLS_CALL_STATE_INCOMING);
|
||||||
|
|
||||||
g_object_ref (call);
|
g_object_ref (call);
|
||||||
g_timeout_add (200, (GSourceFunc) on_call_hangup_cb, call);
|
g_idle_add ((GSourceFunc) on_call_hangup_cb, call);
|
||||||
|
|
||||||
g_timeout_add (1000, (GSourceFunc) on_check_call_disconnected_cb, call);
|
g_signal_connect (call, "state-changed",
|
||||||
|
(GCallback) on_autoreject_state_changed_cb, NULL);
|
||||||
|
|
||||||
return G_SOURCE_REMOVE;
|
return G_SOURCE_REMOVE;
|
||||||
}
|
}
|
||||||
|
@ -235,18 +245,13 @@ on_outgoing_call_cb (CallsOrigin *origin,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
CallsCallState state = calls_call_get_state (call);
|
CallsCallState state = calls_call_get_state (call);
|
||||||
gboolean schedule_hangup = GPOINTER_TO_INT (user_data);
|
|
||||||
|
|
||||||
g_assert_cmpint (state, ==, CALLS_CALL_STATE_DIALING);
|
g_assert_cmpint (state, ==, CALLS_CALL_STATE_DIALING);
|
||||||
|
|
||||||
g_object_ref (call);
|
g_object_ref (call);
|
||||||
|
|
||||||
g_timeout_add (250, (GSourceFunc) on_check_call_active_cb, call);
|
g_signal_connect (call, "state-changed",
|
||||||
|
(GCallback) on_state_changed_cb, user_data);
|
||||||
if (schedule_hangup)
|
|
||||||
g_timeout_add (750, (GSourceFunc) on_call_hangup_cb, call);
|
|
||||||
|
|
||||||
g_timeout_add (2000, (GSourceFunc) on_check_call_disconnected_cb, call);
|
|
||||||
|
|
||||||
return G_SOURCE_REMOVE;
|
return G_SOURCE_REMOVE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue