X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gio%2Ftests%2Fdesktop-app-info.c;h=fceaabc81d012b5417b0580c3180b6e78e24c477;hb=caf0f1df1c59b0b7e5f68327e3852817d74609a5;hp=6c6e3135c4f45f1fcd38792f64186e5feba289b7;hpb=d8ca6404229e5b64d2bf2e1a3660ad9fe7feefdd;p=platform%2Fupstream%2Fglib.git
diff --git a/gio/tests/desktop-app-info.c b/gio/tests/desktop-app-info.c
index 6c6e313..fceaabc 100644
--- a/gio/tests/desktop-app-info.c
+++ b/gio/tests/desktop-app-info.c
@@ -12,9 +12,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General
- * Public License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
- * Boston, MA 02111-1307, USA.
+ * Public License along with this library; if not, see .
*
* Author: Matthias Clasen
*/
@@ -24,6 +22,7 @@
#include
#include
#include
+#include
static char *basedir;
@@ -34,7 +33,7 @@ create_app_info (const char *name)
GAppInfo *info;
error = NULL;
- info = g_app_info_create_from_commandline ("/usr/bin/true blah",
+ info = g_app_info_create_from_commandline ("true blah",
name,
G_APP_INFO_CREATE_NONE,
&error);
@@ -110,62 +109,34 @@ test_default (void)
g_app_info_set_as_default_for_type (info2, "application/x-test", &error);
g_assert (error == NULL);
- list = g_app_info_get_all_for_type ("application/x-test");
- g_assert (g_list_length (list) == 2);
-
- /* check that both are in the list, info2 before info1 */
- info = (GAppInfo *)list->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info2)) == 0);
+ info = g_app_info_get_default_for_type ("application/x-test", FALSE);
+ g_assert (info != NULL);
+ g_assert_cmpstr (g_app_info_get_id (info), ==, g_app_info_get_id (info2));
- info = (GAppInfo *)list->next->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info1)) == 0);
-
- g_list_foreach (list, (GFunc)g_object_unref, NULL);
- g_list_free (list);
-
- /* now try adding something at the end */
+ /* now try adding something, but not setting as default */
g_app_info_add_supports_type (info3, "application/x-test", &error);
g_assert (error == NULL);
- list = g_app_info_get_all_for_type ("application/x-test");
- g_assert (g_list_length (list) == 3);
-
- /* check that all are in the list, info2, info1, info3 */
- info = (GAppInfo *)list->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info2)) == 0);
-
- info = (GAppInfo *)list->next->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info1)) == 0);
-
- info = (GAppInfo *)list->next->next->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info3)) == 0);
-
- g_list_foreach (list, (GFunc)g_object_unref, NULL);
- g_list_free (list);
+ /* check that info2 is still default */
+ info = g_app_info_get_default_for_type ("application/x-test", FALSE);
+ g_assert (info != NULL);
+ g_assert_cmpstr (g_app_info_get_id (info), ==, g_app_info_get_id (info2));
/* now remove info1 again */
g_app_info_remove_supports_type (info1, "application/x-test", &error);
g_assert (error == NULL);
- list = g_app_info_get_all_for_type ("application/x-test");
- g_assert (g_list_length (list) == 2);
-
- /* check that both are in the list, info2 before info3 */
- info = (GAppInfo *)list->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info2)) == 0);
-
- info = (GAppInfo *)list->next->data;
- g_assert (g_strcmp0 (g_app_info_get_id (info), g_app_info_get_id (info3)) == 0);
-
- g_list_foreach (list, (GFunc)g_object_unref, NULL);
- g_list_free (list);
+ /* and make sure info2 is still default */
+ info = g_app_info_get_default_for_type ("application/x-test", FALSE);
+ g_assert (info != NULL);
+ g_assert_cmpstr (g_app_info_get_id (info), ==, g_app_info_get_id (info2));
/* now clean it all up */
g_app_info_reset_type_associations ("application/x-test");
list = g_app_info_get_all_for_type ("application/x-test");
g_assert (list == NULL);
-
+
g_app_info_delete (info1);
g_app_info_delete (info2);
g_app_info_delete (info3);
@@ -191,15 +162,15 @@ test_fallback (void)
old_length = g_list_length (apps);
g_list_free_full (apps, g_object_unref);
- g_app_info_set_as_default_for_type (info1, "text/x-python", &error);
+ g_app_info_add_supports_type (info1, "text/x-python", &error);
g_assert (error == NULL);
- g_app_info_set_as_default_for_type (info2, "text/plain", &error);
+ g_app_info_add_supports_type (info2, "text/plain", &error);
g_assert (error == NULL);
/* check that both apps are registered */
apps = g_app_info_get_all_for_type ("text/x-python");
- g_assert (g_list_length (apps) == old_length + 2);
+ g_assert_cmpint (g_list_length (apps), ==, old_length + 2);
/* check the ordering */
app = g_list_nth_data (apps, 0);
@@ -353,23 +324,372 @@ cleanup_subdirs (const char *base_dir)
g_object_unref (file);
}
+static void
+test_extra_getters (void)
+{
+ GDesktopAppInfo *appinfo;
+ gchar *s;
+ gboolean b;
+
+ appinfo = g_desktop_app_info_new_from_filename (g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL));
+ g_assert (appinfo != NULL);
+
+ g_assert (g_desktop_app_info_has_key (appinfo, "Terminal"));
+ g_assert (!g_desktop_app_info_has_key (appinfo, "Bratwurst"));
+
+ s = g_desktop_app_info_get_string (appinfo, "StartupWMClass");
+ g_assert_cmpstr (s, ==, "appinfo-class");
+ g_free (s);
+
+ b = g_desktop_app_info_get_boolean (appinfo, "Terminal");
+ g_assert (b);
+
+ g_object_unref (appinfo);
+}
+
+static void
+wait_for_file (const gchar *want_this,
+ const gchar *but_not_this,
+ const gchar *or_this)
+{
+ gint retries = 600;
+
+ /* I hate time-based conditions in tests, but this will wait up to one
+ * whole minute for "touch file" to finish running. I think it should
+ * be OK.
+ *
+ * 600 * 100ms = 60 seconds.
+ */
+ while (access (want_this, F_OK) != 0)
+ {
+ g_usleep (100000); /* 100ms */
+ g_assert (retries);
+ retries--;
+ }
+
+ g_assert (access (but_not_this, F_OK) != 0);
+ g_assert (access (or_this, F_OK) != 0);
+
+ unlink (want_this);
+ unlink (but_not_this);
+ unlink (or_this);
+}
+
+static void
+test_actions (void)
+{
+ const gchar * const *actions;
+ GDesktopAppInfo *appinfo;
+ gchar *name;
+
+ appinfo = g_desktop_app_info_new_from_filename (g_test_get_filename (G_TEST_DIST, "appinfo-test-actions.desktop", NULL));
+ g_assert (appinfo != NULL);
+
+ actions = g_desktop_app_info_list_actions (appinfo);
+ g_assert_cmpstr (actions[0], ==, "frob");
+ g_assert_cmpstr (actions[1], ==, "tweak");
+ g_assert_cmpstr (actions[2], ==, "twiddle");
+ g_assert_cmpstr (actions[3], ==, "broken");
+ g_assert_cmpstr (actions[4], ==, NULL);
+
+ name = g_desktop_app_info_get_action_name (appinfo, "frob");
+ g_assert_cmpstr (name, ==, "Frobnicate");
+ g_free (name);
+
+ name = g_desktop_app_info_get_action_name (appinfo, "tweak");
+ g_assert_cmpstr (name, ==, "Tweak");
+ g_free (name);
+
+ name = g_desktop_app_info_get_action_name (appinfo, "twiddle");
+ g_assert_cmpstr (name, ==, "Twiddle");
+ g_free (name);
+
+ name = g_desktop_app_info_get_action_name (appinfo, "broken");
+ g_assert (name != NULL);
+ g_assert (g_utf8_validate (name, -1, NULL));
+ g_free (name);
+
+ unlink ("frob"); unlink ("tweak"); unlink ("twiddle");
+
+ g_desktop_app_info_launch_action (appinfo, "frob", NULL);
+ wait_for_file ("frob", "tweak", "twiddle");
+
+ g_desktop_app_info_launch_action (appinfo, "tweak", NULL);
+ wait_for_file ("tweak", "frob", "twiddle");
+
+ g_desktop_app_info_launch_action (appinfo, "twiddle", NULL);
+ wait_for_file ("twiddle", "frob", "tweak");
+
+ g_object_unref (appinfo);
+}
+
+static gchar *
+run_apps (const gchar *command,
+ const gchar *arg,
+ gboolean with_usr,
+ gboolean with_home,
+ const gchar *locale_name,
+ const gchar *language)
+{
+ gboolean success;
+ gchar **envp;
+ gchar **argv;
+ gint status;
+ gchar *out;
+
+ argv = g_new (gchar *, 4);
+ argv[0] = g_test_build_filename (G_TEST_BUILT, "apps", NULL);
+ argv[1] = g_strdup (command);
+ argv[2] = g_strdup (arg);
+ argv[3] = NULL;
+
+ envp = g_get_environ ();
+
+ if (with_usr)
+ {
+ gchar *tmp = g_test_build_filename (G_TEST_DIST, "desktop-files", "usr", NULL);
+ envp = g_environ_setenv (envp, "XDG_DATA_DIRS", tmp, TRUE);
+ g_free (tmp);
+ }
+ else
+ envp = g_environ_setenv (envp, "XDG_DATA_DIRS", "/does-not-exist", TRUE);
+
+ if (with_home)
+ {
+ gchar *tmp = g_test_build_filename (G_TEST_DIST, "desktop-files", "home", NULL);
+ envp = g_environ_setenv (envp, "XDG_DATA_HOME", tmp, TRUE);
+ g_free (tmp);
+ }
+ else
+ envp = g_environ_setenv (envp, "XDG_DATA_HOME", "/does-not-exist", TRUE);
+
+ if (locale_name)
+ envp = g_environ_setenv (envp, "LC_ALL", locale_name, TRUE);
+ else
+ envp = g_environ_setenv (envp, "LC_ALL", "C", TRUE);
+
+ if (language)
+ envp = g_environ_setenv (envp, "LANGUAGE", language, TRUE);
+ else
+ envp = g_environ_unsetenv (envp, "LANGUAGE");
+
+ success = g_spawn_sync (NULL, argv, envp, 0, NULL, NULL, &out, NULL, &status, NULL);
+ g_assert (success);
+ g_assert (status == 0);
+
+ g_strfreev (envp);
+ g_strfreev (argv);
+
+ return out;
+}
+
+static void
+assert_strings_equivalent (const gchar *expected,
+ const gchar *result)
+{
+ gchar **expected_words;
+ gchar **result_words;
+ gint i, j;
+
+ expected_words = g_strsplit (expected, " ", 0);
+ result_words = g_strsplit (result, " ", 0);
+
+ for (i = 0; expected_words[i]; i++)
+ {
+ for (j = 0; result_words[j]; j++)
+ if (g_str_equal (expected_words[i], result_words[j]))
+ goto got_it;
+
+ g_test_message ("Unable to find expected string '%s' in result '%s'", expected_words[i], result);
+ g_test_fail ();
+
+got_it:
+ continue;
+ }
+
+ g_assert_cmpint (g_strv_length (expected_words), ==, g_strv_length (result_words));
+ g_strfreev (expected_words);
+ g_strfreev (result_words);
+}
+
+static void
+assert_list (const gchar *expected,
+ gboolean with_usr,
+ gboolean with_home,
+ const gchar *locale_name,
+ const gchar *language)
+{
+ gchar *result;
+
+ result = run_apps ("list", NULL, with_usr, with_home, locale_name, language);
+ g_strchomp (result);
+ assert_strings_equivalent (expected, result);
+ g_free (result);
+}
+
+static void
+assert_info (const gchar *desktop_id,
+ const gchar *expected,
+ gboolean with_usr,
+ gboolean with_home,
+ const gchar *locale_name,
+ const gchar *language)
+{
+ gchar *result;
+
+ result = run_apps ("show-info", desktop_id, with_usr, with_home, locale_name, language);
+ g_assert_cmpstr (result, ==, expected);
+ g_free (result);
+}
+
+static void
+assert_search (const gchar *search_string,
+ const gchar *expected,
+ gboolean with_usr,
+ gboolean with_home,
+ const gchar *locale_name,
+ const gchar *language)
+{
+ gchar **expected_lines;
+ gchar **result_lines;
+ gchar *result;
+ gint i;
+
+ expected_lines = g_strsplit (expected, "\n", -1);
+ result = run_apps ("search", search_string, with_usr, with_home, locale_name, language);
+ result_lines = g_strsplit (result, "\n", -1);
+ g_assert_cmpint (g_strv_length (expected_lines), ==, g_strv_length (result_lines));
+ for (i = 0; expected_lines[i]; i++)
+ assert_strings_equivalent (expected_lines[i], result_lines[i]);
+ g_strfreev (expected_lines);
+ g_strfreev (result_lines);
+ g_free (result);
+}
+
+#define ALL_USR_APPS "evince-previewer.desktop nautilus-classic.desktop gnome-font-viewer.desktop " \
+ "baobab.desktop yelp.desktop eog.desktop cheese.desktop gnome-clocks.desktop " \
+ "gnome-contacts.desktop kde4-kate.desktop gcr-prompter.desktop totem.desktop " \
+ "gnome-terminal.desktop nautilus-autorun-software.desktop gcr-viewer.desktop " \
+ "nautilus-connect-server.desktop kde4-dolphin.desktop gnome-music.desktop " \
+ "kde4-konqbrowser.desktop gucharmap.desktop kde4-okular.desktop nautilus.desktop " \
+ "gedit.desktop evince.desktop file-roller.desktop dconf-editor.desktop glade.desktop"
+#define HOME_APPS "epiphany-weather-for-toronto-island-9c6a4e022b17686306243dada811d550d25eb1fb.desktop"
+#define ALL_HOME_APPS HOME_APPS " eog.desktop"
+
+static void
+test_search (void)
+{
+ assert_list ("", FALSE, FALSE, NULL, NULL);
+ assert_list (ALL_USR_APPS, TRUE, FALSE, NULL, NULL);
+ assert_list (ALL_HOME_APPS, FALSE, TRUE, NULL, NULL);
+ assert_list (ALL_USR_APPS " " HOME_APPS, TRUE, TRUE, NULL, NULL);
+
+ /* The user has "installed" their own version of eog.desktop which
+ * calls it "Eye of GNOME". Do some testing based on that.
+ *
+ * We should always find "Pictures" keyword no matter where we look.
+ */
+ assert_search ("Picture", "eog.desktop\n", TRUE, TRUE, NULL, NULL);
+ assert_search ("Picture", "eog.desktop\n", TRUE, FALSE, NULL, NULL);
+ assert_search ("Picture", "eog.desktop\n", FALSE, TRUE, NULL, NULL);
+ assert_search ("Picture", "", FALSE, FALSE, NULL, NULL);
+
+ /* We should only find it called "eye of gnome" when using the user's
+ * directory.
+ */
+ assert_search ("eye gnome", "", TRUE, FALSE, NULL, NULL);
+ assert_search ("eye gnome", "eog.desktop\n", FALSE, TRUE, NULL, NULL);
+ assert_search ("eye gnome", "eog.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* We should only find it called "image viewer" when _not_ using the
+ * user's directory.
+ */
+ assert_search ("image viewer", "eog.desktop\n", TRUE, FALSE, NULL, NULL);
+ assert_search ("image viewer", "", FALSE, TRUE, NULL, NULL);
+ assert_search ("image viewer", "", TRUE, TRUE, NULL, NULL);
+
+ /* Obvious multi-word search */
+ assert_search ("gno hel", "yelp.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* Repeated search terms should do nothing... */
+ assert_search ("files file fil fi f", "nautilus.desktop\n"
+ "gedit.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* "con" will match "connect" and "contacts" on name but dconf only on
+ * the "config" keyword
+ */
+ assert_search ("con", "nautilus-connect-server.desktop gnome-contacts.desktop\n"
+ "dconf-editor.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* "gnome" will match "eye of gnome" from the user's directory, plus
+ * matching "GNOME Clocks" X-GNOME-FullName. It's only a comment on
+ * yelp and gnome-contacts, though.
+ */
+ assert_search ("gnome", "eog.desktop\n"
+ "gnome-clocks.desktop\n"
+ "yelp.desktop gnome-contacts.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* eog has exec name 'false' in usr only */
+ assert_search ("false", "eog.desktop\n", TRUE, FALSE, NULL, NULL);
+ assert_search ("false", "", FALSE, TRUE, NULL, NULL);
+ assert_search ("false", "", TRUE, TRUE, NULL, NULL);
+ assert_search ("false", "", FALSE, FALSE, NULL, NULL);
+
+ /* make sure we only search the first component */
+ assert_search ("nonsearchable", "", TRUE, FALSE, NULL, NULL);
+
+ /* "gnome con" will match only gnome contacts; via the name for
+ * "contacts" and the comment for "gnome"
+ */
+ assert_search ("gnome con", "gnome-contacts.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* make sure we get the correct kde4- prefix on the application IDs
+ * from subdirectories
+ */
+ assert_search ("konq", "kde4-konqbrowser.desktop\n", TRUE, TRUE, NULL, NULL);
+ assert_search ("kate", "kde4-kate.desktop\n", TRUE, TRUE, NULL, NULL);
+
+ /* make sure we can lookup apps by name properly */
+ assert_info ("kde4-kate.desktop",
+ "kde4-kate.desktop\n"
+ "Kate\n"
+ "Kate\n"
+ "nil\n", TRUE, TRUE, NULL, NULL);
+
+ assert_info ("nautilus.desktop",
+ "nautilus.desktop\n"
+ "Files\n"
+ "Files\n"
+ "Access and organize files\n", TRUE, TRUE, NULL, NULL);
+
+ /* make sure localised searching works properly */
+ assert_search ("foliumi", "nautilus.desktop\n"
+ "kde4-konqbrowser.desktop\n"
+ "eog.desktop\n", TRUE, FALSE, "en_US.UTF-8", "eo");
+ /* the user's eog.desktop has no translations... */
+ assert_search ("foliumi", "nautilus.desktop\n"
+ "kde4-konqbrowser.desktop\n", TRUE, TRUE, "en_US.UTF-8", "eo");
+}
+
int
main (int argc,
char *argv[])
{
gint result;
- g_type_init ();
g_test_init (&argc, &argv, NULL);
-
+
basedir = g_get_current_dir ();
g_setenv ("XDG_DATA_HOME", basedir, TRUE);
cleanup_subdirs (basedir);
-
+
g_test_add_func ("/desktop-app-info/delete", test_delete);
g_test_add_func ("/desktop-app-info/default", test_default);
g_test_add_func ("/desktop-app-info/fallback", test_fallback);
g_test_add_func ("/desktop-app-info/lastused", test_last_used);
+ g_test_add_func ("/desktop-app-info/extra-getters", test_extra_getters);
+ g_test_add_func ("/desktop-app-info/actions", test_actions);
+ g_test_add_func ("/desktop-app-info/search", test_search);
result = g_test_run ();