[glib] Test content type icons more thoroughly
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib] Test content type icons more thoroughly
- Date: Sun, 23 Feb 2014 17:12:46 +0000 (UTC)
commit e7bde4acf4499d353780b696435e1a43dee66c54
Author: Matthias Clasen <mclasen redhat com>
Date: Sun Feb 23 12:03:13 2014 -0500
Test content type icons more thoroughly
Check we actually get the right icon names, and check
that symbolic icons fall back to non-symbolic ones.
gio/tests/contenttype.c | 71 +++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 71 insertions(+), 0 deletions(-)
---
diff --git a/gio/tests/contenttype.c b/gio/tests/contenttype.c
index aa8ff82..80ce6a2 100644
--- a/gio/tests/contenttype.c
+++ b/gio/tests/contenttype.c
@@ -199,6 +199,21 @@ test_description (void)
g_free (type);
}
+static gboolean
+strv_contains (const gchar * const *strv,
+ const gchar *s)
+{
+ gint i;
+
+ for (i = 0; strv[i]; i++)
+ {
+ if (g_strcmp0 (strv[i], s) == 0)
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
static void
test_icon (void)
{
@@ -208,12 +223,67 @@ test_icon (void)
type = g_content_type_from_mime_type ("text/plain");
icon = g_content_type_get_icon (type);
g_assert (G_IS_ICON (icon));
+ if (G_IS_THEMED_ICON (icon))
+ {
+ const gchar *const *names;
+
+ names = g_themed_icon_get_names (G_THEMED_ICON (icon));
+ g_assert (strv_contains (names, "text-plain"));
+ g_assert (strv_contains (names, "text-x-generic"));
+ }
g_object_unref (icon);
g_free (type);
type = g_content_type_from_mime_type ("application/rtf");
icon = g_content_type_get_icon (type);
g_assert (G_IS_ICON (icon));
+ if (G_IS_THEMED_ICON (icon))
+ {
+ const gchar *const *names;
+
+ names = g_themed_icon_get_names (G_THEMED_ICON (icon));
+ g_assert (strv_contains (names, "application-rtf"));
+ g_assert (strv_contains (names, "x-office-document"));
+ }
+ g_object_unref (icon);
+ g_free (type);
+}
+
+static void
+test_symbolic_icon (void)
+{
+ gchar *type;
+ GIcon *icon;
+
+ type = g_content_type_from_mime_type ("text/plain");
+ icon = g_content_type_get_symbolic_icon (type);
+ g_assert (G_IS_ICON (icon));
+ if (G_IS_THEMED_ICON (icon))
+ {
+ const gchar *const *names;
+
+ names = g_themed_icon_get_names (G_THEMED_ICON (icon));
+ g_assert (strv_contains (names, "text-plain-symbolic"));
+ g_assert (strv_contains (names, "text-x-generic-symbolic"));
+ g_assert (strv_contains (names, "text-plain"));
+ g_assert (strv_contains (names, "text-x-generic"));
+ }
+ g_object_unref (icon);
+ g_free (type);
+
+ type = g_content_type_from_mime_type ("application/rtf");
+ icon = g_content_type_get_symbolic_icon (type);
+ g_assert (G_IS_ICON (icon));
+ if (G_IS_THEMED_ICON (icon))
+ {
+ const gchar *const *names;
+
+ names = g_themed_icon_get_names (G_THEMED_ICON (icon));
+ g_assert (strv_contains (names, "application-rtf-symbolic"));
+ g_assert (strv_contains (names, "x-office-document-symbolic"));
+ g_assert (strv_contains (names, "application-rtf"));
+ g_assert (strv_contains (names, "x-office-document"));
+ }
g_object_unref (icon);
g_free (type);
}
@@ -254,6 +324,7 @@ main (int argc, char *argv[])
g_test_add_func ("/contenttype/executable", test_executable);
g_test_add_func ("/contenttype/description", test_description);
g_test_add_func ("/contenttype/icon", test_icon);
+ g_test_add_func ("/contenttype/symbolic-icon", test_symbolic_icon);
g_test_add_func ("/contenttype/tree", test_tree);
return g_test_run ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]