diff options
author | Benjamin Otte <otte@redhat.com> | 2014-05-23 16:35:08 +0200 |
---|---|---|
committer | Benjamin Otte <otte@redhat.com> | 2014-05-23 17:12:32 +0200 |
commit | 74b6f5fba8e29923e08aed2b121ec32e505ac31b (patch) | |
tree | 2fb6c854df9346b72dcf161b5e42c9fcff8fdce9 | |
parent | d769f338f2abbffb98804a852887e73362d436b7 (diff) | |
download | gtk+-74b6f5fba8e29923e08aed2b121ec32e505ac31b.tar.gz |
testsuite: Add a test for icon names
This test just checks that all the icon names that GTK uses are present
in the default icon theme.
As icon names are not checked programmatically and we do not want to run
into missing-icon icons in the code, this test seems necessary.
For now, it's just a stub that tests stock icons.
-rw-r--r-- | testsuite/gtk/Makefile.am | 1 | ||||
-rw-r--r-- | testsuite/gtk/check-icon-names.c | 147 |
2 files changed, 148 insertions, 0 deletions
diff --git a/testsuite/gtk/Makefile.am b/testsuite/gtk/Makefile.am index 10301c68e6..d9f8332364 100644 --- a/testsuite/gtk/Makefile.am +++ b/testsuite/gtk/Makefile.am @@ -32,6 +32,7 @@ TEST_PROGS += \ bitmask \ builder \ cellarea \ + check-icon-names \ clipboard \ defaultvalue \ entry \ diff --git a/testsuite/gtk/check-icon-names.c b/testsuite/gtk/check-icon-names.c new file mode 100644 index 0000000000..fe3646c75f --- /dev/null +++ b/testsuite/gtk/check-icon-names.c @@ -0,0 +1,147 @@ +#include <gtk/gtk.h> + +static char *icon_names[] = { + /* stock icons */ + "dialog-password", + "dialog-error", + "dialog-information", + "dialog-question", + "dialog-warning", + /* "gtk-dnd", */ + /* "gtk-dnd-multiple", */ + /* "gtk-apply", */ + /* "gtk-cancel", */ + /* "gtk-no", */ + /* "gtk-ok", */ + /* "gtk-yes", */ + "window-close", + "list-add", + "format-justify-center", + "format-justify-fill", + "format-justify-left", + "format-justify-right", + "go-bottom", + "media-optical", + /* "gtk-convert", */ + "edit-copy", + "edit-cut", + "go-down", + "system-run", + "application-exit", + "go-first", + /* "gtk-select-font", */ + "view-fullscreen", + "view-restore", + "drive-harddisk", + "help-contents", + "go-home", + "dialog-information", + "go-jump", + "go-last", + "go-previous", + "image-missing", + "network-idle", + "document-new", + "document-open", + /* "gtk-orientation-portrait", */ + /* "gtk-orientation-landscape", */ + /* "gtk-orientation-reverse-portrait", */ + /* "gtk-orientation-reverse-landscape", */ + /* "gtk-page-setup", */ + "edit-paste", + /* "gtk-preferences", */ + "document-print", + "printer-error", + /* "printer-paused", */ + "document-print-preview", + /* "printer-info", */ + /* "printer-warning", */ + "document-properties", + "edit-redo", + "list-remove", + "view-refresh", + "document-revert", + "go-next", + "document-save", + "media-floppy", + "document-save-as", + "edit-find", + "edit-find-replace", + "view-sort-descending", + "view-sort-ascending", + "tools-check-spelling", + "process-stop", + "format-text-bold", + "format-text-italic", + "format-text-strikethrough", + "format-text-underline", + "format-indent-more", + "format-indent-less", + "go-top", + "edit-delete", + /* "gtk-undelete", */ + "edit-undo", + "go-up", + "text-x-generic", + "folder", + "help-about", + /* "gtk-connect", */ + /* "gtk-disconnect", */ + /* "gtk-edit", */ + /* "gtk-caps-lock-warning", */ + "media-seek-forward", + "media-skip-forward", + "media-playback-pause", + "media-playback-start", + "media-skip-backward", + "media-record", + "media-seek-backward", + "media-playback-stop", + /* "gtk-index", */ + "zoom-original", + "zoom-in", + "zoom-out", + "zoom-fit-best", + "edit-select-all", + "edit-clear" + /* "gtk-select-color", */ + /* "gtk-color-picker" */ +}; + +static void +test_icon_existence (gconstpointer icon_name) +{ + GtkIconInfo *info; + + /* Not using generic fallback and builtins here, as we explicitly want to check the + * icon theme. + * The icon size is randomly chosen. + */ + info = gtk_icon_theme_lookup_icon (gtk_icon_theme_get_default (), icon_name, 16, 0); + if (info == NULL) + { + g_test_message ("Failed to look up icon for \"%s\"", (char *) icon_name); + g_test_fail (); + return; + } + + g_object_unref (info); +} + +int +main (int argc, char *argv[]) +{ + guint i; + char *test_name; + + gtk_test_init (&argc, &argv); + + for (i = 0; i < G_N_ELEMENTS (icon_names); i++) + { + test_name = g_strdup_printf ("/check-icon-names/%s", icon_names[i]); + g_test_add_data_func (test_name, icon_names[i], test_icon_existence); + g_free (test_name); + } + + return g_test_run(); +} |