Improve GApplication test coverage
[platform/upstream/glib.git] / gio / tests / appinfo.c
index 9151252..e04071a 100644 (file)
@@ -1,5 +1,6 @@
 
 #include <locale.h>
+#include <string.h>
 
 #include <gio/gio.h>
 #include <gio/gdesktopappinfo.h>
@@ -11,8 +12,17 @@ test_launch (void)
   GError *error;
   GFile *file;
   GList *l;
+  const gchar *path;
+  gchar *uri;
+
+  if (g_getenv ("DISPLAY") == NULL || g_getenv ("DISPLAY")[0] == '\0')
+    {
+      g_printerr ("No DISPLAY.  Skipping test.  ");
+      return;
+    }
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
   g_assert (appinfo != NULL);
 
   error = NULL;
@@ -22,7 +32,7 @@ test_launch (void)
   g_assert (g_app_info_launch_uris (appinfo, NULL, NULL, &error));
   g_assert_no_error (error);
 
-  file = g_file_new_for_path (SRCDIR "/appinfo-test.desktop");
+  file = g_file_new_for_path (path);
   l = NULL;
   l = g_list_append (l, file);
 
@@ -32,12 +42,14 @@ test_launch (void)
   g_object_unref (file);
 
   l = NULL;
-  l = g_list_append (l, "file://" SRCDIR "/appinfo-test.desktop");
+  uri = g_strconcat ("file://", g_test_get_dir (G_TEST_DIST), "/appinfo-test.desktop", NULL);
+  l = g_list_append (l, uri);
   l = g_list_append (l, "file:///etc/group#adm");
 
   g_assert (g_app_info_launch_uris (appinfo, l, NULL, &error));
   g_assert_no_error (error);
   g_list_free (l);
+  g_free (uri);
 
   g_object_unref (appinfo);
 }
@@ -47,12 +59,14 @@ test_locale (const char *locale)
 {
   GAppInfo *appinfo;
   const gchar *orig;
+  const gchar *path;
 
   orig = setlocale (LC_ALL, NULL);
   g_setenv ("LANGUAGE", locale, TRUE);
   setlocale (LC_ALL, "");
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
 
   if (g_strcmp0 (locale, "C") == 0)
     {
@@ -94,11 +108,13 @@ test_basic (void)
   GAppInfo *appinfo;
   GAppInfo *appinfo2;
   GIcon *icon, *icon2;
+  const gchar *path;
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
 
-  g_assert (g_app_info_get_id (appinfo) == NULL);
-  g_assert_cmpstr (g_app_info_get_executable (appinfo), ==, "./appinfo-test");
+  g_assert_cmpstr (g_app_info_get_id (appinfo), ==, "appinfo-test.desktop");
+  g_assert (strstr (g_app_info_get_executable (appinfo), "appinfo-test") != NULL);
 
   icon = g_app_info_get_icon (appinfo);
   g_assert (G_IS_THEMED_ICON (icon));
@@ -107,7 +123,7 @@ test_basic (void)
   g_object_unref (icon2);
 
   appinfo2 = g_app_info_dup (appinfo);
-  g_assert (g_app_info_get_id (appinfo) == g_app_info_get_id (appinfo2));
+  g_assert_cmpstr (g_app_info_get_id (appinfo), ==, g_app_info_get_id (appinfo2));
   g_assert_cmpstr (g_app_info_get_commandline (appinfo), ==, g_app_info_get_commandline (appinfo2));
 
   g_object_unref (appinfo);
@@ -118,18 +134,22 @@ static void
 test_show_in (void)
 {
   GAppInfo *appinfo;
+  const gchar *path;
 
   g_desktop_app_info_set_desktop_env ("GNOME");
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
   g_assert (g_app_info_should_show (appinfo));
   g_object_unref (appinfo);
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test-gnome.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test-gnome.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
   g_assert (g_app_info_should_show (appinfo));
   g_object_unref (appinfo);
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test-notgnome.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test-notgnome.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
   g_assert (!g_app_info_should_show (appinfo));
   g_object_unref (appinfo);
 }
@@ -139,34 +159,45 @@ test_commandline (void)
 {
   GAppInfo *appinfo;
   GError *error;
+  gchar *cmdline;
+  gchar *cmdline_out;
+
+  cmdline = g_strconcat (g_test_get_dir (G_TEST_BUILT), "/appinfo-test --option", NULL);
+  cmdline_out = g_strconcat (cmdline, " %u", NULL);
 
   error = NULL;
-  appinfo = g_app_info_create_from_commandline ("./appinfo-test --option",
+  appinfo = g_app_info_create_from_commandline (cmdline,
                                                 "cmdline-app-test",
                                                 G_APP_INFO_CREATE_SUPPORTS_URIS,
                                                 &error);
   g_assert (appinfo != NULL);
   g_assert_no_error (error);
   g_assert_cmpstr (g_app_info_get_name (appinfo), ==, "cmdline-app-test");
-  g_assert_cmpstr (g_app_info_get_commandline (appinfo), ==, "./appinfo-test --option %u");
+  g_assert_cmpstr (g_app_info_get_commandline (appinfo), ==, cmdline_out);
   g_assert (g_app_info_supports_uris (appinfo));
   g_assert (!g_app_info_supports_files (appinfo));
 
   g_object_unref (appinfo);
 
+  g_free (cmdline_out);
+  cmdline_out = g_strconcat (cmdline, " %f", NULL);
+
   error = NULL;
-  appinfo = g_app_info_create_from_commandline ("./appinfo-test --option",
+  appinfo = g_app_info_create_from_commandline (cmdline,
                                                 "cmdline-app-test",
                                                 G_APP_INFO_CREATE_NONE,
                                                 &error);
   g_assert (appinfo != NULL);
   g_assert_no_error (error);
   g_assert_cmpstr (g_app_info_get_name (appinfo), ==, "cmdline-app-test");
-  g_assert_cmpstr (g_app_info_get_commandline (appinfo), ==, "./appinfo-test --option %f");
+  g_assert_cmpstr (g_app_info_get_commandline (appinfo), ==, cmdline_out);
   g_assert (!g_app_info_supports_uris (appinfo));
   g_assert (g_app_info_supports_files (appinfo));
 
   g_object_unref (appinfo);
+
+  g_free (cmdline);
+  g_free (cmdline_out);
 }
 
 static void
@@ -175,9 +206,12 @@ test_launch_context (void)
   GAppLaunchContext *context;
   GAppInfo *appinfo;
   gchar *str;
+  gchar *cmdline;
+
+  cmdline = g_strconcat (g_test_get_dir (G_TEST_BUILT), "/appinfo-test --option", NULL);
 
   context = g_app_launch_context_new ();
-  appinfo = g_app_info_create_from_commandline ("./appinfo-test --option",
+  appinfo = g_app_info_create_from_commandline (cmdline,
                                                 "cmdline-app-test",
                                                 G_APP_INFO_CREATE_SUPPORTS_URIS,
                                                 NULL);
@@ -190,14 +224,72 @@ test_launch_context (void)
 
   g_object_unref (appinfo);
   g_object_unref (context);
+
+  g_free (cmdline);
+}
+
+static gboolean launched_reached;
+
+static void
+launched (GAppLaunchContext *context,
+          GAppInfo          *info,
+          GVariant          *platform_data,
+          gpointer           user_data)
+{
+  gint pid;
+
+  pid = 0;
+  g_assert (g_variant_lookup (platform_data, "pid", "i", &pid));
+  g_assert (pid != 0);
+
+  launched_reached = TRUE;
+}
+
+static void
+launch_failed (GAppLaunchContext *context,
+               const gchar       *startup_notify_id)
+{
+  g_assert_not_reached ();
+}
+
+static void
+test_launch_context_signals (void)
+{
+  GAppLaunchContext *context;
+  GAppInfo *appinfo;
+  GError *error = NULL;
+  gchar *cmdline;
+
+  cmdline = g_strconcat (g_test_get_dir (G_TEST_BUILT), "/appinfo-test --option", NULL);
+
+  context = g_app_launch_context_new ();
+  g_signal_connect (context, "launched", G_CALLBACK (launched), NULL);
+  g_signal_connect (context, "launch_failed", G_CALLBACK (launch_failed), NULL);
+  appinfo = g_app_info_create_from_commandline (cmdline,
+                                                "cmdline-app-test",
+                                                G_APP_INFO_CREATE_SUPPORTS_URIS,
+                                                NULL);
+
+  error = NULL;
+  g_assert (g_app_info_launch (appinfo, NULL, context, &error));
+  g_assert_no_error (error);
+
+  g_assert (launched_reached);
+
+  g_object_unref (appinfo);
+  g_object_unref (context);
+
+  g_free (cmdline);
 }
 
 static void
 test_tryexec (void)
 {
   GAppInfo *appinfo;
+  const gchar *path;
 
-  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test2.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test2.desktop", NULL);
+  appinfo = (GAppInfo*)g_desktop_app_info_new_from_filename (path);
 
   g_assert (appinfo == NULL);
 }
@@ -213,8 +305,10 @@ test_associations (void)
   GError *error;
   gboolean result;
   GList *list;
+  gchar *cmdline;
 
-  appinfo = g_app_info_create_from_commandline ("./appinfo-test --option",
+  cmdline = g_strconcat (g_test_get_dir (G_TEST_BUILT), "/appinfo-test --option", NULL);
+  appinfo = g_app_info_create_from_commandline (cmdline,
                                                 "cmdline-app-test",
                                                 G_APP_INFO_CREATE_SUPPORTS_URIS,
                                                 NULL);
@@ -279,7 +373,7 @@ test_environment (void)
   env = g_app_launch_context_get_environment (ctx);
 
   g_assert (g_environ_getenv (env, "FOO") == NULL);
-  g_assert (g_environ_getenv (env, "BAR") == NULL);
+  g_assert (g_environ_getenv (env, "BLA") == NULL);
   g_assert_cmpstr (g_environ_getenv (env, "PATH"), ==, path);
 
   g_strfreev (env);
@@ -313,8 +407,10 @@ test_startup_wm_class (void)
 {
   GDesktopAppInfo *appinfo;
   const char *wm_class;
+  const gchar *path;
 
-  appinfo = g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop");
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = g_desktop_app_info_new_from_filename (path);
   wm_class = g_desktop_app_info_get_startup_wm_class (appinfo);
 
   g_assert_cmpstr (wm_class, ==, "appinfo-class");
@@ -327,8 +423,10 @@ test_supported_types (void)
 {
   GAppInfo *appinfo;
   const char * const *content_types;
+  const gchar *path;
 
-  appinfo = G_APP_INFO (g_desktop_app_info_new_from_filename (SRCDIR "/appinfo-test.desktop"));
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
+  appinfo = G_APP_INFO (g_desktop_app_info_new_from_filename (path));
   content_types = g_app_info_get_supported_types (appinfo);
 
   g_assert_cmpint (g_strv_length ((char**)content_types), ==, 2);
@@ -347,12 +445,11 @@ test_from_keyfile (void)
   gchar **keywords;
   const gchar *file;
   const gchar *name;
+  const gchar *path;
 
+  path = g_test_get_filename (G_TEST_DIST, "appinfo-test.desktop", NULL);
   kf = g_key_file_new ();
-  g_key_file_load_from_file (kf,
-                             SRCDIR "/appinfo-test.desktop",
-                             G_KEY_FILE_NONE,
-                             &error);
+  g_key_file_load_from_file (kf, path, G_KEY_FILE_NONE, &error);
   g_assert_no_error (error);
   info = g_desktop_app_info_new_from_keyfile (kf);
   g_key_file_free (kf);
@@ -387,6 +484,7 @@ main (int argc, char *argv[])
   g_test_add_func ("/appinfo/show-in", test_show_in);
   g_test_add_func ("/appinfo/commandline", test_commandline);
   g_test_add_func ("/appinfo/launch-context", test_launch_context);
+  g_test_add_func ("/appinfo/launch-context-signals", test_launch_context_signals);
   g_test_add_func ("/appinfo/tryexec", test_tryexec);
   g_test_add_func ("/appinfo/associations", test_associations);
   g_test_add_func ("/appinfo/environment", test_environment);