summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2020-05-31 23:32:44 +0000
committerMatthias Clasen <mclasen@redhat.com>2020-05-31 23:32:44 +0000
commited02bea20da1ab73e97c65dbcb6b3bd8f0d40d14 (patch)
tree0b43ae84d245bf9fe3b6d43a5be5525679d410ce
parentf89a1b05fec792ad7c23c70ad9dbf053217ab1d7 (diff)
parentaf65b7e6d7976c64d8dff3a2815c476a6d1a58a7 (diff)
downloadgtk+-ed02bea20da1ab73e97c65dbcb6b3bd8f0d40d14.tar.gz
Merge branch 'action-tests' into 'master'
Action tests See merge request GNOME/gtk!2003
-rw-r--r--testsuite/gtk/action.c298
1 files changed, 262 insertions, 36 deletions
diff --git a/testsuite/gtk/action.c b/testsuite/gtk/action.c
index 8f348a3f39..d64f876be5 100644
--- a/testsuite/gtk/action.c
+++ b/testsuite/gtk/action.c
@@ -15,23 +15,13 @@
*/
#include <gtk/gtk.h>
-static int win_activated;
-static int box_activated;
-
-static void
-win_activate (GSimpleAction *action,
- GVariant *parameter,
- gpointer user_data)
-{
- win_activated++;
-}
-
static void
-box_activate (GSimpleAction *action,
- GVariant *parameter,
- gpointer user_data)
+activate (GSimpleAction *action,
+ GVariant *parameter,
+ gpointer user_data)
{
- box_activated++;
+ int *activated = user_data;
+ (*activated)++;
}
/* Test that inheriting actions along the widget
@@ -40,20 +30,31 @@ box_activate (GSimpleAction *action,
* the effect of activating them.
*/
static void
-test_action (void)
+test_inheritance (void)
{
GtkWidget *window;
GtkWidget *box;
GtkWidget *button;
GSimpleActionGroup *win_actions;
GSimpleActionGroup *box_actions;
- GActionEntry win_entries[] = {
- { "action", win_activate, NULL, NULL, NULL },
- };
- GActionEntry box_entries[] = {
- { "action", box_activate, NULL, NULL, NULL },
+ GActionEntry entries[] = {
+ { "action", activate, NULL, NULL, NULL },
};
+ gboolean found;
+ int win_activated;
+ int box_activated;
+
+ win_activated = 0;
+ box_activated = 0;
+ /* Our hierarchy looks like this:
+ *
+ * window win.action
+ * |
+ * box box.action
+ * |
+ * button
+ */
window = gtk_window_new ();
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
button = gtk_button_new ();
@@ -63,15 +64,13 @@ test_action (void)
win_actions = g_simple_action_group_new ();
g_action_map_add_action_entries (G_ACTION_MAP (win_actions),
- win_entries,
- G_N_ELEMENTS (win_entries),
- NULL);
+ entries, G_N_ELEMENTS (entries),
+ &win_activated);
box_actions = g_simple_action_group_new ();
g_action_map_add_action_entries (G_ACTION_MAP (box_actions),
- box_entries,
- G_N_ELEMENTS (box_entries),
- NULL);
+ entries, G_N_ELEMENTS (entries),
+ &box_activated);
gtk_widget_insert_action_group (window, "win", G_ACTION_GROUP (win_actions));
gtk_widget_insert_action_group (box, "box", G_ACTION_GROUP (box_actions));
@@ -79,23 +78,27 @@ test_action (void)
g_assert_cmpint (win_activated, ==, 0);
g_assert_cmpint (box_activated, ==, 0);
- gtk_widget_activate_action (button, "win.action", NULL);
+ found = gtk_widget_activate_action (button, "win.action", NULL);
+ g_assert_true (found);
g_assert_cmpint (win_activated, ==, 1);
g_assert_cmpint (box_activated, ==, 0);
- gtk_widget_activate_action (box, "win.action", NULL);
+ found = gtk_widget_activate_action (box, "win.action", NULL);
+ g_assert_true (found);
g_assert_cmpint (win_activated, ==, 2);
g_assert_cmpint (box_activated, ==, 0);
- gtk_widget_activate_action (button, "box.action", NULL);
+ found = gtk_widget_activate_action (button, "box.action", NULL);
+ g_assert_true (found);
g_assert_cmpint (win_activated, ==, 2);
g_assert_cmpint (box_activated, ==, 1);
- gtk_widget_activate_action (window, "box.action", NULL);
+ found = gtk_widget_activate_action (window, "box.action", NULL);
+ g_assert_false (found);
g_assert_cmpint (win_activated, ==, 2);
g_assert_cmpint (box_activated, ==, 1);
@@ -104,6 +107,225 @@ test_action (void)
g_object_unref (box_actions);
}
+/* Test action inheritance with hierarchy changes */
+static void
+test_inheritance2 (void)
+{
+ GtkWidget *window;
+ GtkWidget *box;
+ GtkWidget *box1;
+ GtkWidget *box2;
+ GtkWidget *button;
+ GSimpleActionGroup *win_actions;
+ GSimpleActionGroup *box1_actions;
+ GSimpleActionGroup *box2_actions;
+ GActionEntry entries[] = {
+ { "action", activate, NULL, NULL, NULL },
+ };
+ gboolean found;
+ int win_activated;
+ int box1_activated;
+ int box2_activated;
+
+ win_activated = 0;
+ box1_activated = 0;
+ box2_activated = 0;
+
+ /* Our hierarchy looks like this:
+ *
+ * window win.action
+ * |
+ * box--------------------+
+ * | |
+ * box1 box1.action box2 box2.action;
+ * |
+ * button
+ */
+ window = gtk_window_new ();
+ box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ box1 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ box2 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ button = gtk_button_new ();
+
+ gtk_window_set_child (GTK_WINDOW (window), box);
+ gtk_box_append (GTK_BOX (box), box1);
+ gtk_box_append (GTK_BOX (box), box2);
+ gtk_box_append (GTK_BOX (box1), button);
+
+ win_actions = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (win_actions),
+ entries, G_N_ELEMENTS (entries),
+ &win_activated);
+
+ box1_actions = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (box1_actions),
+ entries, G_N_ELEMENTS (entries),
+ &box1_activated);
+
+ box2_actions = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (box2_actions),
+ entries, G_N_ELEMENTS (entries),
+ &box2_activated);
+
+ gtk_widget_insert_action_group (window, "win", G_ACTION_GROUP (win_actions));
+ gtk_widget_insert_action_group (box1, "box1", G_ACTION_GROUP (box1_actions));
+ gtk_widget_insert_action_group (box2, "box2", G_ACTION_GROUP (box2_actions));
+
+ g_assert_cmpint (win_activated, ==, 0);
+ g_assert_cmpint (box1_activated, ==, 0);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ found = gtk_widget_activate_action (button, "win.action", NULL);
+
+ g_assert_true (found);
+ g_assert_cmpint (win_activated, ==, 1);
+ g_assert_cmpint (box1_activated, ==, 0);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ found = gtk_widget_activate_action (button, "box1.action", NULL);
+
+ g_assert_true (found);
+ g_assert_cmpint (win_activated, ==, 1);
+ g_assert_cmpint (box1_activated, ==, 1);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ found = gtk_widget_activate_action (button, "box2.action", NULL);
+
+ g_assert_false (found);
+ g_assert_cmpint (win_activated, ==, 1);
+ g_assert_cmpint (box1_activated, ==, 1);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ g_object_ref (button);
+ gtk_box_remove (GTK_BOX (box1), button);
+ gtk_box_append (GTK_BOX (box2), button);
+ g_object_unref (button);
+
+ found = gtk_widget_activate_action (button, "win.action", NULL);
+
+ g_assert_true (found);
+ g_assert_cmpint (win_activated, ==, 2);
+ g_assert_cmpint (box1_activated, ==, 1);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ found = gtk_widget_activate_action (button, "box1.action", NULL);
+
+ g_assert_false (found);
+ g_assert_cmpint (win_activated, ==, 2);
+ g_assert_cmpint (box1_activated, ==, 1);
+ g_assert_cmpint (box2_activated, ==, 0);
+
+ found = gtk_widget_activate_action (button, "box2.action", NULL);
+
+ g_assert_true (found);
+ g_assert_cmpint (win_activated, ==, 2);
+ g_assert_cmpint (box1_activated, ==, 1);
+ g_assert_cmpint (box2_activated, ==, 1);
+
+ gtk_window_destroy (GTK_WINDOW (window));
+
+ g_object_unref (win_actions);
+ g_object_unref (box1_actions);
+ g_object_unref (box2_actions);
+}
+
+/* Similar to test_inheritance2, but using the actionable machinery
+ */
+static void
+test_inheritance3 (void)
+{
+ GtkWidget *window;
+ GtkWidget *box;
+ GtkWidget *box1;
+ GtkWidget *box2;
+ GtkWidget *button;
+ GSimpleActionGroup *win_actions;
+ GSimpleActionGroup *box1_actions;
+ GActionEntry entries[] = {
+ { "action", activate, NULL, NULL, NULL },
+ };
+ int activated;
+
+ /* Our hierarchy looks like this:
+ *
+ * window win.action
+ * |
+ * box--------------------+
+ * | |
+ * box1 box1.action box2
+ * |
+ * button
+ */
+ window = gtk_window_new ();
+ box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ box1 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ box2 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ button = gtk_button_new ();
+
+ gtk_window_set_child (GTK_WINDOW (window), box);
+ gtk_box_append (GTK_BOX (box), box1);
+ gtk_box_append (GTK_BOX (box), box2);
+ gtk_box_append (GTK_BOX (box1), button);
+
+ win_actions = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (win_actions),
+ entries, G_N_ELEMENTS (entries),
+ &activated);
+
+ box1_actions = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (box1_actions),
+ entries, G_N_ELEMENTS (entries),
+ &activated);
+
+ gtk_widget_insert_action_group (window, "win", G_ACTION_GROUP (win_actions));
+ gtk_widget_insert_action_group (box1, "box1", G_ACTION_GROUP (box1_actions));
+
+ gtk_actionable_set_action_name (GTK_ACTIONABLE (button), "box1.action");
+
+ g_assert_true (gtk_widget_get_sensitive (button));
+
+ g_object_ref (button);
+ gtk_box_remove (GTK_BOX (box1), button);
+ gtk_box_append (GTK_BOX (box2), button);
+ g_object_unref (button);
+
+ g_assert_false (gtk_widget_get_sensitive (button));
+
+ g_object_ref (button);
+ gtk_box_remove (GTK_BOX (box2), button);
+ gtk_box_append (GTK_BOX (box1), button);
+ g_object_unref (button);
+
+ g_assert_true (gtk_widget_get_sensitive (button));
+
+ g_object_ref (button);
+ gtk_box_remove (GTK_BOX (box1), button);
+ gtk_box_append (GTK_BOX (box2), button);
+ g_object_unref (button);
+
+ g_assert_false (gtk_widget_get_sensitive (button));
+
+ g_object_ref (box2);
+ gtk_box_remove (GTK_BOX (box), box2);
+ gtk_box_append (GTK_BOX (box1), box2);
+ g_object_unref (box2);
+
+ g_assert_true (gtk_widget_get_sensitive (button));
+
+ gtk_widget_insert_action_group (box1, "box1", NULL);
+
+ g_assert_false (gtk_widget_get_sensitive (button));
+
+ gtk_widget_insert_action_group (box1, "box1", G_ACTION_GROUP (box1_actions));
+
+ g_assert_true (gtk_widget_get_sensitive (button));
+
+ gtk_window_destroy (GTK_WINDOW (window));
+
+ g_object_unref (win_actions);
+ g_object_unref (box1_actions);
+}
+
static int cut_activated;
static int copy_activated;
static int paste_activated;
@@ -199,13 +421,15 @@ test_overlap (void)
GtkWidget *window;
GtkWidget *box;
GActionEntry win_entries[] = {
- { "win", win_activate, NULL, NULL, NULL },
+ { "win", activate, NULL, NULL, NULL },
};
GActionEntry box_entries[] = {
- { "box", box_activate, NULL, NULL, NULL },
+ { "box", activate, NULL, NULL, NULL },
};
GSimpleActionGroup *win_actions;
GSimpleActionGroup *box_actions;
+ int win_activated;
+ int box_activated;
window = gtk_window_new ();
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
@@ -216,13 +440,13 @@ test_overlap (void)
g_action_map_add_action_entries (G_ACTION_MAP (win_actions),
win_entries,
G_N_ELEMENTS (win_entries),
- NULL);
+ &win_activated);
box_actions = g_simple_action_group_new ();
g_action_map_add_action_entries (G_ACTION_MAP (box_actions),
box_entries,
G_N_ELEMENTS (box_entries),
- NULL);
+ &box_activated);
gtk_widget_insert_action_group (window, "actions", G_ACTION_GROUP (win_actions));
gtk_widget_insert_action_group (box, "actions", G_ACTION_GROUP (box_actions));
@@ -434,7 +658,9 @@ main (int argc,
{
gtk_test_init (&argc, &argv);
- g_test_add_func ("/action/inheritance", test_action);
+ g_test_add_func ("/action/inheritance", test_inheritance);
+ g_test_add_func ("/action/inheritance2", test_inheritance2);
+ g_test_add_func ("/action/inheritance3", test_inheritance3);
g_test_add_func ("/action/text", test_text);
g_test_add_func ("/action/overlap", test_overlap);
g_test_add_func ("/action/overlap2", test_overlap2);