/* * Copyright (C) 2008 Red Hat, Inc * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 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. * * Author: Matthias Clasen */ #include #include #include #include #include static char *basedir; static GAppInfo * create_app_info (const char *name) { GError *error; GAppInfo *info; error = NULL; info = g_app_info_create_from_commandline ("/usr/bin/true blah", name, G_APP_INFO_CREATE_NONE, &error); g_assert (error == NULL); /* this is necessary to ensure that the info is saved */ g_app_info_set_as_default_for_type (info, "application/x-blah", &error); g_assert (error == NULL); g_app_info_remove_supports_type (info, "application/x-blah", &error); g_assert (error == NULL); g_app_info_reset_type_associations ("application/x-blah"); return info; } static void test_delete (void) { GAppInfo *info; const char *id; char *filename; gboolean res; info = create_app_info ("Blah"); id = g_app_info_get_id (info); g_assert (id != NULL); filename = g_build_filename (basedir, "applications", id, NULL); res = g_file_test (filename, G_FILE_TEST_EXISTS); g_assert (res); res = g_app_info_can_delete (info); g_assert (res); res = g_app_info_delete (info); g_assert (res); res = g_file_test (filename, G_FILE_TEST_EXISTS); g_assert (!res); g_object_unref (info); if (g_file_test ("/usr/share/applications/gedit.desktop", G_FILE_TEST_EXISTS)) { info = (GAppInfo*)g_desktop_app_info_new ("gedit.desktop"); g_assert (info); res = g_app_info_can_delete (info); g_assert (!res); res = g_app_info_delete (info); g_assert (!res); } } static void test_default (void) { GAppInfo *info, *info1, *info2, *info3; GList *list; GError *error = NULL; info1 = create_app_info ("Blah1"); info2 = create_app_info ("Blah2"); info3 = create_app_info ("Blah3"); g_app_info_set_as_default_for_type (info1, "application/x-test", &error); g_assert (error == NULL); 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 = (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 */ 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); /* 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); /* 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); g_object_unref (info1); g_object_unref (info2); } static void cleanup_dir_recurse (GFile *parent, GFile *root) { gboolean res; GError *error; GFileEnumerator *enumerator; GFileInfo *info; GFile *descend; char *relative_path; g_assert (root != NULL); error = NULL; enumerator = g_file_enumerate_children (parent, "*", G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS, NULL, &error); if (! enumerator) return; error = NULL; info = g_file_enumerator_next_file (enumerator, NULL, &error); while ((info) && (!error)) { descend = g_file_get_child (parent, g_file_info_get_name (info)); g_assert (descend != NULL); relative_path = g_file_get_relative_path (root, descend); g_assert (relative_path != NULL); if (g_file_info_get_file_type (info) == G_FILE_TYPE_DIRECTORY) cleanup_dir_recurse (descend, root); error = NULL; res = g_file_delete (descend, NULL, &error); g_assert_cmpint (res, ==, TRUE); g_object_unref (descend); error = NULL; info = g_file_enumerator_next_file (enumerator, NULL, &error); } g_assert (error == NULL); error = NULL; res = g_file_enumerator_close (enumerator, NULL, &error); g_assert_cmpint (res, ==, TRUE); g_assert (error == NULL); } static void cleanup_subdirs (const char *basedir) { GFile *base, *file; base = g_file_new_for_path (basedir); file = g_file_get_child (base, "applications"); cleanup_dir_recurse (file, file); g_object_unref (file); file = g_file_get_child (base, "mime"); cleanup_dir_recurse (file, file); g_object_unref (file); } 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); result = g_test_run (); cleanup_subdirs (basedir); return result; }