mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-12 07:26:15 +01:00
tests/performance: avoid check for toggle notification in "property-{get,set}"
Bumping the reference count from 1 to 2 (and back) is more expensive, due to the check for toggle notifications. We have a performance test already that hits that code path. Avoid that for he "property-{get,set}" tests, so we avoid the known overhead and test more relevant parts.
This commit is contained in:
parent
b6789dd1ea
commit
2b1a7e30b1
@ -1139,6 +1139,12 @@ test_set_setup (PerformanceTest *test)
|
||||
data = g_new0 (struct SetTest, 1);
|
||||
data->object = g_object_new (COMPLEX_TYPE_OBJECT, NULL);
|
||||
|
||||
/* g_object_get() will take a reference. Increasing the ref count from 1 to 2
|
||||
* is more expensive, due to the check for toggle notifications. We have a
|
||||
* performance test for that already. Don't also test that overhead during
|
||||
* "property-get" test and avoid this by taking an additional reference. */
|
||||
g_object_ref (data->object);
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
@ -1175,6 +1181,7 @@ test_set_teardown (PerformanceTest *test,
|
||||
{
|
||||
struct SetTest *data = _data;
|
||||
|
||||
g_object_unref (data->object);
|
||||
g_object_unref (data->object);
|
||||
g_free (data);
|
||||
}
|
||||
@ -1210,6 +1217,12 @@ test_get_setup (PerformanceTest *test)
|
||||
data = g_new0 (struct GetTest, 1);
|
||||
data->object = g_object_new (COMPLEX_TYPE_OBJECT, NULL);
|
||||
|
||||
/* g_object_get() will take a reference. Increasing the ref count from 1 to 2
|
||||
* is more expensive, due to the check for toggle notifications. We have a
|
||||
* performance test for that already. Don't also test that overhead during
|
||||
* "property-get" test and avoid this by taking an additional reference. */
|
||||
g_object_ref (data->object);
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
@ -1246,6 +1259,7 @@ test_get_teardown (PerformanceTest *test,
|
||||
{
|
||||
struct GetTest *data = _data;
|
||||
|
||||
g_object_unref (data->object);
|
||||
g_object_unref (data->object);
|
||||
g_free (data);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user