core: return true from _is_connected() only after receiving the info structure

This commit is contained in:
George Kiagiadakis 2023-04-11 13:43:37 +03:00 committed by Julian Bouzas
parent f00011d23a
commit 903fab9c3c
2 changed files with 21 additions and 8 deletions

View file

@ -648,7 +648,7 @@ gboolean
wp_core_is_connected (WpCore * self)
{
g_return_val_if_fail (WP_IS_CORE (self), FALSE);
return self->pw_core != NULL;
return self->pw_core && self->info;
}
/*!
@ -664,7 +664,6 @@ guint32
wp_core_get_remote_cookie (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), 0);
g_return_val_if_fail (self->info, 0);
return self->info->cookie;
}
@ -679,7 +678,6 @@ const gchar *
wp_core_get_remote_name (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), NULL);
g_return_val_if_fail (self->info, NULL);
return self->info->name;
}
@ -695,7 +693,6 @@ const gchar *
wp_core_get_remote_user_name (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), NULL);
g_return_val_if_fail (self->info, NULL);
return self->info->user_name;
}
@ -711,7 +708,6 @@ const gchar *
wp_core_get_remote_host_name (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), NULL);
g_return_val_if_fail (self->info, NULL);
return self->info->host_name;
}
@ -726,7 +722,6 @@ const gchar *
wp_core_get_remote_version (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), NULL);
g_return_val_if_fail (self->info, NULL);
return self->info->version;
}
@ -742,7 +737,6 @@ WpProperties *
wp_core_get_remote_properties (WpCore * self)
{
g_return_val_if_fail (wp_core_is_connected (self), NULL);
g_return_val_if_fail (self->info, NULL);
return wp_properties_new_wrap_dict (self->info->props);
}

View file

@ -32,6 +32,12 @@ test_core_teardown (TestFixture *self, gconstpointer user_data)
wp_base_test_fixture_teardown (&self->base);
}
static void
expect_connected (WpCore * core, TestFixture * f)
{
g_main_loop_quit (f->base.loop);
}
static void
expect_disconnected (WpCore * core, TestFixture * f)
{
@ -49,6 +55,8 @@ expect_object_added (WpObjectManager *om, WpProxy *proxy, TestFixture *f)
static void
test_core_server_disconnected (TestFixture *f, gconstpointer data)
{
g_signal_connect (f->base.core, "connected",
G_CALLBACK (expect_connected), f);
g_signal_connect (f->base.core, "disconnected",
G_CALLBACK (expect_disconnected), f);
g_signal_connect (f->om, "object-added",
@ -59,6 +67,7 @@ test_core_server_disconnected (TestFixture *f, gconstpointer data)
/* connect */
g_assert_true (wp_core_connect (f->base.core));
g_main_loop_run (f->base.loop);
g_assert_true (wp_core_is_connected (f->base.core));
/* wait for the object manager to collect the client proxy */
@ -77,6 +86,8 @@ test_core_server_disconnected (TestFixture *f, gconstpointer data)
static void
test_core_client_disconnected (TestFixture *f, gconstpointer data)
{
g_signal_connect (f->base.core, "connected",
G_CALLBACK (expect_connected), f);
g_signal_connect (f->base.core, "disconnected",
G_CALLBACK (expect_disconnected), f);
g_signal_connect (f->om, "object-added",
@ -87,6 +98,7 @@ test_core_client_disconnected (TestFixture *f, gconstpointer data)
/* connect */
g_assert_true (wp_core_connect (f->base.core));
g_main_loop_run (f->base.loop);
g_assert_true (wp_core_is_connected (f->base.core));
/* wait for the object manager to collect the client proxy */
@ -111,13 +123,20 @@ test_core_clone (TestFixture *f, gconstpointer data)
g_assert_nonnull (clone);
g_assert_false (wp_core_is_connected (clone));
g_signal_connect (f->base.core, "connected",
G_CALLBACK (expect_connected), f);
g_signal_connect (clone, "connected",
G_CALLBACK (expect_connected), f);
/* connect clone */
g_assert_true (wp_core_connect (clone));
g_main_loop_run (f->base.loop);
g_assert_true (wp_core_is_connected (clone));
g_assert_false (wp_core_is_connected (f->base.core));
/* connect core */
g_assert_true (wp_core_connect (f->base.core));
g_main_loop_run (f->base.loop);
g_assert_true (wp_core_is_connected (clone));
g_assert_true (wp_core_is_connected (f->base.core));
@ -142,7 +161,7 @@ main (gint argc, gchar *argv[])
test_core_setup, test_core_server_disconnected, test_core_teardown);
g_test_add ("/wp/core/client-disconnected", TestFixture, NULL,
test_core_setup, test_core_client_disconnected, test_core_teardown);
g_test_add ("/wp/core/cline", TestFixture, NULL,
g_test_add ("/wp/core/clone", TestFixture, NULL,
test_core_setup, test_core_clone, test_core_teardown);
return g_test_run ();