mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-11 23:16:14 +01:00
Convert tests/gobject/dynamictype.c to glib test framework
This commit is contained in:
parent
b61d3edc33
commit
17ddf79e1d
@ -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 ();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user