Convert tests/gobject/dynamictype.c to glib test framework

This commit is contained in:
Emmanuel Fleury 2022-03-13 17:44:45 +01:00 committed by Philip Withnall
parent b61d3edc33
commit 17ddf79e1d

View File

@ -15,20 +15,12 @@
* Public License along with this library; if not, see <http://www.gnu.org/licenses/>. * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
*/ */
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "TestDynamicType"
#undef G_DISABLE_ASSERT
#undef G_DISABLE_CHECKS
#undef G_DISABLE_CAST_CHECKS
#include <glib-object.h> #include <glib-object.h>
#include "testcommon.h" #include "testcommon.h"
#include "testmodule.h" #include "testmodule.h"
/* This test tests the macros for defining dynamic types. /* This test tests the macros for defining dynamic types */
*/
static gboolean loaded = FALSE; static gboolean loaded = FALSE;
@ -39,8 +31,11 @@ struct _TestIfaceClass
}; };
static GType test_iface_get_type (void); static GType test_iface_get_type (void);
#define TEST_TYPE_IFACE (test_iface_get_type ()) #define TEST_TYPE_IFACE (test_iface_get_type ())
#define TEST_IFACE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), TEST_TYPE_IFACE, TestIfaceClass)) #define TEST_IFACE_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_INTERFACE ((obj), TEST_TYPE_IFACE, TestIfaceClass))
typedef struct _TestIface TestIface; typedef struct _TestIface TestIface;
typedef struct _TestIfaceClass TestIfaceClass; typedef struct _TestIfaceClass TestIfaceClass;
@ -51,7 +46,7 @@ static DEFINE_IFACE(TestIface, test_iface, test_iface_base_init, test_iface_defa
static void static void
test_iface_default_init (TestIfaceClass *iface, test_iface_default_init (TestIfaceClass *iface,
gpointer class_data) gpointer class_data)
{ {
} }
@ -75,8 +70,8 @@ struct _DynamicObjectClass
static void dynamic_object_iface_init (TestIface *iface); static void dynamic_object_iface_init (TestIface *iface);
G_DEFINE_DYNAMIC_TYPE_EXTENDED(DynamicObject, dynamic_object, G_TYPE_OBJECT, 0, G_DEFINE_DYNAMIC_TYPE_EXTENDED(DynamicObject, dynamic_object, G_TYPE_OBJECT, 0,
G_IMPLEMENT_INTERFACE_DYNAMIC (TEST_TYPE_IFACE, G_IMPLEMENT_INTERFACE_DYNAMIC (TEST_TYPE_IFACE,
dynamic_object_iface_init)); dynamic_object_iface_init));
static void static void
dynamic_object_class_init (DynamicObjectClass *class) dynamic_object_class_init (DynamicObjectClass *class)
@ -116,26 +111,28 @@ test_dynamic_type (void)
/* Not loaded until we call ref for the first time */ /* Not loaded until we call ref for the first time */
class = g_type_class_peek (DYNAMIC_OBJECT_TYPE); class = g_type_class_peek (DYNAMIC_OBJECT_TYPE);
g_assert (class == NULL); g_assert_null (class);
g_assert (!loaded); g_assert_false (loaded);
/* Make sure interfaces work */ /* Make sure interfaces work */
g_assert (g_type_is_a (DYNAMIC_OBJECT_TYPE, g_assert_true (g_type_is_a (DYNAMIC_OBJECT_TYPE,
TEST_TYPE_IFACE)); TEST_TYPE_IFACE));
/* Ref loads */ /* Ref loads */
class = g_type_class_ref (DYNAMIC_OBJECT_TYPE); class = g_type_class_ref (DYNAMIC_OBJECT_TYPE);
g_assert (class && class->val == 42); g_assert_nonnull (class);
g_assert (loaded); g_assert_cmpint (class->val, ==, 42);
g_assert_true (loaded);
/* Peek then works */ /* Peek then works */
class = g_type_class_peek (DYNAMIC_OBJECT_TYPE); class = g_type_class_peek (DYNAMIC_OBJECT_TYPE);
g_assert (class && class->val == 42); g_assert_nonnull (class);
g_assert (loaded); g_assert_cmpint (class->val, ==, 42);
g_assert_true (loaded);
/* Make sure interfaces still work */ /* Make sure interfaces still work */
g_assert (g_type_is_a (DYNAMIC_OBJECT_TYPE, g_assert_true (g_type_is_a (DYNAMIC_OBJECT_TYPE,
TEST_TYPE_IFACE)); TEST_TYPE_IFACE));
/* Unref causes finalize */ /* Unref causes finalize */
g_type_class_unref (class); g_type_class_unref (class);
@ -143,21 +140,26 @@ test_dynamic_type (void)
/* Peek returns NULL */ /* Peek returns NULL */
class = g_type_class_peek (DYNAMIC_OBJECT_TYPE); class = g_type_class_peek (DYNAMIC_OBJECT_TYPE);
#if 0 #if 0
g_assert (!class); /* Disabled as unloading dynamic types is disabled.
g_assert (!loaded); * See https://gitlab.gnome.org/GNOME/glib/-/issues/667 */
g_assert_false (class);
g_assert_false (loaded);
#endif #endif
/* Ref reloads */ /* Ref reloads */
class = g_type_class_ref (DYNAMIC_OBJECT_TYPE); class = g_type_class_ref (DYNAMIC_OBJECT_TYPE);
g_assert (class && class->val == 42); g_assert_nonnull (class);
g_assert (loaded); g_assert_cmpint (class->val, ==, 42);
g_assert_true (loaded);
/* And Unref causes finalize once more*/ /* And Unref causes finalize once more*/
g_type_class_unref (class); g_type_class_unref (class);
class = g_type_class_peek (DYNAMIC_OBJECT_TYPE); class = g_type_class_peek (DYNAMIC_OBJECT_TYPE);
#if 0 #if 0
g_assert (!class); /* Disabled as unloading dynamic types is disabled.
g_assert (!loaded); * See https://gitlab.gnome.org/GNOME/glib/-/issues/667 */
g_assert_null (class);
g_assert_false (loaded);
#endif #endif
} }
@ -166,10 +168,12 @@ main (int argc,
char *argv[]) char *argv[])
{ {
g_log_set_always_fatal (g_log_set_always_fatal (G_LOG_FATAL_MASK) | g_log_set_always_fatal (g_log_set_always_fatal (G_LOG_FATAL_MASK) |
G_LOG_LEVEL_WARNING | G_LOG_LEVEL_WARNING |
G_LOG_LEVEL_CRITICAL); G_LOG_LEVEL_CRITICAL);
test_dynamic_type (); g_test_init (&argc, &argv, NULL);
return 0; g_test_add_func ("/gobject/dynamic-type", test_dynamic_type);
return g_test_run ();
} }