sl@0: /* Portion Copyright © 2008-09 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. */ sl@0: #include sl@0: #include sl@0: #include sl@0: sl@0: sl@0: #ifdef SYMBIAN sl@0: #include sl@0: #include "mrt2_glib2_test.h" sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: sl@0: #define G_TYPE_TEST (g_test_get_type ()) sl@0: #define G_TEST(test) (G_TYPE_CHECK_INSTANCE_CAST ((test), G_TYPE_TEST, GTest)) sl@0: #define G_IS_TEST(test) (G_TYPE_CHECK_INSTANCE_TYPE ((test), G_TYPE_TEST)) sl@0: #define G_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_CAST ((tclass), G_TYPE_TEST, GTestClass)) sl@0: #define G_IS_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_TYPE ((tclass), G_TYPE_TEST)) sl@0: #define G_TEST_GET_CLASS(test) (G_TYPE_INSTANCE_GET_CLASS ((test), G_TYPE_TEST, GTestClass)) sl@0: sl@0: typedef struct _GTest GTest; sl@0: typedef struct _GTestClass GTestClass; sl@0: sl@0: struct _GTest sl@0: { sl@0: GObject object; sl@0: }; sl@0: sl@0: struct _GTestClass sl@0: { sl@0: GObjectClass parent_class; sl@0: }; sl@0: sl@0: static GType g_test_get_type (void); sl@0: static volatile gboolean stopping; sl@0: sl@0: static void g_test_class_init (GTestClass * klass); sl@0: static void g_test_init (GTest * test); sl@0: static void g_test_dispose (GObject * object); sl@0: sl@0: static GObjectClass *parent_class = NULL; sl@0: sl@0: static GType sl@0: g_test_get_type (void) sl@0: { sl@0: static GType test_type = 0; sl@0: sl@0: if (!test_type) { sl@0: static const GTypeInfo test_info = { sl@0: sizeof (GTestClass), sl@0: NULL, sl@0: NULL, sl@0: (GClassInitFunc) g_test_class_init, sl@0: NULL, sl@0: NULL, sl@0: sizeof (GTest), sl@0: 0, sl@0: (GInstanceInitFunc) g_test_init, sl@0: NULL sl@0: }; sl@0: sl@0: test_type = g_type_register_static (G_TYPE_OBJECT, "GTest", sl@0: &test_info, 0); sl@0: } sl@0: return test_type; sl@0: } sl@0: sl@0: static void sl@0: g_test_class_init (GTestClass * klass) sl@0: { sl@0: GObjectClass *gobject_class; sl@0: sl@0: gobject_class = (GObjectClass *) klass; sl@0: sl@0: parent_class = g_type_class_ref (G_TYPE_OBJECT); sl@0: sl@0: gobject_class->dispose = g_test_dispose; sl@0: } sl@0: sl@0: static void sl@0: g_test_init (GTest * test) sl@0: { sl@0: //g_print ("init %p\n", test); sl@0: } sl@0: sl@0: static void sl@0: g_test_dispose (GObject * object) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: //g_print ("dispose %p!\n", object); sl@0: sl@0: G_OBJECT_CLASS (parent_class)->dispose (object); sl@0: } sl@0: sl@0: static void sl@0: g_test_do_refcount (GTest * test) sl@0: { sl@0: g_object_ref (test); sl@0: g_object_unref (test); sl@0: } sl@0: sl@0: static gpointer sl@0: run_thread (GTest * test) sl@0: { sl@0: gint i = 1; sl@0: sl@0: while (!stopping) { sl@0: g_test_do_refcount (test); sl@0: if ((i++ % 10000) == 0) { sl@0: //g_print ("."); sl@0: g_thread_yield(); /* force context switch */ sl@0: } sl@0: } sl@0: sl@0: return NULL; sl@0: } sl@0: sl@0: int sl@0: main (int argc, char **argv) sl@0: { sl@0: gint i; sl@0: GTest *test1, *test2; sl@0: GArray *test_threads; sl@0: const guint n_threads = 5; sl@0: sl@0: #ifdef SYMBIAN sl@0: sl@0: g_log_set_handler (NULL, G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION | G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_MESSAGE | G_LOG_LEVEL_INFO | G_LOG_LEVEL_DEBUG, &mrtLogHandler, NULL); sl@0: g_set_print_handler(mrtPrintHandler); sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: g_thread_init (NULL); sl@0: //g_print ("START: %s\n", argv[0]); sl@0: g_log_set_always_fatal (G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL | g_log_set_always_fatal (G_LOG_FATAL_MASK)); sl@0: g_type_init (); sl@0: sl@0: test1 = g_object_new (G_TYPE_TEST, NULL); sl@0: g_assert(test1 != NULL); sl@0: sl@0: test2 = g_object_new (G_TYPE_TEST, NULL); sl@0: g_assert(test2 != NULL); sl@0: sl@0: test_threads = g_array_new (FALSE, FALSE, sizeof (GThread *)); sl@0: sl@0: stopping = FALSE; sl@0: sl@0: for (i = 0; i < n_threads; i++) { sl@0: GThread *thread; sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test1, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test2, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: } sl@0: g_usleep (5000000); sl@0: sl@0: stopping = TRUE; sl@0: sl@0: //g_print ("\nstopping\n"); sl@0: sl@0: /* join all threads */ sl@0: for (i = 0; i < 2 * n_threads; i++) { sl@0: GThread *thread; sl@0: sl@0: thread = g_array_index (test_threads, GThread *, i); sl@0: g_thread_join (thread); sl@0: } sl@0: sl@0: //g_print ("stopped\n"); sl@0: #ifdef SYMBIAN sl@0: testResultXml("objects"); sl@0: #endif /* EMULATOR */ sl@0: sl@0: return 0; sl@0: }