mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-02-10 12:55:48 +01:00
Merge branch 'custom-dispatch-test-more' into 'main'
gobject/tests/custom-dispatch: Add few more tests See merge request GNOME/glib!2802
This commit is contained in:
commit
32dbedc5f2
@ -114,7 +114,9 @@ test_object_class_init (TestObjectClass *klass)
|
|||||||
properties[PROP_FOO] = g_param_spec_int ("foo", "Foo", "Foo",
|
properties[PROP_FOO] = g_param_spec_int ("foo", "Foo", "Foo",
|
||||||
-1, G_MAXINT,
|
-1, G_MAXINT,
|
||||||
0,
|
0,
|
||||||
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS);
|
G_PARAM_READWRITE |
|
||||||
|
G_PARAM_STATIC_STRINGS |
|
||||||
|
G_PARAM_EXPLICIT_NOTIFY);
|
||||||
|
|
||||||
gobject_class->set_property = test_object_set_property;
|
gobject_class->set_property = test_object_set_property;
|
||||||
gobject_class->get_property = test_object_get_property;
|
gobject_class->get_property = test_object_get_property;
|
||||||
@ -137,6 +139,26 @@ object_has_notify_signal_handlers (gpointer instance)
|
|||||||
return g_signal_handler_find (instance, G_SIGNAL_MATCH_ID, signal_id, 0, NULL, NULL, NULL) != 0;
|
return g_signal_handler_find (instance, G_SIGNAL_MATCH_ID, signal_id, 0, NULL, NULL, NULL) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_custom_dispatch_init (void)
|
||||||
|
{
|
||||||
|
TestObject *obj;
|
||||||
|
|
||||||
|
g_test_summary ("Test that custom dispatch_properties_changed is called "
|
||||||
|
"on initialization");
|
||||||
|
|
||||||
|
dispatch_properties_called = 0;
|
||||||
|
obj = g_object_new (test_object_get_type (), "foo", 5, NULL);
|
||||||
|
|
||||||
|
g_assert_false (object_has_notify_signal_handlers (obj));
|
||||||
|
|
||||||
|
g_assert_cmpint (dispatch_properties_called, ==, 1);
|
||||||
|
g_object_set (obj, "foo", 11, NULL);
|
||||||
|
g_assert_cmpint (dispatch_properties_called, ==, 2);
|
||||||
|
|
||||||
|
g_object_unref (obj);
|
||||||
|
}
|
||||||
|
|
||||||
/* This instance init behavior is the thing we are testing:
|
/* This instance init behavior is the thing we are testing:
|
||||||
*
|
*
|
||||||
* 1. Don't connect any notify handlers
|
* 1. Don't connect any notify handlers
|
||||||
@ -144,12 +166,13 @@ object_has_notify_signal_handlers (gpointer instance)
|
|||||||
* 3. Verify that our custom dispatch_properties_changed is called
|
* 3. Verify that our custom dispatch_properties_changed is called
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
test_custom_dispatch (void)
|
test_custom_dispatch_set (void)
|
||||||
{
|
{
|
||||||
TestObject *obj;
|
TestObject *obj;
|
||||||
|
|
||||||
g_test_summary ("Test that custom dispatch_properties_changed is called regardless of connected notify handlers");
|
g_test_summary ("Test that custom dispatch_properties_changed is called regardless of connected notify handlers");
|
||||||
|
|
||||||
|
dispatch_properties_called = 0;
|
||||||
obj = g_object_new (test_object_get_type (), NULL);
|
obj = g_object_new (test_object_get_type (), NULL);
|
||||||
|
|
||||||
g_assert_false (object_has_notify_signal_handlers (obj));
|
g_assert_false (object_has_notify_signal_handlers (obj));
|
||||||
@ -157,6 +180,8 @@ test_custom_dispatch (void)
|
|||||||
g_assert_cmpint (dispatch_properties_called, ==, 0);
|
g_assert_cmpint (dispatch_properties_called, ==, 0);
|
||||||
g_object_set (obj, "foo", 11, NULL);
|
g_object_set (obj, "foo", 11, NULL);
|
||||||
g_assert_cmpint (dispatch_properties_called, ==, 1);
|
g_assert_cmpint (dispatch_properties_called, ==, 1);
|
||||||
|
g_object_set (obj, "foo", 11, NULL);
|
||||||
|
g_assert_cmpint (dispatch_properties_called, ==, 1);
|
||||||
|
|
||||||
g_object_unref (obj);
|
g_object_unref (obj);
|
||||||
}
|
}
|
||||||
@ -166,7 +191,8 @@ main (int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
g_test_init (&argc, &argv, NULL);
|
g_test_init (&argc, &argv, NULL);
|
||||||
|
|
||||||
g_test_add_func ("/properties/custom-dispatch", test_custom_dispatch);
|
g_test_add_func ("/properties/custom-dispatch/init", test_custom_dispatch_init);
|
||||||
|
g_test_add_func ("/properties/custom-dispatch/set", test_custom_dispatch_set);
|
||||||
|
|
||||||
return g_test_run ();
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user