Merge remote branch 'gvdb/master'
[platform/upstream/glib.git] / glib / tests / array-test.c
1 /* GLIB - Library of useful routines for C programming
2  * Copyright (C) 1995-1997  Peter Mattis, Spencer Kimball and Josh MacDonald
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */
19
20 /*
21  * Modified by the GLib Team and others 1997-2000.  See the AUTHORS
22  * file for a list of people on the GLib Team.  See the ChangeLog
23  * files for a list of changes.  These files are distributed with
24  * GLib at ftp://ftp.gtk.org/pub/gtk/. 
25  */
26
27 #undef G_DISABLE_ASSERT
28 #undef G_LOG_DOMAIN
29
30 #include <stdio.h>
31 #include <stdlib.h>
32 #include <string.h>
33 #include "glib.h"
34
35 static void
36 sum_up (gpointer data,
37         gpointer user_data)
38 {
39   gint *sum = (gint *)user_data;
40
41   *sum += GPOINTER_TO_INT (data);
42 }
43
44 static void
45 array_append (void)
46 {
47   GArray *garray;
48   gint i;
49   gint *segment;
50
51   garray = g_array_new (FALSE, FALSE, sizeof (gint));
52   for (i = 0; i < 10000; i++)
53     g_array_append_val (garray, i);
54
55   for (i = 0; i < 10000; i++)
56     g_assert_cmpint (g_array_index (garray, gint, i), ==, i);
57
58   segment = (gint*)g_array_free (garray, FALSE);
59   for (i = 0; i < 10000; i++)
60     g_assert_cmpint (segment[i], ==, i);
61   g_free (segment);
62 }
63
64 static void
65 array_prepend (void)
66 {
67   GArray *garray;
68   gint i;
69
70   garray = g_array_new (FALSE, FALSE, sizeof (gint));
71   for (i = 0; i < 100; i++)
72     g_array_prepend_val (garray, i);
73
74   for (i = 0; i < 100; i++)
75     g_assert_cmpint (g_array_index (garray, gint, i), ==, (100 - i - 1));
76
77   g_array_free (garray, TRUE);
78 }
79
80 static void
81 array_remove (void)
82 {
83   GArray *garray;
84   gint i;
85   gint prev, cur;
86
87   garray = g_array_new (FALSE, FALSE, sizeof (gint));
88   for (i = 0; i < 100; i++)
89     g_array_append_val (garray, i);
90
91   g_assert_cmpint (garray->len, ==, 100);
92
93   g_array_remove_index (garray, 1);
94   g_array_remove_index (garray, 3);
95   g_array_remove_index (garray, 21);
96   g_array_remove_index (garray, 57);
97
98   g_assert_cmpint (garray->len, ==, 96);
99
100   prev = -1;
101   for (i = 0; i < garray->len; i++)
102     {
103       cur = g_array_index (garray, gint, i);
104       g_assert (cur != 1 &&  cur != 4 && cur != 23 && cur != 60);
105       g_assert_cmpint (prev, <, cur);
106       prev = cur;
107     }
108
109   g_array_free (garray, TRUE);
110 }
111
112 static void
113 array_remove_fast (void)
114 {
115   GArray *garray;
116   gint i;
117   gint prev, cur;
118
119   garray = g_array_new (FALSE, FALSE, sizeof (gint));
120   for (i = 0; i < 100; i++)
121     g_array_append_val (garray, i);
122
123   g_assert_cmpint (garray->len, ==, 100);
124
125   g_array_remove_index_fast (garray, 1);
126   g_array_remove_index_fast (garray, 3);
127   g_array_remove_index_fast (garray, 21);
128   g_array_remove_index_fast (garray, 57);
129
130   g_assert_cmpint (garray->len, ==, 96);
131
132   prev = -1;
133   for (i = 0; i < garray->len; i++)
134     {
135       cur = g_array_index (garray, gint, i);
136       g_assert (cur != 1 &&  cur != 3 && cur != 21 && cur != 57);
137       if (cur < 96)
138         {
139           g_assert_cmpint (prev, <, cur);
140           prev = cur;
141         }
142     }
143
144   g_array_free (garray, TRUE);
145 }
146
147 static void
148 array_remove_range (void)
149 {
150   GArray *garray;
151   gint i;
152   gint prev, cur;
153
154   garray = g_array_new (FALSE, FALSE, sizeof (gint));
155   for (i = 0; i < 100; i++)
156     g_array_append_val (garray, i);
157
158   g_assert_cmpint (garray->len, ==, 100);
159
160   g_array_remove_range (garray, 31, 4);
161
162   g_assert_cmpint (garray->len, ==, 96);
163
164   prev = -1;
165   for (i = 0; i < garray->len; i++)
166     {
167       cur = g_array_index (garray, gint, i);
168       g_assert (cur < 31 || cur > 34);
169       g_assert_cmpint (prev, <, cur);
170       prev = cur;
171     }
172
173   g_array_free (garray, TRUE);
174 }
175
176 static void
177 array_ref_count (void)
178 {
179   GArray *garray;
180   GArray *garray2;
181   gint i;
182
183   garray = g_array_new (FALSE, FALSE, sizeof (gint));
184   g_assert_cmpint (g_array_get_element_size (garray), ==, sizeof (gint));
185   for (i = 0; i < 100; i++)
186     g_array_prepend_val (garray, i);
187
188   /* check we can ref, unref and still access the array */
189   garray2 = g_array_ref (garray);
190   g_assert (garray == garray2);
191   g_array_unref (garray2);
192   for (i = 0; i < 100; i++)
193     g_assert_cmpint (g_array_index (garray, gint, i), ==, (100 - i - 1));
194
195   /* garray2 should be an empty valid GArray wrapper */
196   garray2 = g_array_ref (garray);
197   g_array_free (garray, TRUE);
198
199   g_assert_cmpint (garray2->len, ==, 0);
200   g_array_unref (garray2);
201 }
202
203 static gpointer
204 array_large_size_remalloc_impl (gpointer mem,
205                                 gsize n_bytes)
206 {
207   /* We only care that g_array_set_size() doesn't hang; we'll never
208    * actually use any of the 2G of memory that it requests, so it's
209    * OK that we don't actually allocate the whole thing.
210    */
211   return realloc (mem, MIN (n_bytes, 1024 * 1024));
212 }
213
214 static GMemVTable array_large_size_mem_vtable = {
215   malloc, array_large_size_remalloc_impl, free,
216   NULL, NULL, NULL
217 };
218
219 static void
220 array_large_size (void)
221 {
222   GArray* array;
223
224   g_test_bug ("568760");
225
226   array = g_array_new (FALSE, FALSE, sizeof (char));
227
228   if (g_test_trap_fork (5 /* s */ * 1000 /* ms */ * 1000 /* µs */, 0))
229     {
230       g_mem_set_vtable (&array_large_size_mem_vtable);
231       g_array_set_size (array, 1073750016);
232       exit (0); /* success */
233     }
234   g_test_trap_assert_passed ();
235
236   g_array_free (array, TRUE);
237 }
238
239 static int
240 int_compare (gconstpointer p1, gconstpointer p2)
241 {
242   const gint *i1 = p1;
243   const gint *i2 = p2;
244
245   return *i1 - *i2;
246 }
247
248 static int
249 int_compare_data (gconstpointer p1, gconstpointer p2, gpointer data)
250 {
251   const gint *i1 = p1;
252   const gint *i2 = p2;
253
254   return *i1 - *i2;
255 }
256 static void
257 array_sort (void)
258 {
259   GArray *garray;
260   gint i;
261   gint prev, cur;
262
263   garray = g_array_new (FALSE, FALSE, sizeof (gint));
264   for (i = 0; i < 10000; i++)
265     {
266       cur = g_random_int_range (0, 10000);
267       g_array_append_val (garray, cur);
268     }
269   g_array_sort (garray,  int_compare);
270
271   prev = -1;
272   for (i = 0; i < garray->len; i++)
273     {
274       cur = g_array_index (garray, gint, i);
275       g_assert_cmpint (prev, <=, cur);
276       prev = cur;
277     }
278
279   g_array_free (garray, TRUE);
280 }
281
282 static void
283 array_sort_with_data (void)
284 {
285   GArray *garray;
286   gint i;
287   gint prev, cur;
288
289   garray = g_array_new (FALSE, FALSE, sizeof (gint));
290   for (i = 0; i < 10000; i++)
291     {
292       cur = g_random_int_range (0, 10000);
293       g_array_append_val (garray, cur);
294     }
295   g_array_sort_with_data (garray, int_compare_data, NULL);
296
297   prev = -1;
298   for (i = 0; i < garray->len; i++)
299     {
300       cur = g_array_index (garray, gint, i);
301       g_assert_cmpint (prev, <=, cur);
302       prev = cur;
303     }
304
305   g_array_free (garray, TRUE);
306 }
307
308 static void
309 pointer_array_add (void)
310 {
311   GPtrArray *gparray;
312   gint i;
313   gint sum = 0;
314   gpointer *segment;
315
316   gparray = g_ptr_array_sized_new (1000);
317
318   for (i = 0; i < 10000; i++)
319     g_ptr_array_add (gparray, GINT_TO_POINTER (i));
320
321   for (i = 0; i < 10000; i++)
322     g_assert (g_ptr_array_index (gparray, i) == GINT_TO_POINTER (i));
323   
324   g_ptr_array_foreach (gparray, sum_up, &sum);
325   g_assert (sum == 49995000);
326
327   segment = g_ptr_array_free (gparray, FALSE);
328   for (i = 0; i < 10000; i++)
329     g_assert (segment[i] == GINT_TO_POINTER (i));
330   g_free (segment);
331 }
332
333 static void
334 pointer_array_ref_count (void)
335 {
336   GPtrArray *gparray;
337   GPtrArray *gparray2;
338   gint i;
339   gint sum = 0;
340
341   gparray = g_ptr_array_new ();
342   for (i = 0; i < 10000; i++)
343     g_ptr_array_add (gparray, GINT_TO_POINTER (i));
344
345   /* check we can ref, unref and still access the array */
346   gparray2 = g_ptr_array_ref (gparray);
347   g_assert (gparray == gparray2);
348   g_ptr_array_unref (gparray2);
349   for (i = 0; i < 10000; i++)
350     g_assert (g_ptr_array_index (gparray, i) == GINT_TO_POINTER (i));
351
352   g_ptr_array_foreach (gparray, sum_up, &sum);
353   g_assert (sum == 49995000);
354
355   /* gparray2 should be an empty valid GPtrArray wrapper */
356   gparray2 = g_ptr_array_ref (gparray);
357   g_ptr_array_free (gparray, TRUE);
358
359   g_assert_cmpint (gparray2->len, ==, 0);
360   g_ptr_array_unref (gparray2);
361 }
362
363 static gint num_free_func_invocations = 0;
364
365 static void
366 my_free_func (gpointer data)
367 {
368   num_free_func_invocations++;
369   g_free (data);
370 }
371
372 static void
373 pointer_array_free_func (void)
374 {
375   GPtrArray *gparray;
376   GPtrArray *gparray2;
377   gchar **strv;
378   gchar *s;
379
380   num_free_func_invocations = 0;
381   gparray = g_ptr_array_new_with_free_func (my_free_func);
382   g_ptr_array_unref (gparray);
383   g_assert_cmpint (num_free_func_invocations, ==, 0);
384
385   gparray = g_ptr_array_new_with_free_func (my_free_func);
386   g_ptr_array_free (gparray, TRUE);
387   g_assert_cmpint (num_free_func_invocations, ==, 0);
388
389   num_free_func_invocations = 0;
390   gparray = g_ptr_array_new_with_free_func (my_free_func);
391   g_ptr_array_add (gparray, g_strdup ("foo"));
392   g_ptr_array_add (gparray, g_strdup ("bar"));
393   g_ptr_array_add (gparray, g_strdup ("baz"));
394   g_ptr_array_remove_index (gparray, 0);
395   g_assert_cmpint (num_free_func_invocations, ==, 1);
396   s = g_strdup ("frob");
397   g_ptr_array_add (gparray, s);
398   g_assert (g_ptr_array_remove (gparray, s));
399   g_assert_cmpint (num_free_func_invocations, ==, 2);
400   g_ptr_array_set_size (gparray, 1);
401   g_assert_cmpint (num_free_func_invocations, ==, 3);
402   g_ptr_array_ref (gparray);
403   g_ptr_array_unref (gparray);
404   g_assert_cmpint (num_free_func_invocations, ==, 3);
405   g_ptr_array_unref (gparray);
406   g_assert_cmpint (num_free_func_invocations, ==, 4);
407
408   num_free_func_invocations = 0;
409   gparray = g_ptr_array_new_with_free_func (my_free_func);
410   g_ptr_array_add (gparray, g_strdup ("foo"));
411   g_ptr_array_add (gparray, g_strdup ("bar"));
412   g_ptr_array_add (gparray, g_strdup ("baz"));
413   g_ptr_array_add (gparray, NULL);
414   gparray2 = g_ptr_array_ref (gparray);
415   strv = (gchar **) g_ptr_array_free (gparray, FALSE);
416   g_assert_cmpint (num_free_func_invocations, ==, 0);
417   g_strfreev (strv);
418   g_ptr_array_unref (gparray2);
419   g_assert_cmpint (num_free_func_invocations, ==, 0);
420
421   num_free_func_invocations = 0;
422   gparray = g_ptr_array_new_with_free_func (my_free_func);
423   g_ptr_array_add (gparray, g_strdup ("foo"));
424   g_ptr_array_add (gparray, g_strdup ("bar"));
425   g_ptr_array_add (gparray, g_strdup ("baz"));
426   g_ptr_array_unref (gparray);
427   g_assert_cmpint (num_free_func_invocations, ==, 3);
428
429   num_free_func_invocations = 0;
430   gparray = g_ptr_array_new_with_free_func (my_free_func);
431   g_ptr_array_add (gparray, g_strdup ("foo"));
432   g_ptr_array_add (gparray, g_strdup ("bar"));
433   g_ptr_array_add (gparray, g_strdup ("baz"));
434   g_ptr_array_free (gparray, TRUE);
435   g_assert_cmpint (num_free_func_invocations, ==, 3);
436
437   num_free_func_invocations = 0;
438   gparray = g_ptr_array_new_with_free_func (my_free_func);
439   g_ptr_array_add (gparray, "foo");
440   g_ptr_array_add (gparray, "bar");
441   g_ptr_array_add (gparray, "baz");
442   g_ptr_array_set_free_func (gparray, NULL);
443   g_ptr_array_free (gparray, TRUE);
444   g_assert_cmpint (num_free_func_invocations, ==, 0);
445 }
446
447 static gint
448 ptr_compare (gconstpointer p1, gconstpointer p2)
449 {
450   gpointer i1 = *(gpointer*)p1;
451   gpointer i2 = *(gpointer*)p2;
452
453   return GPOINTER_TO_INT (i1) - GPOINTER_TO_INT (i2);
454 }
455
456 static gint
457 ptr_compare_data (gconstpointer p1, gconstpointer p2, gpointer data)
458 {
459   gpointer i1 = *(gpointer*)p1;
460   gpointer i2 = *(gpointer*)p2;
461
462   return GPOINTER_TO_INT (i1) - GPOINTER_TO_INT (i2);
463 }
464
465 static void
466 pointer_array_sort (void)
467 {
468   GPtrArray *gparray;
469   gint i;
470   gint val;
471   gint prev, cur;
472
473   gparray = g_ptr_array_new ();
474   for (i = 0; i < 10000; i++)
475     {
476       val = g_random_int_range (0, 10000);
477       g_ptr_array_add (gparray, GINT_TO_POINTER (val));
478     }
479
480   g_ptr_array_sort (gparray, ptr_compare);
481
482   prev = -1;
483   for (i = 0; i < 10000; i++)
484     {
485       cur = GPOINTER_TO_INT (g_ptr_array_index (gparray, i));
486       g_assert_cmpint (prev, <=, cur);
487       prev = cur;
488     }
489
490   g_ptr_array_free (gparray, TRUE);
491 }
492
493 static void
494 pointer_array_sort_with_data (void)
495 {
496   GPtrArray *gparray;
497   gint i;
498   gint prev, cur;
499
500   gparray = g_ptr_array_new ();
501   for (i = 0; i < 10000; i++)
502     g_ptr_array_add (gparray, GINT_TO_POINTER (g_random_int_range (0, 10000)));
503
504   g_ptr_array_sort_with_data (gparray, ptr_compare_data, NULL);
505
506   prev = -1;
507   for (i = 0; i < 10000; i++)
508     {
509       cur = GPOINTER_TO_INT (g_ptr_array_index (gparray, i));
510       g_assert_cmpint (prev, <=, cur);
511       prev = cur;
512     }
513
514   g_ptr_array_free (gparray, TRUE);
515 }
516
517 static void
518 byte_array_append (void)
519 {
520   GByteArray *gbarray;
521   gint i;
522   guint8 *segment;
523
524   gbarray = g_byte_array_sized_new (1000);
525   for (i = 0; i < 10000; i++)
526     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
527
528   for (i = 0; i < 10000; i++)
529     {
530       g_assert (gbarray->data[4*i] == 'a');
531       g_assert (gbarray->data[4*i+1] == 'b');
532       g_assert (gbarray->data[4*i+2] == 'c');
533       g_assert (gbarray->data[4*i+3] == 'd');
534     }
535
536   segment = g_byte_array_free (gbarray, FALSE);
537
538   for (i = 0; i < 10000; i++)
539     {
540       g_assert (segment[4*i] == 'a');
541       g_assert (segment[4*i+1] == 'b');
542       g_assert (segment[4*i+2] == 'c');
543       g_assert (segment[4*i+3] == 'd');
544     }
545
546   g_free (segment);
547 }
548
549 static void
550 byte_array_prepend (void)
551 {
552   GByteArray *gbarray;
553   gint i;
554
555   gbarray = g_byte_array_new ();
556   g_byte_array_set_size (gbarray, 1000);
557
558   for (i = 0; i < 10000; i++)
559     g_byte_array_prepend (gbarray, (guint8*) "abcd", 4);
560
561   for (i = 0; i < 10000; i++)
562     {
563       g_assert (gbarray->data[4*i] == 'a');
564       g_assert (gbarray->data[4*i+1] == 'b');
565       g_assert (gbarray->data[4*i+2] == 'c');
566       g_assert (gbarray->data[4*i+3] == 'd');
567     }
568
569   g_byte_array_free (gbarray, TRUE);
570 }
571
572 static void
573 byte_array_ref_count (void)
574 {
575   GByteArray *gbarray;
576   GByteArray *gbarray2;
577   gint i;
578
579   gbarray = g_byte_array_new ();
580   for (i = 0; i < 10000; i++)
581     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
582
583   gbarray2 = g_byte_array_ref (gbarray);
584   g_assert (gbarray2 == gbarray);
585   g_byte_array_unref (gbarray2);
586   for (i = 0; i < 10000; i++)
587     {
588       g_assert (gbarray->data[4*i] == 'a');
589       g_assert (gbarray->data[4*i+1] == 'b');
590       g_assert (gbarray->data[4*i+2] == 'c');
591       g_assert (gbarray->data[4*i+3] == 'd');
592     }
593
594   gbarray2 = g_byte_array_ref (gbarray);
595   g_assert (gbarray2 == gbarray);
596   g_byte_array_free (gbarray, TRUE);
597   g_assert_cmpint (gbarray2->len, ==, 0);
598   g_byte_array_unref (gbarray2);
599 }
600
601 static void
602 byte_array_remove (void)
603 {
604   GByteArray *gbarray;
605   gint i;
606
607   gbarray = g_byte_array_new ();
608   for (i = 0; i < 100; i++)
609     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
610
611   g_assert_cmpint (gbarray->len, ==, 400);
612
613   g_byte_array_remove_index (gbarray, 4);
614   g_byte_array_remove_index (gbarray, 4);
615   g_byte_array_remove_index (gbarray, 4);
616   g_byte_array_remove_index (gbarray, 4);
617
618   g_assert_cmpint (gbarray->len, ==, 396);
619
620   for (i = 0; i < 99; i++)
621     {
622       g_assert (gbarray->data[4*i] == 'a');
623       g_assert (gbarray->data[4*i+1] == 'b');
624       g_assert (gbarray->data[4*i+2] == 'c');
625       g_assert (gbarray->data[4*i+3] == 'd');
626     }
627
628   g_byte_array_free (gbarray, TRUE);
629 }
630
631 static void
632 byte_array_remove_fast (void)
633 {
634   GByteArray *gbarray;
635   gint i;
636
637   gbarray = g_byte_array_new ();
638   for (i = 0; i < 100; i++)
639     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
640
641   g_assert_cmpint (gbarray->len, ==, 400);
642
643   g_byte_array_remove_index_fast (gbarray, 4);
644   g_byte_array_remove_index_fast (gbarray, 4);
645   g_byte_array_remove_index_fast (gbarray, 4);
646   g_byte_array_remove_index_fast (gbarray, 4);
647
648   g_assert_cmpint (gbarray->len, ==, 396);
649
650   for (i = 0; i < 99; i++)
651     {
652       g_assert (gbarray->data[4*i] == 'a');
653       g_assert (gbarray->data[4*i+1] == 'b');
654       g_assert (gbarray->data[4*i+2] == 'c');
655       g_assert (gbarray->data[4*i+3] == 'd');
656     }
657
658   g_byte_array_free (gbarray, TRUE);
659 }
660
661 static void
662 byte_array_remove_range (void)
663 {
664   GByteArray *gbarray;
665   gint i;
666
667   gbarray = g_byte_array_new ();
668   for (i = 0; i < 100; i++)
669     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
670
671   g_assert_cmpint (gbarray->len, ==, 400);
672
673   g_byte_array_remove_range (gbarray, 12, 4);
674
675   g_assert_cmpint (gbarray->len, ==, 396);
676
677   for (i = 0; i < 99; i++)
678     {
679       g_assert (gbarray->data[4*i] == 'a');
680       g_assert (gbarray->data[4*i+1] == 'b');
681       g_assert (gbarray->data[4*i+2] == 'c');
682       g_assert (gbarray->data[4*i+3] == 'd');
683     }
684
685   g_byte_array_free (gbarray, TRUE);
686 }
687
688 static int
689 byte_compare (gconstpointer p1, gconstpointer p2)
690 {
691   const guint8 *i1 = p1;
692   const guint8 *i2 = p2;
693
694   return *i1 - *i2;
695 }
696
697 static int
698 byte_compare_data (gconstpointer p1, gconstpointer p2, gpointer data)
699 {
700   const guint8 *i1 = p1;
701   const guint8 *i2 = p2;
702
703   return *i1 - *i2;
704 }
705
706 static void
707 byte_array_sort (void)
708 {
709   GByteArray *gbarray;
710   gint i;
711   guint8 val;
712   guint8 prev, cur;
713
714   gbarray = g_byte_array_new ();
715   for (i = 0; i < 100; i++)
716     {
717       val = 'a' + g_random_int_range (0, 26);
718       g_byte_array_append (gbarray, (guint8*) &val, 1);
719     }
720
721   g_byte_array_sort (gbarray, byte_compare);
722
723   prev = 'a';
724   for (i = 0; i < gbarray->len; i++)
725     {
726       cur = gbarray->data[i];
727       g_assert_cmpint (prev, <=, cur);
728       prev = cur;
729     }
730
731   g_byte_array_free (gbarray, TRUE);
732 }
733
734 static void
735 byte_array_sort_with_data (void)
736 {
737   GByteArray *gbarray;
738   gint i;
739   guint8 val;
740   guint8 prev, cur;
741
742   gbarray = g_byte_array_new ();
743   for (i = 0; i < 100; i++)
744     {
745       val = 'a' + g_random_int_range (0, 26);
746       g_byte_array_append (gbarray, (guint8*) &val, 1);
747     }
748
749   g_byte_array_sort_with_data (gbarray, byte_compare_data, NULL);
750
751   prev = 'a';
752   for (i = 0; i < gbarray->len; i++)
753     {
754       cur = gbarray->data[i];
755       g_assert_cmpint (prev, <=, cur);
756       prev = cur;
757     }
758
759   g_byte_array_free (gbarray, TRUE);
760 }
761
762 int
763 main (int argc, char *argv[])
764 {
765   g_test_init (&argc, &argv, NULL);
766
767   g_test_bug_base ("http://bugs.gnome.org/%s");
768
769   /* array tests */
770   g_test_add_func ("/array/append", array_append);
771   g_test_add_func ("/array/prepend", array_prepend);
772   g_test_add_func ("/array/remove", array_remove);
773   g_test_add_func ("/array/remove-fast", array_remove_fast);
774   g_test_add_func ("/array/remove-range", array_remove_range);
775   g_test_add_func ("/array/ref-count", array_ref_count);
776   g_test_add_func ("/array/large-size", array_large_size);
777   g_test_add_func ("/array/sort", array_sort);
778   g_test_add_func ("/array/sort-with-data", array_sort_with_data);
779
780   /* pointer arrays */
781   g_test_add_func ("/pointerarray/add", pointer_array_add);
782   g_test_add_func ("/pointerarray/ref-count", pointer_array_ref_count);
783   g_test_add_func ("/pointerarray/free-func", pointer_array_free_func);
784   g_test_add_func ("/pointerarray/sort", pointer_array_sort);
785   g_test_add_func ("/pointerarray/sort-with-data", pointer_array_sort_with_data);
786
787   /* byte arrays */
788   g_test_add_func ("/bytearray/append", byte_array_append);
789   g_test_add_func ("/bytearray/prepend", byte_array_prepend);
790   g_test_add_func ("/bytearray/remove", byte_array_remove);
791   g_test_add_func ("/bytearray/remove-fast", byte_array_remove_fast);
792   g_test_add_func ("/bytearray/remove-range", byte_array_remove_range);
793   g_test_add_func ("/bytearray/ref-count", byte_array_ref_count);
794   g_test_add_func ("/bytearray/sort", byte_array_sort);
795   g_test_add_func ("/bytearray/sort-with-data", byte_array_sort_with_data);
796
797   return g_test_run ();
798 }
799