[test/unicode] Test Unicode 5.2+ but don't fail

This commit is contained in:
Behdad Esfahbod 2011-05-02 14:03:55 -04:00
parent c763aa42b4
commit e74b5b339a
1 changed files with 19 additions and 2 deletions

View File

@ -419,6 +419,7 @@ test_unicode_properties (gconstpointer user_data)
{ {
hb_unicode_funcs_t *uf = (hb_unicode_funcs_t *) user_data; hb_unicode_funcs_t *uf = (hb_unicode_funcs_t *) user_data;
unsigned int i, j; unsigned int i, j;
gboolean failed = TRUE;
g_assert (hb_unicode_funcs_is_immutable (uf)); g_assert (hb_unicode_funcs_is_immutable (uf));
@ -432,8 +433,21 @@ test_unicode_properties (gconstpointer user_data)
g_test_message ("Test %s #%d: U+%04X", p->name, j, tests[j].unicode); g_test_message ("Test %s #%d: U+%04X", p->name, j, tests[j].unicode);
g_assert_cmphex (p->getter (uf, tests[j].unicode), ==, tests[j].value); g_assert_cmphex (p->getter (uf, tests[j].unicode), ==, tests[j].value);
} }
/* These tests are from Unicode 5.2 onward and older glib/ICU
* don't get them right. Just warn instead of assert. */
tests = p->tests_more;
for (j = 0; j < p->num_tests_more; j++) {
g_test_message ("Test %s more #%d: U+%04X", p->name, j, tests[j].unicode);
if (p->getter (uf, tests[j].unicode) != tests[j].value) {
g_test_message ("Soft fail: Received %x, expected %x", p->getter (uf, tests[j].unicode), tests[j].value);
failed = TRUE;
} }
} }
}
if (failed)
g_message ("Some property tests failed. You probably have an old version of one of the libraries used. Rerun with --verbose for details");
}
static hb_codepoint_t static hb_codepoint_t
default_value (hb_codepoint_t default_value, hb_codepoint_t unicode) default_value (hb_codepoint_t default_value, hb_codepoint_t unicode)
@ -459,6 +473,11 @@ test_unicode_properties_nil (void)
g_test_message ("Test %s #%d: U+%04X", p->name, j, tests[j].unicode); g_test_message ("Test %s #%d: U+%04X", p->name, j, tests[j].unicode);
g_assert_cmphex (p->getter (uf, tests[j].unicode), ==, default_value (p->default_value, tests[j].unicode)); g_assert_cmphex (p->getter (uf, tests[j].unicode), ==, default_value (p->default_value, tests[j].unicode));
} }
tests = p->tests_more;
for (j = 0; j < p->num_tests_more; j++) {
g_test_message ("Test %s more #%d: U+%04X", p->name, j, tests[j].unicode);
g_assert_cmphex (p->getter (uf, tests[j].unicode), ==, default_value (p->default_value, tests[j].unicode));
}
} }
hb_unicode_funcs_destroy (uf); hb_unicode_funcs_destroy (uf);
@ -647,8 +666,6 @@ main (int argc, char **argv)
hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_default); hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_default);
hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_deep); hb_test_add_fixture (data_fixture, NULL, test_unicode_subclassing_deep);
/* XXX test icu ufuncs */
/* XXX test _more tests (warn?) */
/* XXX test chainup */ /* XXX test chainup */
/* XXX test glib & icu two-way script conversion */ /* XXX test glib & icu two-way script conversion */