[test/unicode] Use text fixture instead of static variables
diff --git a/src/hb-unicode-private.hh b/src/hb-unicode-private.hh
index 8337e42..34da030 100644
--- a/src/hb-unicode-private.hh
+++ b/src/hb-unicode-private.hh
@@ -1,6 +1,6 @@
/*
* Copyright © 2009 Red Hat, Inc.
- * Copyright © 2011 Codethink Limited
+ * Copyright © 2011 Codethink Limited
* Copyright © 2010,2011 Google, Inc.
*
* This is part of HarfBuzz, a text shaping library.
diff --git a/src/hb-unicode.h b/src/hb-unicode.h
index a46431b..c7e35ba 100644
--- a/src/hb-unicode.h
+++ b/src/hb-unicode.h
@@ -1,6 +1,6 @@
/*
* Copyright © 2009 Red Hat, Inc.
- * Copyright © 2011 Codethink Limited
+ * Copyright © 2011 Codethink Limited
* Copyright © 2011 Google, Inc.
*
* This is part of HarfBuzz, a text shaping library.
diff --git a/test/test-buffer.c b/test/test-buffer.c
index f9dabe6..1468bfb 100644
--- a/test/test-buffer.c
+++ b/test/test-buffer.c
@@ -26,7 +26,7 @@
#include "hb-test.h"
-/* This file tests types defined in hb-buffer.h */
+/* Unit tests for hb-buffer.h */
static const char utf8[10] = "ab\360\240\200\200defg";
diff --git a/test/test-c.c b/test/test-c.c
index a48f030..543fa7b 100644
--- a/test/test-c.c
+++ b/test/test-c.c
@@ -26,6 +26,7 @@
/* This file tests that all headers can be included from .c files */
+
#include <config.h>
#include <hb.h>
diff --git a/test/test-common.c b/test/test-common.c
index 31661f0..c2b4e1c 100644
--- a/test/test-common.c
+++ b/test/test-common.c
@@ -26,7 +26,8 @@
#include "hb-test.h"
-/* This file tests types defined in hb-common.h */
+/* Unit tests for hb-common.h */
+
static void
test_types_int (void)
diff --git a/test/test-cplusplus.cc b/test/test-cplusplus.cc
index 55a4d18..3313d74 100644
--- a/test/test-cplusplus.cc
+++ b/test/test-cplusplus.cc
@@ -26,4 +26,5 @@
/* This file tests that all headers can be included from .cc files */
+
#include "test-c.c"
diff --git a/test/test-unicode.c b/test/test-unicode.c
index 30a89be..40bb03d 100644
--- a/test/test-unicode.c
+++ b/test/test-unicode.c
@@ -1,5 +1,6 @@
/*
- * Copyright © 2011 Codethink Limited
+ * Copyright © 2011 Codethink Limited
+ * Copyright © 2011 Google, Inc.
*
* This is part of HarfBuzz, a text shaping library.
*
@@ -22,11 +23,13 @@
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*
* Codethink Author(s): Ryan Lortie
+ * Google Author(s): Behdad Esfahbod
*/
#include "hb-test.h"
-/* This file tests the unicode virtual functions interface */
+/* Unit tests for hb-unicode.h */
+
static void
test_unicode_nil (void)
@@ -54,20 +57,36 @@
g_assert_cmpint (hb_unicode_get_script (uf, 'd'), ==, HB_SCRIPT_LATIN);
}
-static gboolean freed0, freed1;
-static int unique_pointer0[1];
-static int unique_pointer1[1];
-static void free_up (void *up)
+
+#define MAGIC0 0x12345678
+#define MAGIC1 0x76543210
+
+typedef struct {
+ int value;
+ gboolean freed;
+} data_t;
+
+typedef struct {
+ data_t data[2];
+} data_fixture_t;
+static void
+data_fixture_init (data_fixture_t *f, gconstpointer user_data)
{
- if (up == unique_pointer0) {
- g_assert (!freed0);
- freed0 = TRUE;
- } else if (up == unique_pointer1) {
- g_assert (!freed1);
- freed1 = TRUE;
- } else {
- g_assert_not_reached ();
- }
+ f->data[0].value = MAGIC0;
+ f->data[1].value = MAGIC1;
+}
+static void
+data_fixture_finish (data_fixture_t *f, gconstpointer user_data)
+{
+}
+
+static void free_up (void *p)
+{
+ data_t *data = (data_t *) p;
+
+ g_assert (data->value == MAGIC0 || data->value == MAGIC1);
+ g_assert (data->freed == FALSE);
+ data->freed = TRUE;
}
static hb_script_t
@@ -75,8 +94,11 @@
hb_codepoint_t codepoint,
void *user_data)
{
+ data_t *data = (data_t *) user_data;
+
g_assert (hb_unicode_funcs_get_parent (ufuncs) == NULL);
- g_assert (unique_pointer0 == user_data);
+ g_assert (data->value == MAGIC0);
+ g_assert (data->freed == FALSE);
if ('a' <= codepoint && codepoint <= 'z')
return HB_SCRIPT_LATIN;
@@ -85,30 +107,31 @@
}
static void
-test_unicode_custom (void)
+test_unicode_custom (data_fixture_t *f, gconstpointer user_data)
{
hb_unicode_funcs_t *uf = hb_unicode_funcs_create (NULL);
hb_unicode_funcs_set_script_func (uf, simple_get_script,
- unique_pointer0, free_up);
+ &f->data[0], free_up);
g_assert_cmpint (hb_unicode_get_script (uf, 'a'), ==, HB_SCRIPT_LATIN);
g_assert_cmpint (hb_unicode_get_script (uf, '0'), ==, HB_SCRIPT_UNKNOWN);
- g_assert (!freed0 && !freed1);
+ g_assert (!f->data[0].freed && !f->data[1].freed);
hb_unicode_funcs_destroy (uf);
- g_assert (freed0 && !freed1);
- freed0 = FALSE;
+ g_assert (f->data[0].freed && !f->data[1].freed);
}
-
static hb_script_t
a_is_for_arabic_get_script (hb_unicode_funcs_t *ufuncs,
hb_codepoint_t codepoint,
void *user_data)
{
+ data_t *data = (data_t *) user_data;
+
g_assert (hb_unicode_funcs_get_parent (ufuncs) != NULL);
- g_assert (user_data == unique_pointer1);
+ g_assert (data->value == MAGIC1);
+ g_assert (data->freed == FALSE);
if (codepoint == 'a') {
return HB_SCRIPT_ARABIC;
@@ -120,7 +143,7 @@
}
static void
-test_unicode_subclassing_nil (void)
+test_unicode_subclassing_nil (data_fixture_t *f, gconstpointer user_data)
{
hb_unicode_funcs_t *uf, *aa;
@@ -131,67 +154,65 @@
hb_unicode_funcs_destroy (uf);
hb_unicode_funcs_set_script_func (aa, a_is_for_arabic_get_script,
- unique_pointer1, free_up);
+ &f->data[1], free_up);
g_assert_cmpint (hb_unicode_get_script (aa, 'a'), ==, HB_SCRIPT_ARABIC);
g_assert_cmpint (hb_unicode_get_script (aa, 'b'), ==, HB_SCRIPT_UNKNOWN);
- g_assert (!freed0 && !freed1);
+ g_assert (!f->data[0].freed && !f->data[1].freed);
hb_unicode_funcs_destroy (aa);
- g_assert (!freed0 && freed1);
- freed1 = FALSE;
+ g_assert (!f->data[0].freed && f->data[1].freed);
}
static void
-test_unicode_subclassing_glib (void)
+test_unicode_subclassing_default (data_fixture_t *f, gconstpointer user_data)
{
hb_unicode_funcs_t *uf, *aa;
- uf = hb_glib_get_unicode_funcs ();
+ uf = hb_unicode_funcs_get_default ();
aa = hb_unicode_funcs_create (uf);
hb_unicode_funcs_set_script_func (aa, a_is_for_arabic_get_script,
- unique_pointer1, free_up);
+ &f->data[1], free_up);
g_assert_cmpint (hb_unicode_get_script (aa, 'a'), ==, HB_SCRIPT_ARABIC);
g_assert_cmpint (hb_unicode_get_script (aa, 'b'), ==, HB_SCRIPT_LATIN);
- g_assert (!freed0 && !freed1);
+ g_assert (!f->data[0].freed && !f->data[1].freed);
hb_unicode_funcs_destroy (aa);
- g_assert (!freed0 && freed1);
- freed1 = FALSE;
+ g_assert (!f->data[0].freed && f->data[1].freed);
}
static void
-test_unicode_subclassing_deep (void)
+test_unicode_subclassing_deep (data_fixture_t *f, gconstpointer user_data)
{
hb_unicode_funcs_t *uf, *aa;
uf = hb_unicode_funcs_create (NULL);
hb_unicode_funcs_set_script_func (uf, simple_get_script,
- unique_pointer0, free_up);
+ &f->data[0], free_up);
aa = hb_unicode_funcs_create (uf);
hb_unicode_funcs_destroy (uf);
/* make sure the 'uf' didn't get freed, since 'aa' holds a ref */
- g_assert (!freed0);
+ g_assert (!f->data[0].freed);
hb_unicode_funcs_set_script_func (aa, a_is_for_arabic_get_script,
- unique_pointer1, free_up);
+ &f->data[1], free_up);
g_assert_cmpint (hb_unicode_get_script (aa, 'a'), ==, HB_SCRIPT_ARABIC);
g_assert_cmpint (hb_unicode_get_script (aa, 'b'), ==, HB_SCRIPT_LATIN);
g_assert_cmpint (hb_unicode_get_script (aa, '0'), ==, HB_SCRIPT_UNKNOWN);
- g_assert (!freed0 && !freed1);
+ g_assert (!f->data[0].freed && !f->data[1].freed);
hb_unicode_funcs_destroy (aa);
- g_assert (freed0 && freed1);
- freed0 = freed1 = FALSE;
+ g_assert (f->data[0].freed && f->data[1].freed);
}
+
int
main (int argc, char **argv)
{
@@ -200,10 +221,11 @@
hb_test_add (test_unicode_nil);
hb_test_add (test_unicode_glib);
hb_test_add (test_unicode_default);
- hb_test_add (test_unicode_custom);
- hb_test_add (test_unicode_subclassing_nil);
- hb_test_add (test_unicode_subclassing_glib);
- hb_test_add (test_unicode_subclassing_deep);
+
+ hb_test_add_fixture (data_fixture, NULL, test_unicode_custom);
+ hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_nil);
+ hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_default);
+ hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_deep);
/* XXX test all methods for their defaults and various (glib, icu, default) implementations. */
/* XXX test glib & icu two-way script conversion */