aboutsummaryrefslogtreecommitdiffstats
path: root/tests/ui-tests
diff options
context:
space:
mode:
authorbertrand <Bertrand.Guiheneuf@aful.org>1999-08-11 01:31:48 +0800
committerBertrand Guiheneuf <bertrand@src.gnome.org>1999-08-11 01:31:48 +0800
commit7d7f5423308313eb30558700598091b4ba1f0d20 (patch)
tree020433e7bc24d30d192737a4cce7c11314a38e4f /tests/ui-tests
parent6cb08f0bc177cd0de35b852fac94a181f4d2233c (diff)
downloadgsoc2013-evolution-7d7f5423308313eb30558700598091b4ba1f0d20.tar.gz
gsoc2013-evolution-7d7f5423308313eb30558700598091b4ba1f0d20.tar.zst
gsoc2013-evolution-7d7f5423308313eb30558700598091b4ba1f0d20.zip
Quick and (very) dirty hack to test Camel more easily.
1999-08-09 bertrand <Bertrand.Guiheneuf@aful.org> * tests/ui-tests/store_listing.c: * tests/ui-tests/store_listing.glade: Quick and (very) dirty hack to test Camel more easily. * camel/camel-folder.c (camel_folder_append_message): new method. svn path=/trunk/; revision=1102
Diffstat (limited to 'tests/ui-tests')
-rw-r--r--tests/ui-tests/Makefile.am1
-rw-r--r--tests/ui-tests/store_listing.c211
-rw-r--r--tests/ui-tests/store_listing.glade151
3 files changed, 335 insertions, 28 deletions
diff --git a/tests/ui-tests/Makefile.am b/tests/ui-tests/Makefile.am
index 19bbb6c8d4..8ed5393e8a 100644
--- a/tests/ui-tests/Makefile.am
+++ b/tests/ui-tests/Makefile.am
@@ -6,6 +6,7 @@ INCLUDES = -I$(top_srcdir)/intl -I$(top_srcdir)/camel \
LDADD = \
$(top_builddir)/camel/libcamel.la \
+ $(top_builddir)/camel/providers/MH/libcamelmh.la \
$(INTLLIBS) $(EXTRA_GNOME_LIBS)
diff --git a/tests/ui-tests/store_listing.c b/tests/ui-tests/store_listing.c
index 1eee741286..64f95f0b1d 100644
--- a/tests/ui-tests/store_listing.c
+++ b/tests/ui-tests/store_listing.c
@@ -1,4 +1,5 @@
-/* Bertrand.Guiheneuf@aful.org */
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/* Author : Bertrand.Guiheneuf@aful.org */
@@ -12,43 +13,213 @@
#include <gnome.h>
#include <glade/glade.h>
+#include "camel-folder.h"
+#include "camel-mh-folder.h"
+#include "camel-mh-store.h"
+#include "camel.h"
static GladeXML *xml;
+static void add_mail_store (const gchar *store_url);
+static void show_folder_messages (CamelFolder *folder);
+
void
-on_exit1_activate (GtkWidget *widget, void *data)
+mailbox_row_selected (GtkCTree *ctree, GList *node, gint column, gpointer user_data)
{
- gtk_main_quit ();
+ GtkCTreeNode *mailbox_node = GTK_CTREE_NODE (node);
+ CamelFolder *folder;
+ const gchar *mailbox_name;
+
+ folder = gtk_ctree_node_get_row_data (ctree, mailbox_node);
+ if (folder && IS_CAMEL_FOLDER (folder)) {
+ mailbox_name = camel_folder_get_name (folder);
+ printf ("Mailbox name : %s\n", mailbox_name);
+ show_folder_messages (folder);
+ } else {
+ printf ("Node is a store\n");
+ }
+
}
-void
-on_about1_activate (GtkWidget *widget, void *data)
+static void
+message_destroy_notify (gpointer data)
{
- GtkWidget *about_widget;
-
- about_widget = glade_xml_get_widget (xml, "about_widget");
- gtk_widget_show (about_widget);
+ CamelMimeMessage *message = CAMEL_MIME_MESSAGE (data);
+
+ gtk_object_unref (GTK_OBJECT (message));
+
}
-int
-main(int argc, char *argv[])
+
+static void
+show_folder_messages (CamelFolder *folder)
+{
+ GtkWidget *message_clist;
+ gint folder_message_count;
+ CamelMimeMessage *message;
+ gint i;
+ gchar *clist_row_text[3];
+ const char *sent_date, *subject, *sender;
+ gint current_row;
+
+ message_clist = glade_xml_get_widget (xml, "message-clist");
+
+ /* clear old message list */
+ gtk_clist_clear (GTK_CLIST (message_clist));
+
+ folder_message_count = camel_folder_get_message_count (folder);
+ for (i=0; i<folder_message_count; i++) {
+ message = camel_folder_get_message (folder, i);
+
+ sent_date = camel_mime_message_get_sent_date (message);
+ sender = camel_mime_message_get_from (message);
+ subject = camel_mime_message_get_subject (message);
+
+ if (sent_date) clist_row_text [0] = g_strdup (sent_date);
+ else clist_row_text [0] = g_strdup ('\0');
+ if (sender) clist_row_text [1] = g_strdup (sender);
+ else clist_row_text [1] = g_strdup ('\0');
+ if (subject) clist_row_text [2] = g_strdup (subject);
+ else clist_row_text [2] = g_strdup ('\0');
+
+ current_row = gtk_clist_append (GTK_CLIST (message_clist), clist_row_text);
+ gtk_clist_set_row_data_full (GTK_CLIST (message_clist), current_row, (gpointer)message, message_destroy_notify);
+ }
+
+
+
+}
+
+
+
+/* add a mail store given by its URL */
+static void
+add_mail_store (const gchar *store_url)
+{
+
+ CamelStore *store;
+ GtkWidget *mailbox_and_store_tree;
+ GtkCTreeNode* new_store_node;
+ GtkCTreeNode* new_folder_node;
+ char *new_tree_text[1];
+ GList *subfolder_list;
+ CamelFolder *root_folder;
+ CamelFolder *new_folder;
+
+
+ /* normally the store type is found automatically
+ with the URL, this is not implemented for
+ the moment */
+ store = gtk_type_new (CAMEL_MH_STORE_TYPE);
+ camel_store_init (store, (CamelSession *)NULL, g_strdup (store_url));
+
+ //store_list = g_list_append (store_list, (gpointer)store);
+ mailbox_and_store_tree = glade_xml_get_widget (xml, "store-and-mailbox-tree");
+ new_tree_text[0] = g_strdup (store_url);
+ new_store_node = gtk_ctree_insert_node (GTK_CTREE (mailbox_and_store_tree),
+ NULL,
+ NULL,
+ new_tree_text,
+ 0,
+ NULL,
+ NULL,
+ NULL,
+ NULL,
+ FALSE,
+ FALSE);
+
+ /* normally, use get_root_folder */
+ root_folder = camel_store_get_folder (store, "");
+ subfolder_list = camel_folder_list_subfolders (root_folder);
+ while (subfolder_list) {
+ new_tree_text[0] = subfolder_list->data;
+ new_folder = camel_store_get_folder (store, subfolder_list->data);
+ new_folder_node = gtk_ctree_insert_node (GTK_CTREE (mailbox_and_store_tree),
+ new_store_node,
+ NULL,
+ new_tree_text,
+ 0,
+ NULL,
+ NULL,
+ NULL,
+ NULL,
+ FALSE,
+ FALSE);
+
+
+ gtk_ctree_node_set_row_data (GTK_CTREE (mailbox_and_store_tree), new_folder_node, (gpointer)new_folder);
+ subfolder_list = subfolder_list->next;
+ }
+
+
+}
+
+
+/* ----- */
+void
+on_exit_activate (GtkWidget *widget, void *data)
+{
+ gtk_main_quit ();
+}
+
+
+void
+on_about_activate (GtkWidget *widget, void *data)
+{
+ GtkWidget *about_widget;
+
+ about_widget = glade_xml_get_widget (xml, "about_widget");
+ gtk_widget_show (about_widget);
+}
+
+void
+on_new_store_activate (GtkWidget *widget, void *data)
{
-
- gnome_init ("store_listing", "1.0", argc, argv);
+ GtkWidget *new_store_dialog;
+ GtkWidget *new_store_gnome_entry;
+ GtkWidget *new_store_entry;
+ gchar *url_text;
+
+
+ gint pressed_button;
+
+ new_store_dialog = glade_xml_get_widget (xml, "new_store_dialog");
+ pressed_button = gnome_dialog_run (GNOME_DIALOG (new_store_dialog));
+
+ if ((pressed_button != 0) && (pressed_button != 1))
+ return;
+
+ new_store_gnome_entry = glade_xml_get_widget (xml, "new-store-entry");
+ new_store_entry = gnome_entry_gtk_entry (GNOME_ENTRY (new_store_gnome_entry));
+ url_text = gtk_entry_get_text (GTK_ENTRY (new_store_entry));
+
+ if (url_text)
+ add_mail_store (url_text);
+
+}
- glade_gnome_init();
- xml = glade_xml_new ("store_listing.glade", NULL);
- if (xml) glade_xml_signal_autoconnect (xml);
-
- gtk_main ();
-
- return 0;
+
+int
+main(int argc, char *argv[])
+{
+
+ gnome_init ("store_listing", "1.0", argc, argv);
+
+ glade_gnome_init ();
+ camel_init ();
+ xml = glade_xml_new ("store_listing.glade", NULL);
+ if (xml) glade_xml_signal_autoconnect (xml);
+
+
+ gtk_main ();
+
+ return 0;
}
diff --git a/tests/ui-tests/store_listing.glade b/tests/ui-tests/store_listing.glade
index 32516494aa..d01d408db4 100644
--- a/tests/ui-tests/store_listing.glade
+++ b/tests/ui-tests/store_listing.glade
@@ -98,11 +98,11 @@
<widget>
<class>GtkPixmapMenuItem</class>
- <name>exit1</name>
+ <name>exit</name>
<signal>
<name>activate</name>
- <handler>on_exit1_activate</handler>
- <last_modification_time>Tue, 10 Aug 1999 10:25:52 GMT</last_modification_time>
+ <handler>on_exit_activate</handler>
+ <last_modification_time>Tue, 10 Aug 1999 12:06:35 GMT</last_modification_time>
</signal>
<stock_item>GNOMEUIINFO_MENU_EXIT_ITEM</stock_item>
</widget>
@@ -120,11 +120,11 @@
<widget>
<class>GtkPixmapMenuItem</class>
- <name>about1</name>
+ <name>about</name>
<signal>
<name>activate</name>
- <handler>on_about1_activate</handler>
- <last_modification_time>Tue, 10 Aug 1999 10:25:52 GMT</last_modification_time>
+ <handler>on_about_activate</handler>
+ <last_modification_time>Tue, 10 Aug 1999 12:06:58 GMT</last_modification_time>
</signal>
<stock_item>GNOMEUIINFO_MENU_ABOUT_ITEM</stock_item>
</widget>
@@ -163,6 +163,11 @@
<class>GtkButton</class>
<child_name>Toolbar:button</child_name>
<name>new_store_button</name>
+ <signal>
+ <name>clicked</name>
+ <handler>on_new_store_activate</handler>
+ <last_modification_time>Tue, 10 Aug 1999 12:17:17 GMT</last_modification_time>
+ </signal>
<label>new store</label>
<stock_pixmap>GNOME_STOCK_PIXMAP_NEW</stock_pixmap>
</widget>
@@ -179,8 +184,14 @@
<widget>
<class>GtkCTree</class>
- <name>ctree1</name>
+ <name>store-and-mailbox-tree</name>
+ <width>150</width>
<can_focus>True</can_focus>
+ <signal>
+ <name>tree_select_row</name>
+ <handler>mailbox_row_selected</handler>
+ <last_modification_time>Tue, 10 Aug 1999 16:25:40 GMT</last_modification_time>
+ </signal>
<columns>1</columns>
<column_widths>80</column_widths>
<selection_mode>GTK_SELECTION_SINGLE</selection_mode>
@@ -207,7 +218,7 @@
<widget>
<class>GtkCList</class>
- <name>clist1</name>
+ <name>message-clist</name>
<can_focus>True</can_focus>
<columns>3</columns>
<column_widths>80,80,80</column_widths>
@@ -286,4 +297,128 @@
<comments>This is a very simple program to test Camel</comments>
</widget>
+<widget>
+ <class>GnomeDialog</class>
+ <name>new_store_dialog</name>
+ <visible>False</visible>
+ <title>New store</title>
+ <type>GTK_WINDOW_TOPLEVEL</type>
+ <position>GTK_WIN_POS_NONE</position>
+ <modal>False</modal>
+ <allow_shrink>False</allow_shrink>
+ <allow_grow>False</allow_grow>
+ <auto_shrink>False</auto_shrink>
+ <auto_close>True</auto_close>
+ <hide_on_close>True</hide_on_close>
+
+ <widget>
+ <class>GtkVBox</class>
+ <child_name>GnomeDialog:vbox</child_name>
+ <name>dialog-vbox1</name>
+ <homogeneous>False</homogeneous>
+ <spacing>8</spacing>
+ <child>
+ <padding>4</padding>
+ <expand>True</expand>
+ <fill>True</fill>
+ </child>
+
+ <widget>
+ <class>GtkVBox</class>
+ <name>vbox1</name>
+ <homogeneous>False</homogeneous>
+ <spacing>0</spacing>
+ <child>
+ <padding>0</padding>
+ <expand>True</expand>
+ <fill>True</fill>
+ </child>
+
+ <widget>
+ <class>GtkLabel</class>
+ <name>new_store_label</name>
+ <style>
+ <style_font>-adobe-helvetica-bold-r-normal-*-*-140-*-*-p-*-iso8859-1</style_font>
+ </style>
+ <label>Enter complete store URL</label>
+ <justify>GTK_JUSTIFY_CENTER</justify>
+ <wrap>False</wrap>
+ <xalign>0.5</xalign>
+ <yalign>0.5</yalign>
+ <xpad>0</xpad>
+ <ypad>29</ypad>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>False</fill>
+ </child>
+ </widget>
+
+ <widget>
+ <class>GnomeEntry</class>
+ <name>new-store-entry</name>
+ <max_saved>10</max_saved>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>False</fill>
+ </child>
+
+ <widget>
+ <class>GtkEntry</class>
+ <child_name>GnomeEntry:entry</child_name>
+ <name>new-store-dialog-combo-entry</name>
+ <can_focus>True</can_focus>
+ <editable>True</editable>
+ <text_visible>True</text_visible>
+ <text_max_length>0</text_max_length>
+ <text></text>
+ </widget>
+ </widget>
+ </widget>
+
+ <widget>
+ <class>GtkHButtonBox</class>
+ <child_name>GnomeDialog:action_area</child_name>
+ <name>dialog-action_area1</name>
+ <layout_style>GTK_BUTTONBOX_END</layout_style>
+ <spacing>8</spacing>
+ <child_min_width>85</child_min_width>
+ <child_min_height>27</child_min_height>
+ <child_ipad_x>7</child_ipad_x>
+ <child_ipad_y>0</child_ipad_y>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>True</fill>
+ <pack>GTK_PACK_END</pack>
+ </child>
+
+ <widget>
+ <class>GtkButton</class>
+ <name>button1</name>
+ <can_default>True</can_default>
+ <can_focus>True</can_focus>
+ <stock_button>GNOME_STOCK_BUTTON_OK</stock_button>
+ </widget>
+
+ <widget>
+ <class>GtkButton</class>
+ <name>button2</name>
+ <can_default>True</can_default>
+ <can_focus>True</can_focus>
+ <stock_button>GNOME_STOCK_BUTTON_APPLY</stock_button>
+ </widget>
+
+ <widget>
+ <class>GtkButton</class>
+ <name>button3</name>
+ <can_default>True</can_default>
+ <can_focus>True</can_focus>
+ <stock_button>GNOME_STOCK_BUTTON_CANCEL</stock_button>
+ </widget>
+ </widget>
+ </widget>
+</widget>
+
</GTK-Interface>