os/ossrv/glib/tsrc/BC/src/extra_tests.c
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.
sl@0
     3
*
sl@0
     4
* This library is free software; you can redistribute it and/or
sl@0
     5
* modify it under the terms of the GNU Lesser General Public
sl@0
     6
* License as published by the Free Software Foundation; either
sl@0
     7
* version 2 of the License, or (at your option) any later version.
sl@0
     8
*
sl@0
     9
* This library is distributed in the hope that it will be useful,
sl@0
    10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
sl@0
    11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
sl@0
    12
* Lesser General Public License for more details.
sl@0
    13
*
sl@0
    14
* You should have received a copy of the GNU Lesser General Public
sl@0
    15
* License along with this library; if not, write to the
sl@0
    16
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
sl@0
    17
* Boston, MA 02111-1307, USA.
sl@0
    18
*
sl@0
    19
* Description:
sl@0
    20
*
sl@0
    21
*/
sl@0
    22
sl@0
    23
sl@0
    24
sl@0
    25
#undef G_DISABLE_ASSERT
sl@0
    26
#undef G_LOG_DOMAIN
sl@0
    27
sl@0
    28
#include <stdio.h>
sl@0
    29
#include <glib.h>
sl@0
    30
#include <glib/gatomic.h>
sl@0
    31
#include <glib/galloca.h>
sl@0
    32
#include <glib/gprintf.h>
sl@0
    33
#include <glib-object.h>
sl@0
    34
sl@0
    35
#include <stdlib.h>
sl@0
    36
sl@0
    37
sl@0
    38
#ifdef SYMBIAN
sl@0
    39
#include "mrt2_glib2_test.h"
sl@0
    40
#endif /*SYMBIAN*/
sl@0
    41
sl@0
    42
#define THREADS 10
sl@0
    43
sl@0
    44
typedef enum
sl@0
    45
{
sl@0
    46
  MY_ENUM_FOO,
sl@0
    47
  MY_ENUM_BAR,
sl@0
    48
} myEnum;
sl@0
    49
sl@0
    50
typedef enum
sl@0
    51
{
sl@0
    52
  MY_FLAG_FOO = 1 << 0,
sl@0
    53
  MY_FLAG_BAR = 1 << 1,
sl@0
    54
} myFlags;
sl@0
    55
sl@0
    56
sl@0
    57
sl@0
    58
#define	TEST(m,cond)	G_STMT_START { failed = !(cond); \
sl@0
    59
if (failed) \
sl@0
    60
  { ++notpassed; \
sl@0
    61
  	assert_failed = TRUE; \
sl@0
    62
    if (!m) \
sl@0
    63
      g_print ("\n(%s:%d) failed for: %s\n", __FILE__, __LINE__, ( # cond )); \
sl@0
    64
    else \
sl@0
    65
      g_print ("\n(%s:%d) failed for: %s: (%s)\n", __FILE__, __LINE__, ( # cond ), (gchar*)m); \
sl@0
    66
  } \
sl@0
    67
else \
sl@0
    68
  ++passed;    \
sl@0
    69
  if ((passed+notpassed) % 10000 == 0) /*g_print (".")*/; fflush (stdout); \
sl@0
    70
} G_STMT_END
sl@0
    71
sl@0
    72
sl@0
    73
sl@0
    74
void g_ascii_strdown_test()
sl@0
    75
{
sl@0
    76
	gchar str[] = "ABCd";
sl@0
    77
	gchar *str1;
sl@0
    78
	str1 = g_ascii_strdown(str,4);
sl@0
    79
	g_assert(str1[0] == 'a');
sl@0
    80
	g_assert(str1[1] == 'b');
sl@0
    81
	g_assert(str1[2] == 'c');
sl@0
    82
	g_assert(str1[3] == 'd');	
sl@0
    83
}
sl@0
    84
sl@0
    85
#if 0
sl@0
    86
void g_assert_warning_test()
sl@0
    87
{
sl@0
    88
	g_assert_warning(NULL, __FILE__,__LINE__,"g_assert_warning_test","'a'== 'a'");
sl@0
    89
	#ifdef SYMBIAN
sl@0
    90
  	testResultXml("extra_test");
sl@0
    91
  	#endif /* EMULATOR */
sl@0
    92
	/*following will abort!*/
sl@0
    93
	g_assert_warning(NULL, __FILE__,__LINE__,"g_assert_warning_test","'a'== 'b'");
sl@0
    94
}
sl@0
    95
#endif
sl@0
    96
sl@0
    97
sl@0
    98
static gpointer
sl@0
    99
atomic_int_thread (gpointer data)
sl@0
   100
{
sl@0
   101
	gint* val = (gint*)data;
sl@0
   102
	g_atomic_int_set ((gint *) data,
sl@0
   103
                  (*val)+1);
sl@0
   104
sl@0
   105
	return NULL;
sl@0
   106
}
sl@0
   107
sl@0
   108
sl@0
   109
static void
sl@0
   110
test_g_atomic_int_set ()
sl@0
   111
{
sl@0
   112
  GThread *threads[THREADS];
sl@0
   113
  guint i;
sl@0
   114
  
sl@0
   115
    
sl@0
   116
  for (i = 0; i < THREADS; i++)
sl@0
   117
    {
sl@0
   118
      int data;
sl@0
   119
      data = i;
sl@0
   120
      threads[i] = g_thread_create (atomic_int_thread, 
sl@0
   121
				    &data, TRUE, NULL);      
sl@0
   122
    }
sl@0
   123
  g_usleep (G_USEC_PER_SEC * 5);
sl@0
   124
  for (i = 0; i < THREADS; i++)
sl@0
   125
    {
sl@0
   126
      g_thread_join (threads[i]);
sl@0
   127
    }
sl@0
   128
}
sl@0
   129
sl@0
   130
sl@0
   131
static gpointer
sl@0
   132
atomic_pointer_thread (gpointer data)
sl@0
   133
{
sl@0
   134
	
sl@0
   135
	g_atomic_pointer_set ((gpointer*) &data,NULL);
sl@0
   136
sl@0
   137
	return NULL;
sl@0
   138
}
sl@0
   139
sl@0
   140
sl@0
   141
static void
sl@0
   142
test_g_atomic_pointer_set ()
sl@0
   143
{
sl@0
   144
  GThread *threads[THREADS];
sl@0
   145
  guint i;
sl@0
   146
  
sl@0
   147
    
sl@0
   148
  for (i = 0; i < THREADS; i++)
sl@0
   149
    {
sl@0
   150
      int data;
sl@0
   151
      data = i;
sl@0
   152
      threads[i] = g_thread_create (atomic_pointer_thread, 
sl@0
   153
				    &data, TRUE, NULL);      
sl@0
   154
    }
sl@0
   155
  g_usleep (G_USEC_PER_SEC * 5);
sl@0
   156
  for (i = 0; i < THREADS; i++)
sl@0
   157
    {
sl@0
   158
      g_thread_join (threads[i]);
sl@0
   159
    }
sl@0
   160
}
sl@0
   161
sl@0
   162
sl@0
   163
#if 0
sl@0
   164
void test_g_get_codeset()
sl@0
   165
{
sl@0
   166
	gchar* charset =  g_get_codeset ();
sl@0
   167
    g_assert(!strcmp(charset,"US-ASCII"));
sl@0
   168
    g_free(charset);
sl@0
   169
}
sl@0
   170
#endif
sl@0
   171
sl@0
   172
sl@0
   173
void test_g_blow_chunks()
sl@0
   174
{
sl@0
   175
	gchar *name = "chunk";
sl@0
   176
	GMemChunk *mem_chunk = g_mem_chunk_new(name,2,10,G_ALLOC_ONLY);
sl@0
   177
	g_blow_chunks();
sl@0
   178
}
sl@0
   179
sl@0
   180
void test_g_date_set_time_val()
sl@0
   181
{
sl@0
   182
  GDate* d = g_date_new();
sl@0
   183
  
sl@0
   184
  GTimeVal current_time;
sl@0
   185
  g_get_current_time (&current_time);
sl@0
   186
  g_date_set_time_val(d, &current_time);
sl@0
   187
  
sl@0
   188
  g_assert(g_date_valid(d));
sl@0
   189
  
sl@0
   190
sl@0
   191
}
sl@0
   192
sl@0
   193
sl@0
   194
sl@0
   195
gboolean func1(int *data)
sl@0
   196
{
sl@0
   197
	*data = 1;
sl@0
   198
	return TRUE;
sl@0
   199
}
sl@0
   200
sl@0
   201
gboolean func2(int *data)
sl@0
   202
{
sl@0
   203
	*data = 2;
sl@0
   204
	return TRUE;
sl@0
   205
}
sl@0
   206
sl@0
   207
gboolean func3(int *data)
sl@0
   208
{
sl@0
   209
	*data = 3;
sl@0
   210
	return FALSE;
sl@0
   211
}
sl@0
   212
sl@0
   213
gboolean func4(int *data)
sl@0
   214
{
sl@0
   215
	*data = 4;
sl@0
   216
	return TRUE;
sl@0
   217
}
sl@0
   218
sl@0
   219
sl@0
   220
void hook_test()
sl@0
   221
{
sl@0
   222
	GHookList hooklist;
sl@0
   223
	GHook *hook1 = NULL,*hook2 = NULL,*hook3 = NULL,*hook4 = NULL,*temp_hook;
sl@0
   224
	int data1 = 0,data2 = 0,data3 = 0,data4 = 0;
sl@0
   225
	int comp_value;
sl@0
   226
	gboolean val;
sl@0
   227
	
sl@0
   228
	g_hook_list_init(&hooklist,sizeof(GHook));
sl@0
   229
	
sl@0
   230
	hook1 = g_hook_alloc(&hooklist);
sl@0
   231
	hook1->func = (gpointer)func1;
sl@0
   232
	hook1->data = &data1;
sl@0
   233
	
sl@0
   234
	hook2 = g_hook_alloc(&hooklist);
sl@0
   235
	hook2->func = (gpointer)func2;
sl@0
   236
	hook2->data = &data2;
sl@0
   237
	
sl@0
   238
	hook3 = g_hook_alloc(&hooklist);
sl@0
   239
	hook3->func = (gpointer)func3;
sl@0
   240
	hook3->data = &data3;
sl@0
   241
	
sl@0
   242
	hook4 = g_hook_alloc(&hooklist);
sl@0
   243
	hook4->func = (gpointer)func4;
sl@0
   244
	hook4->data = &data4;
sl@0
   245
	
sl@0
   246
	g_hook_append(&hooklist,hook1);
sl@0
   247
	g_hook_append(&hooklist,hook2);
sl@0
   248
	g_hook_append(&hooklist,hook3);
sl@0
   249
	g_hook_append(&hooklist,hook4);
sl@0
   250
	
sl@0
   251
	g_hook_list_invoke_check(&hooklist,FALSE);
sl@0
   252
	
sl@0
   253
	g_assert(data1 == 1 && data2 == 2 && data3 == 3 && data4 == 4);
sl@0
   254
	
sl@0
   255
	//now only func3 must be in hooklist
sl@0
   256
	data1 = 0,data2 = 0,data3 = 0,data4 = 0;
sl@0
   257
	g_hook_list_invoke_check(&hooklist,FALSE);
sl@0
   258
	
sl@0
   259
	//check for implemention behaviour as opposed to documented behaviour
sl@0
   260
	
sl@0
   261
	//enable this to check for documented behaviour
sl@0
   262
	//g_assert(data1 == 0 && data2 == 0 && data3 == 3 && data4 == 0);
sl@0
   263
	
sl@0
   264
	//disable this to stop checking implemented behaviour
sl@0
   265
	g_assert(data1 == 1 && data2 == 2 && data3 == 0 && data4 == 4);
sl@0
   266
	
sl@0
   267
	g_hook_list_clear(&hooklist);
sl@0
   268
	
sl@0
   269
}
sl@0
   270
sl@0
   271
void test_g_mem_chunk_alloc0()
sl@0
   272
{
sl@0
   273
	gchar *name = "chunk";
sl@0
   274
	char* pchar;
sl@0
   275
	GMemChunk *mem_chunk = g_mem_chunk_new(name,2,10,G_ALLOC_ONLY);
sl@0
   276
	gpointer data = g_mem_chunk_alloc0(mem_chunk);
sl@0
   277
	g_assert(data != NULL);
sl@0
   278
	pchar = (char*)data;
sl@0
   279
	g_assert( (*pchar) == '\0' && *(pchar+1) == '\0');
sl@0
   280
	g_mem_chunk_print(mem_chunk);
sl@0
   281
	g_mem_chunk_clean(mem_chunk);
sl@0
   282
	g_mem_chunk_destroy(mem_chunk);
sl@0
   283
}
sl@0
   284
sl@0
   285
sl@0
   286
sl@0
   287
gpointer theFunc(gpointer data)
sl@0
   288
{
sl@0
   289
	int* pval = (int*) data;
sl@0
   290
	(*pval)++;
sl@0
   291
	return NULL;
sl@0
   292
}
sl@0
   293
sl@0
   294
void test_gonce()
sl@0
   295
{
sl@0
   296
	GOnce onceObject;
sl@0
   297
	int val = 1;
sl@0
   298
	
sl@0
   299
	g_once_impl (&onceObject,theFunc, &val);
sl@0
   300
	g_once_impl (&onceObject,theFunc, &val);
sl@0
   301
	g_once_impl (&onceObject,theFunc, &val);
sl@0
   302
	g_assert(val == 2);
sl@0
   303
}
sl@0
   304
sl@0
   305
void test_g_return_if_fail_warning()
sl@0
   306
{
sl@0
   307
	//currently not exported 
sl@0
   308
	//g_return_if_fail_warning (NULL,"extra_tests::main","1== 1");
sl@0
   309
}
sl@0
   310
sl@0
   311
void test_g_slist_alloc()
sl@0
   312
{
sl@0
   313
	GSList*    pList =  g_slist_alloc();
sl@0
   314
	g_assert(pList != NULL);
sl@0
   315
	g_slist_free_1 (pList);
sl@0
   316
}
sl@0
   317
sl@0
   318
void test_g_string_insert_c()
sl@0
   319
{
sl@0
   320
	GString* string1 = g_string_new ("firstlast");
sl@0
   321
    g_string_insert_c (string1, 5, '_');
sl@0
   322
  	g_assert (strcmp (string1->str, "first_last") == 0);
sl@0
   323
  	g_string_free (string1, TRUE);
sl@0
   324
}
sl@0
   325
sl@0
   326
void test_g_strsignal()
sl@0
   327
{
sl@0
   328
	const gchar* errmsg = g_strsignal(0);
sl@0
   329
	g_assert(strcmp(errmsg, "unknown signal (0)")==0);	
sl@0
   330
}
sl@0
   331
sl@0
   332
sl@0
   333
sl@0
   334
void test_g_generictype_get_type()
sl@0
   335
{
sl@0
   336
	GType type_id, type_id2;
sl@0
   337
	int i;
sl@0
   338
	
sl@0
   339
sl@0
   340
	GType (*fnArray[])() =
sl@0
   341
	{
sl@0
   342
	g_closure_get_type,
sl@0
   343
	g_date_get_type,	
sl@0
   344
	g_gstring_get_type,	
sl@0
   345
	g_hash_table_get_type,
sl@0
   346
	g_io_channel_get_type,
sl@0
   347
	g_io_condition_get_type,
sl@0
   348
	g_strv_get_type,
sl@0
   349
	g_value_get_type,
sl@0
   350
	};
sl@0
   351
	
sl@0
   352
		
sl@0
   353
	
sl@0
   354
#define NumFns sizeof(fnArray)/sizeof(GType (*)())	
sl@0
   355
		
sl@0
   356
	for(i =0; i<NumFns;i++)
sl@0
   357
	{
sl@0
   358
		type_id =  fnArray[i]();
sl@0
   359
		g_assert(type_id != 0);
sl@0
   360
		type_id2 =  fnArray[i]();
sl@0
   361
		g_assert(type_id == type_id2);	
sl@0
   362
		//pInstance = g_type_create_instance(type_id);
sl@0
   363
		//g_assert(g_type_name(type_id) == g_type_name_from_instance(pInstance) );
sl@0
   364
	}
sl@0
   365
	
sl@0
   366
}
sl@0
   367
sl@0
   368
void test_enumClass()
sl@0
   369
{
sl@0
   370
	GType type_id = 0;
sl@0
   371
	GEnumClass* pPointer = NULL;
sl@0
   372
	GEnumValue* retrievedValue;
sl@0
   373
	static GEnumValue enum_array[] =
sl@0
   374
	{
sl@0
   375
		{ 0, "EZero", "zero"},
sl@0
   376
		{ 1, "EOne", "One"},
sl@0
   377
		{ 2, "ETwo", "Two"},
sl@0
   378
		{ 0, NULL, NULL},
sl@0
   379
	};
sl@0
   380
sl@0
   381
	//g_type_init();
sl@0
   382
sl@0
   383
	type_id =  g_enum_register_static("egEnum",enum_array);
sl@0
   384
	pPointer = g_type_class_ref(type_id);
sl@0
   385
	if(pPointer)
sl@0
   386
	{
sl@0
   387
sl@0
   388
		retrievedValue = g_enum_get_value(pPointer,1);
sl@0
   389
		g_assert(retrievedValue && retrievedValue->value == 1);
sl@0
   390
		retrievedValue = g_enum_get_value(pPointer,5);
sl@0
   391
		g_assert(retrievedValue == NULL);
sl@0
   392
sl@0
   393
		retrievedValue = g_enum_get_value_by_name(pPointer,"EOne");
sl@0
   394
		g_assert(retrievedValue && retrievedValue->value == 1);
sl@0
   395
		retrievedValue = g_enum_get_value_by_name(pPointer,"EFive");
sl@0
   396
		g_assert(retrievedValue == NULL);
sl@0
   397
sl@0
   398
		retrievedValue = g_enum_get_value_by_nick(pPointer,"One");
sl@0
   399
		g_assert(retrievedValue && retrievedValue->value == 1);
sl@0
   400
		retrievedValue = g_enum_get_value_by_nick(pPointer,"Five");
sl@0
   401
		g_assert(retrievedValue == NULL);
sl@0
   402
sl@0
   403
	}
sl@0
   404
}//fn
sl@0
   405
sl@0
   406
sl@0
   407
void test_flagsClass()
sl@0
   408
{
sl@0
   409
	GType type_id = 0;
sl@0
   410
	GFlagsClass* pPointer = NULL;
sl@0
   411
	GFlagsValue* retrievedValue;
sl@0
   412
	static GFlagsValue flags_array[] =
sl@0
   413
	{
sl@0
   414
		{ 1, "EOne", "One"},
sl@0
   415
		{ 2, "ETwo", "Two"},
sl@0
   416
		{ 4, "EFour", "Four"},
sl@0
   417
		{ 0, NULL, NULL},
sl@0
   418
	};
sl@0
   419
sl@0
   420
	//g_type_init();
sl@0
   421
sl@0
   422
	type_id =  g_flags_register_static("egFlags",flags_array);
sl@0
   423
	pPointer = g_type_class_ref(type_id);
sl@0
   424
	if(pPointer)
sl@0
   425
	{
sl@0
   426
sl@0
   427
		retrievedValue = g_flags_get_value_by_name(pPointer,"EOne");
sl@0
   428
		g_assert(retrievedValue && retrievedValue->value == 1);
sl@0
   429
		retrievedValue = g_flags_get_value_by_name(pPointer,"EFive");
sl@0
   430
		g_assert(retrievedValue == NULL);
sl@0
   431
sl@0
   432
		retrievedValue = g_flags_get_value_by_nick(pPointer,"One");
sl@0
   433
		g_assert(retrievedValue && retrievedValue->value == 1);
sl@0
   434
		retrievedValue = g_flags_get_value_by_nick(pPointer,"Five");
sl@0
   435
		g_assert(retrievedValue == NULL);
sl@0
   436
	}
sl@0
   437
}//fn
sl@0
   438
sl@0
   439
sl@0
   440
sl@0
   441
int main (int   argc,
sl@0
   442
      char *argv[])
sl@0
   443
{
sl@0
   444
	#ifdef SYMBIAN
sl@0
   445
	int handler = 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
   446
	#endif /*SYMBIAN*/
sl@0
   447
sl@0
   448
	g_thread_init(NULL);	
sl@0
   449
	g_type_init();
sl@0
   450
	
sl@0
   451
	g_ascii_strdown_test();
sl@0
   452
    test_g_atomic_int_set();
sl@0
   453
    test_g_atomic_pointer_set();
sl@0
   454
sl@0
   455
	//test_g_get_codeset();    
sl@0
   456
	test_g_blow_chunks();
sl@0
   457
	test_g_date_set_time_val();
sl@0
   458
	hook_test();
sl@0
   459
	
sl@0
   460
	test_g_mem_chunk_alloc0();
sl@0
   461
	test_gonce();
sl@0
   462
	//test_g_return_if_fail_warning ();
sl@0
   463
	test_g_slist_alloc();
sl@0
   464
	test_g_string_insert_c();
sl@0
   465
	test_g_strsignal();
sl@0
   466
	
sl@0
   467
	test_g_generictype_get_type();
sl@0
   468
	
sl@0
   469
	test_enumClass();
sl@0
   470
 	test_flagsClass();
sl@0
   471
	
sl@0
   472
	
sl@0
   473
	
sl@0
   474
	//test 
sl@0
   475
	#ifdef SYMBIAN
sl@0
   476
	g_log_remove_handler (NULL, handler);
sl@0
   477
	g_warning("This test message should have been printed on console\n");
sl@0
   478
	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
   479
	#endif /*SYMBIAN*/
sl@0
   480
	
sl@0
   481
    
sl@0
   482
		
sl@0
   483
	//g_assert_warning_test();
sl@0
   484
	
sl@0
   485
	#ifdef SYMBIAN
sl@0
   486
  	testResultXml("extra_tests");
sl@0
   487
  	#endif /* EMULATOR */
sl@0
   488
	
sl@0
   489
	return 0;
sl@0
   490
}