[glib] Improve GApplicationCommandline test coverage
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib] Improve GApplicationCommandline test coverage
- Date: Wed, 1 Jan 2014 23:00:36 +0000 (UTC)
commit 3bbfd908802a44fb871a0498c088ac61b7ca50e7
Author: Matthias Clasen <mclasen redhat com>
Date: Mon Dec 23 12:08:47 2013 -0500
Improve GApplicationCommandline test coverage
Add tests for many GApplicationCommandline apis to the
existing application tests.
gio/tests/basic-application.c | 115 ++++++++++++++++++++++++++--
gio/tests/gapplication.c | 170 ++++++++++++++++++++++++++++++++++-------
2 files changed, 252 insertions(+), 33 deletions(-)
---
diff --git a/gio/tests/basic-application.c b/gio/tests/basic-application.c
index a2b797a..ea31888 100644
--- a/gio/tests/basic-application.c
+++ b/gio/tests/basic-application.c
@@ -18,17 +18,120 @@ open (GApplication *application,
gint i;
g_application_hold (application);
- g_print ("open");
+ g_print ("open");
for (i = 0; i < n_files; i++)
{
gchar *uri = g_file_get_uri (files[i]);
g_print (" %s", uri);
g_free (uri);
}
+ g_print ("\n");
+
g_application_release (application);
+}
- g_print ("\n");
+static int
+command_line (GApplication *application,
+ GApplicationCommandLine *cmdline)
+{
+ gchar **argv;
+ gint argc;
+ gint i;
+
+ g_application_hold (application);
+ argv = g_application_command_line_get_arguments (cmdline, &argc);
+
+ if (argc > 1)
+ {
+ if (g_strcmp0 (argv[1], "echo") == 0)
+ {
+ g_print ("cmdline");
+ for (i = 0; i < argc; i++)
+ g_print (" %s", argv[i]);
+ g_print ("\n");
+ }
+ else if (g_strcmp0 (argv[1], "env") == 0)
+ {
+ const gchar * const *env;
+
+ env = g_application_command_line_get_environ (cmdline);
+ g_print ("environment");
+ for (i = 0; env[i]; i++)
+ if (g_str_has_prefix (env[i], "TEST="))
+ g_print (" %s", env[i]);
+ g_print ("\n");
+ }
+ else if (g_strcmp0 (argv[1], "getenv") == 0)
+ {
+ g_print ("getenv TEST=%s\n", g_application_command_line_getenv (cmdline, "TEST"));
+ }
+ else if (g_strcmp0 (argv[1], "print") == 0)
+ {
+ g_application_command_line_print (cmdline, "print %s\n", argv[2]);
+ }
+ else if (g_strcmp0 (argv[1], "printerr") == 0)
+ {
+ g_application_command_line_printerr (cmdline, "printerr %s\n", argv[2]);
+ }
+ else if (g_strcmp0 (argv[1], "file") == 0)
+ {
+ GFile *file;
+
+ file = g_application_command_line_create_file_for_arg (cmdline, argv[2]);
+ g_print ("file %s\n", g_file_get_path (file));
+ g_object_unref (file);
+ }
+ else if (g_strcmp0 (argv[1], "properties") == 0)
+ {
+ gboolean remote;
+ GVariant *data;
+
+ g_object_get (cmdline,
+ "is-remote", &remote,
+ NULL);
+
+ data = g_application_command_line_get_platform_data (cmdline);
+ g_assert (remote);
+ g_assert (g_variant_is_of_type (data, G_VARIANT_TYPE ("a{sv}")));
+ g_variant_unref (data);
+ g_print ("properties ok\n");
+ }
+ else if (g_strcmp0 (argv[1], "cwd") == 0)
+ {
+ g_print ("cwd %s\n", g_application_command_line_get_cwd (cmdline));
+ }
+ else if (g_strcmp0 (argv[1], "busy") == 0)
+ {
+ g_application_mark_busy (g_application_get_default ());
+ g_print ("busy\n");
+ }
+ else if (g_strcmp0 (argv[1], "idle") == 0)
+ {
+ g_application_unmark_busy (g_application_get_default ());
+ g_print ("idle\n");
+ }
+ else if (g_strcmp0 (argv[1], "stdin") == 0)
+ {
+ GInputStream *stream;
+
+ stream = g_application_command_line_get_stdin (cmdline);
+
+ g_assert (stream == NULL || G_IS_INPUT_STREAM (stream));
+ g_object_unref (stream);
+
+ g_print ("stdin ok\n");
+ }
+ else
+ g_print ("unexpected command: %s\n", argv[1]);
+ }
+ else
+ g_print ("got ./cmd %d\n", g_application_command_line_get_is_remote (cmdline));
+
+ g_strfreev (argv);
+ g_application_release (application);
+
+ return 0;
}
int
@@ -39,12 +142,12 @@ main (int argc, char **argv)
app = g_application_new ("org.gtk.TestApplication",
G_APPLICATION_SEND_ENVIRONMENT |
- G_APPLICATION_HANDLES_OPEN |
- (g_strcmp0 (argv[1], "./cmd") == 0 ?
- G_APPLICATION_HANDLES_COMMAND_LINE
- : 0));
+ (g_strcmp0 (argv[1], "./cmd") == 0
+ ? G_APPLICATION_HANDLES_COMMAND_LINE
+ : G_APPLICATION_HANDLES_OPEN));
g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
g_signal_connect (app, "open", G_CALLBACK (open), NULL);
+ g_signal_connect (app, "command-line", G_CALLBACK (command_line), NULL);
#ifdef STANDALONE
g_application_set_inactivity_timeout (app, 10000);
#else
diff --git a/gio/tests/gapplication.c b/gio/tests/gapplication.c
index d970f75..f72432d 100644
--- a/gio/tests/gapplication.c
+++ b/gio/tests/gapplication.c
@@ -11,39 +11,56 @@ static GMainLoop *main_loop;
typedef struct
{
- const gchar *expected_stdout;
+ gchar *expected_stdout;
gint stdout_pipe;
+ gchar *expected_stderr;
+ gint stderr_pipe;
} ChildData;
static void
+check_data (gint fd, const gchar *expected)
+{
+ gssize len, actual;
+ gchar *buffer;
+
+ len = strlen (expected);
+ buffer = g_alloca (len + 100);
+ actual = read (fd, buffer, len + 100);
+
+ g_assert_cmpint (actual, >=, 0);
+
+ if (actual != len ||
+ memcmp (buffer, expected, len) != 0)
+ {
+ buffer[MIN(len + 100, actual)] = '\0';
+
+ g_error ("\nExpected\n-----\n%s-----\nGot (%s)\n-----\n%s-----\n",
+ expected,
+ (actual > len) ? "truncated" : "full", buffer);
+ }
+}
+
+static void
child_quit (GPid pid,
gint status,
gpointer data)
{
ChildData *child = data;
- gssize expected, actual;
- gchar *buffer;
g_assert_cmpint (status, ==, 0);
if (--outstanding_watches == 0)
g_main_loop_quit (main_loop);
- expected = strlen (child->expected_stdout);
- buffer = g_alloca (expected + 100);
- actual = read (child->stdout_pipe, buffer, expected + 100);
+ check_data (child->stdout_pipe, child->expected_stdout);
close (child->stdout_pipe);
+ g_free (child->expected_stdout);
- g_assert_cmpint (actual, >=, 0);
-
- if (actual != expected ||
- memcmp (buffer, child->expected_stdout, expected) != 0)
+ if (child->expected_stderr)
{
- buffer[MIN(expected + 100, actual)] = '\0';
-
- g_error ("\nExpected\n-----\n%s-----\nGot (%s)\n-----\n%s-----\n",
- child->expected_stdout,
- (actual > expected) ? "truncated" : "full", buffer);
+ check_data (child->stderr_pipe, child->expected_stderr);
+ close (child->stderr_pipe);
+ g_free (child->expected_stderr);
}
g_slice_free (ChildData, child);
@@ -51,6 +68,7 @@ child_quit (GPid pid,
static void
spawn (const gchar *expected_stdout,
+ const gchar *expected_stderr,
const gchar *first_arg,
...)
{
@@ -62,6 +80,7 @@ spawn (const gchar *expected_stdout,
va_list ap;
GPid pid;
GPollFD fd;
+ gchar **env;
va_start (ap, first_arg);
array = g_ptr_array_new ();
@@ -70,18 +89,24 @@ spawn (const gchar *expected_stdout,
g_ptr_array_add (array, g_strdup (arg));
g_ptr_array_add (array, NULL);
args = (gchar **) g_ptr_array_free (array, FALSE);
-
va_end (ap);
+ env = g_environ_setenv (g_get_environ (), "TEST", "1", TRUE);
+
data = g_slice_new (ChildData);
- data->expected_stdout = expected_stdout;
+ data->expected_stdout = g_strdup (expected_stdout);
+ data->expected_stderr = g_strdup (expected_stderr);
- g_spawn_async_with_pipes (NULL, args, NULL,
+ g_spawn_async_with_pipes (NULL, args, env,
G_SPAWN_DO_NOT_REAP_CHILD,
NULL, NULL, &pid, NULL,
- &data->stdout_pipe, NULL, &error);
+ &data->stdout_pipe,
+ expected_stderr ? &data->stderr_pipe : NULL,
+ &error);
g_assert_no_error (error);
+ g_strfreev (env);
+
g_child_watch_add (pid, child_quit, data);
outstanding_watches++;
@@ -99,6 +124,8 @@ basic (void)
{
GDBusConnection *c;
+ g_assert (outstanding_watches == 0);
+
session_bus_up ();
c = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL);
@@ -107,19 +134,105 @@ basic (void)
/* spawn the master */
spawn ("activated\n"
"open file:///a file:///b\n"
- "exit status: 0\n",
+ "exit status: 0\n", NULL,
"./app", NULL);
/* send it some files */
- spawn ("exit status: 0\n",
+ spawn ("exit status: 0\n", NULL,
"./app", "/a", "/b", NULL);
g_main_loop_run (main_loop);
g_object_unref (c);
session_bus_down ();
+
+ g_main_loop_unref (main_loop);
}
+static void
+test_remote_command_line (void)
+{
+ GDBusConnection *c;
+ GFile *file;
+ gchar *replies;
+ gchar *cwd;
+
+ g_assert (outstanding_watches == 0);
+
+ session_bus_up ();
+ c = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL);
+
+ main_loop = g_main_loop_new (NULL, 0);
+
+ file = g_file_new_for_commandline_arg ("foo");
+ cwd = g_get_current_dir ();
+
+ replies = g_strconcat ("got ./cmd 0\n",
+ "got ./cmd 1\n",
+ "cmdline ./cmd echo --abc -d\n",
+ "environment TEST=1\n",
+ "getenv TEST=1\n",
+ "file ", g_file_get_path (file), "\n",
+ "properties ok\n",
+ "cwd ", cwd, "\n",
+ "busy\n",
+ "idle\n",
+ "stdin ok\n",
+ "exit status: 0\n",
+ NULL);
+ g_object_unref (file);
+
+ /* spawn the master */
+ spawn (replies, NULL,
+ "./cmd", NULL);
+
+ g_free (replies);
+
+ /* send it a few commandlines */
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "echo", "--abc", "-d", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "env", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "getenv", NULL);
+
+ spawn ("print test\n"
+ "exit status: 0\n", NULL,
+ "./cmd", "print", "test", NULL);
+
+ spawn ("exit status: 0\n", "printerr test\n",
+ "./cmd", "printerr", "test", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "file", "foo", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "properties", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "cwd", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "busy", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "idle", NULL);
+
+ spawn ("exit status: 0\n", NULL,
+ "./cmd", "stdin", NULL);
+
+ g_main_loop_run (main_loop);
+
+ g_object_unref (c);
+ session_bus_down ();
+
+ g_main_loop_unref (main_loop);
+}
#if 0
/* Now that we register non-unique apps on the bus we need to fix the
@@ -358,20 +471,21 @@ test_noappid (void)
g_free (binpath);
}
+static gboolean activated;
+static gboolean quitted;
static gboolean
quit_app (gpointer user_data)
{
+ quitted = TRUE;
g_application_quit (user_data);
return G_SOURCE_REMOVE;
}
-static gboolean quit_activated;
-
static void
quit_activate (GApplication *app)
{
- quit_activated = TRUE;
+ activated = TRUE;
g_application_hold (app);
g_assert (g_application_get_dbus_connection (app) != NULL);
@@ -393,12 +507,15 @@ test_quit (void)
app = g_application_new ("org.gtk.Unimportant",
G_APPLICATION_FLAGS_NONE);
+ activated = FALSE;
+ quitted = FALSE;
g_signal_connect (app, "activate", G_CALLBACK (quit_activate), NULL);
g_application_run (app, 1, argv);
g_object_unref (app);
g_object_unref (c);
- g_assert (quit_activated);
+ g_assert (activated);
+ g_assert (quitted);
session_bus_down ();
g_free (binpath);
@@ -436,8 +553,6 @@ on_activate (GApplication *app)
actions = g_action_group_list_actions (G_ACTION_GROUP (app));
g_assert (g_strv_length (actions) == 0);
g_strfreev (actions);
-
- g_idle_add (quit_app, app);
}
static void
@@ -526,6 +641,7 @@ main (int argc, char **argv)
g_test_add_func ("/gapplication/quit", test_quit);
g_test_add_func ("/gapplication/actions", test_actions);
g_test_add_func ("/gapplication/local-command-line", test_local_command_line);
+ g_test_add_func ("/gapplication/remote-command-line", test_remote_command_line);
return g_test_run ();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]