elementary/dayselector - New widget Elc_dayselector
[framework/uifw/elementary.git] / src / bin / test.c
index 48f7144..a363bdb 100644 (file)
@@ -1,4 +1,5 @@
 #include <Elementary.h>
+#include "test.h"
 #ifdef HAVE_CONFIG_H
 # include "elementary_config.h"
 #endif
@@ -11,9 +12,12 @@ void test_bg_options(void *data, Evas_Object *obj, void *event_info);
 void test_icon(void *data, Evas_Object *obj, void *event_info);
 void test_box_vert(void *data, Evas_Object *obj, void *event_info);
 void test_box_vert2(void *data, Evas_Object *obj, void *event_info);
+void test_box_pack(void *data, Evas_Object *obj, void *event_info);
 void test_box_horiz(void *data, Evas_Object *obj, void *event_info);
+void test_box_homo(void *data, Evas_Object *obj, void *event_info);
 void test_box_transition(void *data, Evas_Object *obj, void *event_info);
 void test_button(void *data, Evas_Object *obj, void *event_info);
+void test_cnp(void *data, Evas_Object *obj, void *event_info);
 void test_transit(void *data, Evas_Object *obj, void *event_info);
 void test_transit2(void *data, Evas_Object *obj, void *event_info);
 void test_transit3(void *data, Evas_Object *obj, void *event_info);
@@ -28,6 +32,7 @@ void test_fileselector_entry(void *data, Evas_Object *obj, void *event_info);
 void test_toggle(void *data, Evas_Object *obj, void *event_info);
 void test_clock(void *data, Evas_Object *obj, void *event_info);
 void test_clock2(void *data, Evas_Object *obj, void *event_info);
+void test_clock3(void *data, Evas_Object *obj, void *event_info);
 void test_check(void *data, Evas_Object *obj, void *event_info);
 void test_radio(void *data, Evas_Object *obj, void *event_info);
 void test_layout(void *data, Evas_Object *obj, void *event_info);
@@ -38,15 +43,21 @@ void test_entry_scrolled(void *data, Evas_Object *obj, void *event_info);
 void test_entry3(void *data, Evas_Object *obj, void *event_info);
 void test_entry4(void *data, Evas_Object *obj, void *event_info);
 void test_entry5(void *data, Evas_Object *obj, void *event_info);
+void test_entry6(void *data, Evas_Object *obj, void *event_info);
+void test_entry7(void *data, Evas_Object *obj, void *event_info);
+void test_entry8(void *data, Evas_Object *obj, void *event_info);
 void test_entry_notepad(void *data, Evas_Object *obj, void *event_info);
-void test_anchorview(void *data, Evas_Object *obj, void *event_info);
-void test_anchorblock(void *data, Evas_Object *obj, void *event_info);
+void test_multibuttonentry(void *data, Evas_Object *obj, void *event_info);
+void test_entry_anchor2(void *data, Evas_Object *obj, void *event_info);
+void test_entry_anchor(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar2(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar3(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar4(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar5(void *data, Evas_Object *obj, void *event_info);
 void test_toolbar6(void *data, Evas_Object *obj, void *event_info);
+void test_toolbar7(void *data, Evas_Object *obj, void *event_info);
+void test_toolbar8(void *data, Evas_Object *obj, void *event_info);
 void test_hoversel(void *data, Evas_Object *obj, void *event_info);
 void test_list(void *data, Evas_Object *obj, void *event_info);
 void test_list_horizontal(void *data, Evas_Object *obj, void *event_info);
@@ -72,18 +83,23 @@ void test_genlist9(void *data, Evas_Object *obj, void *event_info);
 void test_genlist10(void *data, Evas_Object *obj, void *event_info);
 void test_genlist11(void *data, Evas_Object *obj, void *event_info);
 void test_genlist12(void *data, Evas_Object *obj, void *event_info);
+void test_genlist13(void *data, Evas_Object *obj, void *event_info);
+void test_genlist14(void *data, Evas_Object *obj, void *event_info);
+void test_genlist15(void *data, Evas_Object *obj, void *event_info);
+void test_genlist16(void *data, Evas_Object *obj, void *event_info);
 void test_gesture_layer(void *data, Evas_Object *obj, void *event_info);
+void test_gesture_layer2(void *data, Evas_Object *obj, void *event_info);
+void test_gesture_layer3(void *data, Evas_Object *obj, void *event_info);
 void test_table(void *data, Evas_Object *obj, void *event_info);
 void test_table2(void *data, Evas_Object *obj, void *event_info);
 void test_table3(void *data, Evas_Object *obj, void *event_info);
 void test_table4(void *data, Evas_Object *obj, void *event_info);
 void test_table5(void *data, Evas_Object *obj, void *event_info);
 void test_table6(void *data, Evas_Object *obj, void *event_info);
+void test_table7(void *data, Evas_Object *obj, void *event_info);
 void test_gengrid(void *data, Evas_Object *obj, void *event_info);
 void test_gengrid2(void *data, Evas_Object *obj, void *event_info);
 void test_gengrid3(void *data, Evas_Object *obj, void *event_info);
-void test_pager(void *data, Evas_Object *obj, void *event_info);
-void test_pager_slide(void *data, Evas_Object *obj, void *event_info);
 void test_win_state(void *data, Evas_Object *obj, void *event_info);
 void test_win_state2(void *data, Evas_Object *obj, void *event_info);
 void test_progressbar(void *data, Evas_Object *obj, void *event_info);
@@ -94,6 +110,7 @@ void test_scroller2(void *data, Evas_Object *obj, void *event_info);
 void test_spinner(void *data, Evas_Object *obj, void *event_info);
 void test_index(void *data, Evas_Object *obj, void *event_info);
 void test_index2(void *data, Evas_Object *obj, void *event_info);
+void test_index3(void *data, Evas_Object *obj, void *event_info);
 void test_photocam(void *data, Evas_Object *obj, void *event_info);
 void test_photo(void *data, Evas_Object *obj, void *event_info);
 void test_thumb(void *data, Evas_Object *obj, void *event_info);
@@ -127,9 +144,11 @@ void test_tooltip2(void *data, Evas_Object *obj, void *event_info);
 void test_cursor(void *data, Evas_Object *obj, void *event_info);
 void test_cursor2(void *data, Evas_Object *obj, void *event_info);
 void test_cursor3(void *data, Evas_Object *obj, void *event_info);
+void test_cursor4(void *data, Evas_Object *obj, void *event_info);
 void test_focus(void *data, Evas_Object *obj, void *event_info);
 void test_focus2(void *data, Evas_Object *obj, void *event_info);
 void test_focus3(void *data, Evas_Object *obj, void *event_info);
+void test_focus4(void *data, Evas_Object *obj, void *event_info);
 void test_flipselector(void *data, Evas_Object *obj, void *event_info);
 void test_diskselector(void *data, Evas_Object *obj, void *event_info);
 void test_colorselector(void *data, Evas_Object *obj, void *event_info);
@@ -138,21 +157,32 @@ void test_bubble(void *data, Evas_Object *obj, void *event_info);
 void test_segment_control(void *data, Evas_Object *obj, void *event_info);
 void test_store(void *data, Evas_Object *obj, void *event_info);
 void test_win_inline(void *data, Evas_Object *obj, void *event_info);
+void test_win_socket(void *data, Evas_Object *obj, void *event_info);
+void test_win_plug(void *data, Evas_Object *obj, void *event_info);
 void test_grid(void *data, Evas_Object *obj, void *event_info);
 void test_glview_simple(void *data, Evas_Object *obj, void *event_info);
 void test_glview(void *data, Evas_Object *obj, void *event_info);
 void test_3d(void *data, Evas_Object *obj, void *event_info);
 void test_naviframe(void *data, Evas_Object *obj, void *event_info);
-void test_factory(void *data, Evas_Object *obj, void *event_info);
+//void test_factory(void *data, Evas_Object *obj, void *event_info);
+void test_datetime(void *data, Evas_Object *obj, void *event_info);
+void test_popup(void *data, Evas_Object *obj, void *event_info);
+void test_dayselector(void *data, Evas_Object *obj, void *event_info);
+#ifdef HAVE_EMOTION
+void test_video(void *data, Evas_Object *obj, void *event_info);
+#endif
 #ifdef HAVE_EIO
 void test_eio(void *data, Evas_Object *obj, void *event_info);
 #endif
 #ifdef HAVE_ELEMENTARY_WEB
-void test_web(void *data, Evas_Object *obj, void *event_info);
+void test_web_normal(void *data, Evas_Object *obj, void *event_info);
+void test_web_mobile(void *data, Evas_Object *obj, void *event_info);
 #endif
 
 struct elm_test
 {
+   const char *icon;
+   const char *category;
    const char *name;
    void (*cb)(void *, Evas_Object *, void *);
 };
@@ -161,46 +191,50 @@ static int
 elm_test_sort(const void *pa, const void *pb)
 {
    const struct elm_test *a = pa, *b = pb;
+   int res = strcasecmp(a->category, b->category);
+   if (res) return res;
    return strcasecmp(a->name, b->name);
 }
 
 static void
-elm_test_add(Eina_List **p_list, const char *name, void (*cb)(void *, Evas_Object *, void *))
+elm_test_add(Eina_List **p_list, const char *icon, const char *category, const char *name, void (*cb)(void *, Evas_Object *, void *))
 {
    struct elm_test *t = malloc(sizeof(struct elm_test));
+   t->icon = icon;
+   t->category = category;
    t->name = name;
    t->cb = cb;
    *p_list = eina_list_sorted_insert(*p_list, elm_test_sort, t);
 }
 
-static void
+void
 my_win_del(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   /* called when my_win_main is requested to be deleted */
    elm_exit(); /* exit the program's main loop that runs in elm_run() */
 }
 
 static void
-index_changed(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
+_ui_tg_changed(void *data, Evas_Object *obj, void *event_info)
 {
-   elm_list_item_show(event_info);
+   (void) data; (void) event_info;
+   elm_config_mirrored_set(elm_check_state_get(obj));
 }
 
 static void
-_ui_tg_changed(void *data, Evas_Object *obj, void *event_info)
+_frame_clicked(void *data __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
 {
-   (void) data; (void) event_info;
-   elm_mirrored_set(elm_check_state_get(obj));
+   printf("frame %p is: %s\n", obj, elm_frame_collapse_get(obj) ? "collapsed" : "expanded");
 }
 
-
 static void
 my_win_main(char *autorun, Eina_Bool test_win_only)
 {
-   Evas_Object *win = NULL, *bg = NULL, *bx0 = NULL, *lb = NULL, *li = NULL;
-   Evas_Object *idx = NULL, *fr = NULL, *tg = NULL;
+   Evas_Object *win = NULL, *bg = NULL, *bx0 = NULL, *lb = NULL;
+   Evas_Object *fr = NULL, *tg = NULL, *sc = NULL, *ic = NULL;
+   Evas_Object *tbx = NULL, *cfr = NULL, *tbx2 = NULL, *bt = NULL;
    Eina_List *tests, *l;
-   struct elm_test *t;
+   struct elm_test *t = NULL;
+   void *tt;
 
    if (test_win_only) goto add_tests;
    /* Create an elm window - It returns an evas object. This is a little
@@ -228,8 +262,8 @@ my_win_main(char *autorun, Eina_Bool test_win_only)
 
    /* Add a background to our window. This just uses the standard theme set
     * background. Without a background, you could make a window seem
-    * transparent with elm_win_alpha_set(win, 1); For example. if you have
-    * a compositor running this will make the window able to be
+    * transparent with elm_win_alpha_set(win, EINA_TRUE); For example. if you
+    * have a compositor running this will make the window able to be
     * semi-transparent and any space not filled by object/widget pixels will
     * be transparent or translucent based on alpha. If you do not have a
     * compositor running this should fall back to using shaped windows
@@ -255,229 +289,368 @@ my_win_main(char *autorun, Eina_Bool test_win_only)
    evas_object_show(bx0);
 
    fr = elm_frame_add(win);
+   evas_object_smart_callback_add(fr, "clicked", _frame_clicked, NULL);
+   elm_frame_autocollapse_set(fr, EINA_TRUE);
    elm_object_text_set(fr, "Information");
    elm_box_pack_end(bx0, fr);
    evas_object_show(fr);
 
    lb = elm_label_add(win);
    elm_object_text_set(lb,
-                       "Please select a test from the list below<br>"
-                       "by clicking the test button to show the<br>"
+                       "Please select a test from the list below<br/>"
+                       "by clicking the test button to show the<br/>"
                        "test window.");
-   elm_frame_content_set(fr, lb);
+   elm_object_content_set(fr, lb);
    evas_object_show(lb);
 
    tg = elm_check_add(win);
    elm_object_style_set(tg, "toggle");
    elm_object_text_set(tg, "UI-Mirroring:");
-   elm_check_state_set(tg, elm_mirrored_get());
+   elm_check_state_set(tg, elm_config_mirrored_get());
    evas_object_smart_callback_add(tg, "changed", _ui_tg_changed, NULL);
    elm_box_pack_end(bx0, tg);
    evas_object_show(tg);
 
-   li = elm_list_add(win);
-   elm_list_always_select_mode_set(li, 1);
-   evas_object_size_hint_weight_set(li, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-   evas_object_size_hint_fill_set(li, EVAS_HINT_FILL, EVAS_HINT_FILL);
-   elm_box_pack_end(bx0, li);
-   evas_object_show(li);
+   sc = elm_scroller_add(win);
+   elm_scroller_bounce_set(sc, EINA_FALSE, EINA_TRUE);
+   evas_object_size_hint_weight_set(sc, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_fill_set(sc, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   elm_box_pack_end(bx0, sc);
+   evas_object_show(sc);
 
-   idx = elm_index_add(win);
-   evas_object_smart_callback_add(idx, "delay,changed", index_changed, NULL);
-   evas_object_size_hint_weight_set(idx, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-   elm_win_resize_object_add(win, idx);
-   evas_object_show(idx);
+   tbx = elm_box_add(win);
+   evas_object_size_hint_weight_set(tbx, EVAS_HINT_EXPAND, 0.0);
+   evas_object_size_hint_align_set(tbx, EVAS_HINT_FILL, 0.0);
+   elm_object_content_set(sc, tbx);
+   evas_object_show(tbx);
 
 add_tests:
    tests = NULL;
-#define ADD_TEST(name_, cb_) elm_test_add(&tests, name_, cb_)
-   ADD_TEST("Bg Plain", test_bg_plain);
-   ADD_TEST("Bg Image", test_bg_image);
-   ADD_TEST("Bg Options", test_bg_options);
-   ADD_TEST("Icon Transparent", test_icon);
-   ADD_TEST("Icon Animation", test_icon_animated);
-   ADD_TEST("Box Vert", test_box_vert);
-   ADD_TEST("Box Vert 2", test_box_vert2);
-   ADD_TEST("Box Horiz", test_box_horiz);
-   ADD_TEST("Box Transition", test_box_transition);
-   ADD_TEST("Buttons", test_button);
-   ADD_TEST("Transit", test_transit);
-   ADD_TEST("Transit 2", test_transit2);
-   ADD_TEST("Transit 3", test_transit3);
-   ADD_TEST("Transit 4", test_transit4);
-   ADD_TEST("Transit 5", test_transit5);
-   ADD_TEST("Transit 6", test_transit6);
-   ADD_TEST("Transit 7", test_transit7);
-   ADD_TEST("Transit 8", test_transit8);
-   ADD_TEST("Transit 9", test_transit9);
-   ADD_TEST("File Selector Button", test_fileselector_button);
-   ADD_TEST("File Selector Entry", test_fileselector_entry);
-   ADD_TEST("Toggles", test_toggle);
-   ADD_TEST("Table", test_table);
-   ADD_TEST("Table Homogeneous", test_table2);
-   ADD_TEST("Table 3", test_table3);
-   ADD_TEST("Table 4", test_table4);
-   ADD_TEST("Table 5", test_table5);
-   ADD_TEST("Table 6", test_table6);
-   ADD_TEST("Clock", test_clock);
-   ADD_TEST("Clock 2", test_clock2);
-   ADD_TEST("Layout", test_layout);
-   ADD_TEST("Hover", test_hover);
-   ADD_TEST("Hover 2", test_hover2);
-   ADD_TEST("Entry", test_entry);
-   ADD_TEST("Entry Scrolled", test_entry_scrolled);
-   ADD_TEST("Entry 3", test_entry3);
-   ADD_TEST("Entry 4", test_entry4);
-   ADD_TEST("Entry 5", test_entry5);
-   ADD_TEST("Entry Notepad", test_entry_notepad);
-   ADD_TEST("Anchorview", test_anchorview);
-   ADD_TEST("Anchorblock", test_anchorblock);
-   ADD_TEST("Toolbar", test_toolbar);
-   ADD_TEST("Toolbar 2", test_toolbar2);
-   ADD_TEST("Toolbar 3", test_toolbar3);
-   ADD_TEST("Toolbar 4", test_toolbar4);
-   ADD_TEST("Toolbar 5", test_toolbar5);
-   ADD_TEST("Toolbar 6", test_toolbar6);
-   ADD_TEST("Hoversel", test_hoversel);
-   ADD_TEST("List", test_list);
-   ADD_TEST("List - Horizontal", test_list_horizontal);
-   ADD_TEST("List 2", test_list2);
-   ADD_TEST("List 3", test_list3);
-   ADD_TEST("List 4", test_list4);
-   ADD_TEST("List 5", test_list5);
-   ADD_TEST("Inwin", test_inwin);
-   ADD_TEST("Inwin 2", test_inwin2);
-   ADD_TEST("Scaling", test_scaling);
-   ADD_TEST("Scaling 2", test_scaling2);
-   ADD_TEST("Slider", test_slider);
-   ADD_TEST("Actionslider", test_actionslider);
-   ADD_TEST("Genlist", test_genlist);
-   ADD_TEST("Genlist 2", test_genlist2);
-   ADD_TEST("Genlist 3", test_genlist3);
-   ADD_TEST("Genlist 4", test_genlist4);
-   ADD_TEST("Genlist 5", test_genlist5);
-   ADD_TEST("Genlist 7", test_genlist7);
-   ADD_TEST("Genlist Tree", test_genlist6);
-   ADD_TEST("Genlist Group", test_genlist8);
-   ADD_TEST("Genlist Group Tree", test_genlist9);
-   ADD_TEST("Genlist Mode", test_genlist10);
-   ADD_TEST("Genlist Reorder Mode", test_genlist11);
+#define ADD_TEST(icon_, cat_, name_, cb_) elm_test_add(&tests, icon_, cat_, name_, cb_)
+
+   //------------------------------//
+   ADD_TEST(NULL, "Window / Background", "Bg Plain", test_bg_plain);
+   ADD_TEST(NULL, "Window / Background", "Bg Image", test_bg_image);
+   ADD_TEST(NULL, "Window / Background", "Bg Options", test_bg_options);
+   ADD_TEST(NULL, "Window / Background", "Window States", test_win_state);
+   ADD_TEST(NULL, "Window / Background", "Window States 2", test_win_state2);
+   ADD_TEST(NULL, "Window / Background", "Inwin", test_inwin);
+   ADD_TEST(NULL, "Window / Background", "Inwin 2", test_inwin2);
+   ADD_TEST(NULL, "Window / Background", "Window Inline", test_win_inline);
+   ADD_TEST(NULL, "Window / Background", "Window Socket", test_win_socket);
+   ADD_TEST(NULL, "Window / Background", "Window Plug", test_win_plug);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Images", "Icon Transparent", test_icon);
+   ADD_TEST(NULL, "Images", "Icon Animation", test_icon_animated);
+   ADD_TEST(NULL, "Images", "Photocam", test_photocam);
+   ADD_TEST(NULL, "Images", "Photo", test_photo);
+   ADD_TEST(NULL, "Images", "Thumb", test_thumb);
+   ADD_TEST(NULL, "Images", "Slideshow", test_slideshow);
+#ifdef HAVE_EMOTION
+   ADD_TEST(NULL, "Images", "Video", test_video);
+#endif
+
+   //------------------------------//
+   ADD_TEST(NULL, "Containers", "Box Vert", test_box_vert);
+   ADD_TEST(NULL, "Containers", "Box Vert 2", test_box_vert2);
+   ADD_TEST(NULL, "Containers", "Box Pack", test_box_pack);
+   ADD_TEST(NULL, "Containers", "Box Horiz", test_box_horiz);
+   ADD_TEST(NULL, "Containers", "Box Homogeneous", test_box_homo);
+   ADD_TEST(NULL, "Containers", "Box Transition", test_box_transition);
+   ADD_TEST(NULL, "Containers", "Table", test_table);
+   ADD_TEST(NULL, "Containers", "Table Homogeneous", test_table2);
+   ADD_TEST(NULL, "Containers", "Table 3", test_table3);
+   ADD_TEST(NULL, "Containers", "Table 4", test_table4);
+   ADD_TEST(NULL, "Containers", "Table 5", test_table5);
+   ADD_TEST(NULL, "Containers", "Table 6", test_table6);
+   ADD_TEST(NULL, "Containers", "Table 7", test_table7);
+   ADD_TEST(NULL, "Containers", "Layout", test_layout);
+   ADD_TEST(NULL, "Containers", "Grid", test_grid);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Entries", "Entry", test_entry);
+   ADD_TEST(NULL, "Entries", "Entry Scrolled", test_entry_scrolled);
+   ADD_TEST(NULL, "Entries", "Entry 3", test_entry3);
+   ADD_TEST(NULL, "Entries", "Entry 4", test_entry4);
+   ADD_TEST(NULL, "Entries", "Entry 5", test_entry5);
+   ADD_TEST(NULL, "Entries", "Entry 6", test_entry6);
+   ADD_TEST(NULL, "Entries", "Entry 7", test_entry7);
+   ADD_TEST(NULL, "Entries", "Entry 8", test_entry8);
+   ADD_TEST(NULL, "Entries", "Entry Notepad", test_entry_notepad);
+   ADD_TEST(NULL, "Entries", "Multibuttonentry", test_multibuttonentry);
+   ADD_TEST(NULL, "Entries", "Entry Anchor", test_entry_anchor);
+   ADD_TEST(NULL, "Entries", "Entry Anchor2", test_entry_anchor2);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Buttons", "Buttons", test_button);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Effects", "Transit", test_transit);
+   ADD_TEST(NULL, "Effects", "Transit 2", test_transit2);
+   ADD_TEST(NULL, "Effects", "Transit 3", test_transit3);
+   ADD_TEST(NULL, "Effects", "Transit 4", test_transit4);
+   ADD_TEST(NULL, "Effects", "Transit 5", test_transit5);
+   ADD_TEST(NULL, "Effects", "Transit 6", test_transit6);
+   ADD_TEST(NULL, "Effects", "Transit 7", test_transit7);
+   ADD_TEST(NULL, "Effects", "Transit 8", test_transit8);
+   ADD_TEST(NULL, "Effects", "Transit 9", test_transit9);
+   ADD_TEST(NULL, "Effects", "Flip", test_flip);
+   ADD_TEST(NULL, "Effects", "Flip 2", test_flip2);
+   ADD_TEST(NULL, "Effects", "Flip 3", test_flip3);
+   ADD_TEST(NULL, "Effects", "Flip Interactive", test_flip4);
+   ADD_TEST(NULL, "Effects", "Flip Page", test_flip_page);
+   ADD_TEST(NULL, "Effects", "Animation", test_anim);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Toolbars", "Toolbar", test_toolbar);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 2", test_toolbar2);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 3", test_toolbar3);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 4", test_toolbar4);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 5", test_toolbar5);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 6", test_toolbar6);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 7", test_toolbar7);
+   ADD_TEST(NULL, "Toolbars", "Toolbar 8", test_toolbar8);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Lists", "List", test_list);
+   ADD_TEST(NULL, "Lists", "List - Horizontal", test_list_horizontal);
+   ADD_TEST(NULL, "Lists", "List 2", test_list2);
+   ADD_TEST(NULL, "Lists", "List 3", test_list3);
+   ADD_TEST(NULL, "Lists", "List 4", test_list4);
+   ADD_TEST(NULL, "Lists", "List 5", test_list5);
+   ADD_TEST(NULL, "Lists", "Genlist", test_genlist);
+   ADD_TEST(NULL, "Lists", "Genlist 2", test_genlist2);
+   ADD_TEST(NULL, "Lists", "Genlist 3", test_genlist3);
+   ADD_TEST(NULL, "Lists", "Genlist 4", test_genlist4);
+   ADD_TEST(NULL, "Lists", "Genlist 5", test_genlist5);
+   ADD_TEST(NULL, "Lists", "Genlist 7", test_genlist7);
+   ADD_TEST(NULL, "Lists", "Genlist Tree", test_genlist6);
+   ADD_TEST(NULL, "Lists", "Genlist Group", test_genlist8);
+   ADD_TEST(NULL, "Lists", "Genlist Group Tree", test_genlist9);
+   ADD_TEST(NULL, "Lists", "Genlist Mode", test_genlist10);
+   ADD_TEST(NULL, "Lists", "Genlist Reorder Mode", test_genlist11);
 #ifdef HAVE_EIO
-   ADD_TEST("Genlist Eio", test_eio);
+   ADD_TEST(NULL, "Lists", "Genlist Eio", test_eio);
 #endif
-   ADD_TEST("Genlist Textblock", test_genlist12);
-   ADD_TEST("GenGrid", test_gengrid);
-   ADD_TEST("GenGrid 2", test_gengrid2);
-   ADD_TEST("GenGrid Group", test_gengrid3);
-   ADD_TEST("Checks", test_check);
-   ADD_TEST("Radios", test_radio);
-   ADD_TEST("Pager", test_pager);
-   ADD_TEST("Pager Slide", test_pager_slide);
-   ADD_TEST("Window States", test_win_state);
-   ADD_TEST("Window States 2", test_win_state2);
-   ADD_TEST("Progressbar", test_progressbar);
-   ADD_TEST("File Selector", test_fileselector);
-   ADD_TEST("Separator", test_separator);
-   ADD_TEST("Scroller", test_scroller);
-   ADD_TEST("Scroller 2", test_scroller2);
-   ADD_TEST("Spinner", test_spinner);
-   ADD_TEST("Index", test_index);
-   ADD_TEST("Index 2", test_index2);
-   ADD_TEST("Photocam", test_photocam);
-   ADD_TEST("Photo", test_photo);
-   ADD_TEST("Thumb", test_thumb);
-   ADD_TEST("Icon Desktops", test_icon_desktops);
-   ADD_TEST("Notify", test_notify);
-   ADD_TEST("Slideshow", test_slideshow);
-   ADD_TEST("Menu", test_menu);
-   ADD_TEST("Panel", test_panel);
-   ADD_TEST("Panes", test_panes);
-   ADD_TEST("Map", test_map);
-   ADD_TEST("Weather", test_weather);
-   ADD_TEST("Flip", test_flip);
-   ADD_TEST("Flip 2", test_flip2);
-   ADD_TEST("Flip 3", test_flip3);
-   ADD_TEST("Flip Interactive", test_flip4);
-   ADD_TEST("Flip Page", test_flip_page);
-   ADD_TEST("Label", test_label);
-   ADD_TEST("Conformant", test_conformant);
-   ADD_TEST("Conformant 2", test_conformant2);
-   ADD_TEST("Multi Touch", test_multi);
-   ADD_TEST("Floating Objects", test_floating);
-   ADD_TEST("Launcher", test_launcher);
-   ADD_TEST("Launcher 2", test_launcher2);
-   ADD_TEST("Launcher 3", test_launcher3);
-   ADD_TEST("Animation", test_anim);
-   ADD_TEST("Calendar", test_calendar);
-   ADD_TEST("Calendar 2", test_calendar2);
-   ADD_TEST("Tooltip", test_tooltip);
-   ADD_TEST("Tooltip2", test_tooltip2);
-   ADD_TEST("Cursor", test_cursor);
-   ADD_TEST("Cursor 2", test_cursor2);
-   ADD_TEST("Cursor 3", test_cursor3);
-   ADD_TEST("Focus", test_focus);
-   ADD_TEST("Focus 2", test_focus2);
-   ADD_TEST("Focus 3", test_focus3);
-   ADD_TEST("Flip Selector", test_flipselector);
-   ADD_TEST("Disk Selector", test_diskselector);
-   ADD_TEST("Color Selector", test_colorselector);
-   ADD_TEST("Ctxpopup", test_ctxpopup);
-   ADD_TEST("Bubble", test_bubble);
-   ADD_TEST("Segment Control", test_segment_control);
-   ADD_TEST("Store", test_store);
-   ADD_TEST("Window Inline", test_win_inline);
-   ADD_TEST("Grid", test_grid);
-   ADD_TEST("GLViewSimple", test_glview_simple);
-   ADD_TEST("GLView", test_glview);
-   ADD_TEST("3D", test_3d);
-   ADD_TEST("Gesture Layer", test_gesture_layer);
-   ADD_TEST("Naviframe", test_naviframe);
-   ADD_TEST("Factory", test_factory);
+   ADD_TEST(NULL, "Lists", "Genlist Textblock", test_genlist12);
+   ADD_TEST(NULL, "Lists", "Genlist Tree, Insert Sorted", test_genlist13);
+   ADD_TEST(NULL, "Lists", "Genlist Tree, Insert Relative", test_genlist14);
+   ADD_TEST(NULL, "Lists", "Genlist Edit Mode", test_genlist15);
+   ADD_TEST(NULL, "Lists", "Genlist Flip Mode", test_genlist16);
+   ADD_TEST(NULL, "Lists", "GenGrid", test_gengrid);
+   ADD_TEST(NULL, "Lists", "GenGrid 2", test_gengrid2);
+   ADD_TEST(NULL, "Lists", "GenGrid Group", test_gengrid3);
+
+   //------------------------------//
+   ADD_TEST(NULL, "General", "Scaling", test_scaling);
+   ADD_TEST(NULL, "General", "Scaling 2", test_scaling2);
+
+   //------------------------------//
+   ADD_TEST(NULL, "3D", "GLViewSimple", test_glview_simple);
+   ADD_TEST(NULL, "3D", "GLView", test_glview);
+   ADD_TEST(NULL, "3D", "Evas Map 3D", test_3d);
+
+   //------------------------------//
 #ifdef HAVE_ELEMENTARY_WEB
-   ADD_TEST("Web", test_web);
+   ADD_TEST(NULL, "Web", "Web", test_web_normal);
+   ADD_TEST(NULL, "Web", "Web-mobile", test_web_mobile);
 #endif
+
+   //------------------------------//
+   ADD_TEST(NULL, "Input", "Gesture Layer", test_gesture_layer);
+   ADD_TEST(NULL, "Input", "Gesture Layer 2", test_gesture_layer2);
+   ADD_TEST(NULL, "Input", "Gesture Layer 3", test_gesture_layer3);
+   ADD_TEST(NULL, "Input", "Multi Touch", test_multi);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Selectors", "Index", test_index);
+   ADD_TEST(NULL, "Selectors", "Index 2", test_index2);
+   ADD_TEST(NULL, "Selectors", "Index 3", test_index3);
+   ADD_TEST(NULL, "Selectors", "File Selector", test_fileselector);
+   ADD_TEST(NULL, "Selectors", "File Selector Entry", test_fileselector_entry);
+   ADD_TEST(NULL, "Selectors", "File Selector Button", test_fileselector_button);
+   ADD_TEST(NULL, "Selectors", "Actionslider", test_actionslider);
+   ADD_TEST(NULL, "Selectors", "Menu", test_menu);
+   ADD_TEST(NULL, "Selectors", "Disk Selector", test_diskselector);
+   ADD_TEST(NULL, "Selectors", "Color Selector", test_colorselector);
+   ADD_TEST(NULL, "Selectors", "Segment Control", test_segment_control);
+   ADD_TEST(NULL, "Selectors", "Hoversel", test_hoversel);
+   ADD_TEST(NULL, "Selectors", "Radios", test_radio);
+   ADD_TEST(NULL, "Selectors", "Flip Selector", test_flipselector);
+   ADD_TEST(NULL, "Selectors", "Dayselector", test_dayselector);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Cursors", "Cursor", test_cursor);
+   ADD_TEST(NULL, "Cursors", "Cursor 2", test_cursor2);
+   ADD_TEST(NULL, "Cursors", "Cursor 3", test_cursor3);
+   ADD_TEST(NULL, "Cursors", "Cursor Layout", test_cursor4);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Scroller", "Scroller", test_scroller);
+   ADD_TEST(NULL, "Scroller", "Scroller 2", test_scroller2);
+
+   //------------------------------//
+   // FIXME: add frame test
+   ADD_TEST(NULL, "Boundaries", "Bubble", test_bubble);
+   ADD_TEST(NULL, "Boundaries", "Separator", test_separator);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Range Values", "Spinner", test_spinner);
+   ADD_TEST(NULL, "Range Values", "Slider", test_slider);
+   ADD_TEST(NULL, "Range Values", "Progressbar", test_progressbar);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Booleans", "Checks", test_check);
+   ADD_TEST(NULL, "Booleans", "Toggles", test_toggle);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Popups", "Ctxpopup", test_ctxpopup);
+   ADD_TEST(NULL, "Popups", "Hover", test_hover);
+   ADD_TEST(NULL, "Popups", "Hover 2", test_hover2);
+   ADD_TEST(NULL, "Popups", "Notify", test_notify);
+   ADD_TEST(NULL, "Popups", "Tooltip", test_tooltip);
+   ADD_TEST(NULL, "Popups", "Tooltip 2", test_tooltip2);
+   ADD_TEST(NULL, "Popups", "Popup", test_popup);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Times & Dates", "Calendar", test_calendar);
+   ADD_TEST(NULL, "Times & Dates", "Calendar 2", test_calendar2);
+   ADD_TEST(NULL, "Times & Dates", "Clock", test_clock);
+   ADD_TEST(NULL, "Times & Dates", "Clock 2", test_clock2);
+   ADD_TEST(NULL, "Times & Dates", "Clock 3", test_clock3);
+   ADD_TEST(NULL, "Times & Dates", "Datetime", test_datetime);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Text", "Label", test_label);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Stored Surface Buffer", "Launcher", test_launcher);
+   ADD_TEST(NULL, "Stored Surface Buffer", "Launcher 2", test_launcher2);
+   ADD_TEST(NULL, "Stored Surface Buffer", "Launcher 3", test_launcher3);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Focus", "Focus", test_focus);
+   ADD_TEST(NULL, "Focus", "Focus 2", test_focus2);
+   ADD_TEST(NULL, "Focus", "Focus 3", test_focus3);
+   ADD_TEST(NULL, "Focus", "Focus 4", test_focus4);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Storyboard", "Naviframe", test_naviframe);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Geographic", "Map", test_map);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Dividers", "Panel", test_panel);
+   ADD_TEST(NULL, "Dividers", "Panes", test_panes);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Standardization", "Conformant", test_conformant);
+   ADD_TEST(NULL, "Standardization", "Conformant 2", test_conformant2);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Helpers", "Store", test_store);
+//   ADD_TEST(NULL, "Helpers", "Factory", test_factory);
+
+   //------------------------------//
+   ADD_TEST(NULL, "Micellaneous", "Copy And Paste", test_cnp);
+   ADD_TEST(NULL, "Micellaneous", "Weather", test_weather);
+   ADD_TEST(NULL, "Micellaneous", "Icon Desktops", test_icon_desktops);
+   ADD_TEST(NULL, "Micellaneous", "Floating Objects", test_floating);
+
 #undef ADD_TEST
 
    if (autorun)
      {
+        size_t alen = strlen(autorun);
         EINA_LIST_FOREACH(tests, l, t)
-          if ((t->name) && (t->cb) && (!strcmp(t->name, autorun)))
-            t->cb(NULL, NULL, NULL);
+          {
+             if ((t->name) && (t->cb) && (!strncasecmp(t->name, autorun, alen)))
+               {
+                  t->cb(NULL, NULL, NULL);
+                  break;
+               }
+          }
 
      }
+   tt = t;
 
-   if (test_win_only) return;
+   if (test_win_only)
+     {
+        EINA_LIST_FREE(tests, t)
+           free (t);
+
+        return;
+     }
 
    if (tests)
      {
-        char last_letter = 0;
+        const char *pcat = NULL;
+
         EINA_LIST_FREE(tests, t)
           {
-             Elm_List_Item *it;
-             it = elm_list_item_append(li, t->name, NULL, NULL, t->cb, NULL);
-             if (last_letter != t->name[0])
+             if ((!pcat) || (strcmp(pcat, t->category)))
+               {
+                  cfr = elm_frame_add(win);
+                  // FIXME: add new style of frame for this
+                  evas_object_smart_callback_add(cfr, "clicked", _frame_clicked, NULL);
+                  elm_frame_autocollapse_set(cfr, EINA_TRUE);
+                  elm_object_text_set(cfr, t->category);
+                  evas_object_size_hint_weight_set(cfr, EVAS_HINT_EXPAND, 0.0);
+                  evas_object_size_hint_fill_set(cfr, EVAS_HINT_FILL, 0.0);
+                  elm_box_pack_end(tbx, cfr);
+                  evas_object_show(cfr);
+
+                  tbx2 = elm_box_add(win);
+                  elm_box_layout_set(tbx2, evas_object_box_layout_flow_horizontal, NULL, NULL);
+                  evas_object_size_hint_weight_set(tbx2, EVAS_HINT_EXPAND, 0.0);
+                  evas_object_size_hint_align_set(tbx2, EVAS_HINT_FILL, 0.0);
+                  elm_box_align_set(tbx2, 0.0, 0.5);
+                  elm_object_content_set(cfr, tbx2);
+                  evas_object_show(tbx2);
+               }
+             bt = elm_button_add(win);
+             // FIXME: add new style of button for this like efm in e17
+             elm_object_text_set(bt, t->name);
+             if (t->icon)
                {
-                  char letter[2] = {t->name[0], '\0'};
-                  elm_index_item_append(idx, letter, it);
-                  last_letter = t->name[0];
+                  char buf[PATH_MAX];
+
+                  ic = elm_icon_add(win);
+                  snprintf(buf, sizeof(buf), "%s/images/%s", elm_app_data_dir_get(), t->icon);
+                  elm_icon_file_set(ic, buf, NULL);
+                  elm_object_part_content_set(bt, "icon", ic);
+                  evas_object_show(ic);
                }
+             elm_box_pack_end(tbx2, bt);
+             evas_object_show(bt);
+             evas_object_smart_callback_add(bt, "clicked", t->cb, NULL);
+             pcat = t->category;
+             if (t == tt) tt = cfr;
              free(t);
           }
-        elm_index_item_go(idx, 0);
      }
 
-   elm_list_go(li);
-
    /* set an initial window size */
-   evas_object_resize(win, 320, 480);
+   evas_object_resize(win, 480, 480);
    /* show the window */
    if (!test_win_only)
-     evas_object_show(win);
+     {
+        evas_object_show(win);
+        /* bring in autorun frame */
+        if (autorun)
+          {
+             Evas_Coord x, y;
+             evas_object_geometry_get(tt, &x, &y, NULL, NULL);
+             elm_scroller_region_bring_in(sc, x, y, 0, 0);
+          }
+     }
 }
 
 /* this is your elementary main function - it MUST be called IMMEDIATELY
  * after elm_init() and MUST be passed argc and argv, and MUST be called
- * elm_main and not be static - must be a visible symbol with EAPI infront */
+ * elm_main and not be static - must be a visible symbol with EAPI_MAIN infront */
 EAPI_MAIN int
 elm_main(int argc, char **argv)
 {
@@ -500,7 +673,8 @@ elm_main(int argc, char **argv)
      {
         /* Just a workaround to make the shot module more
          * useful with elementary test. */
-        if (!strcmp(argv[1], "--test-win-only"))
+        if ((!strcmp(argv[1], "--test-win-only")) ||
+            (!strcmp(argv[1], "-to")))
           {
              test_win_only = EINA_TRUE;
              autorun = argv[2];
@@ -509,7 +683,7 @@ elm_main(int argc, char **argv)
 
    /* put here any init specific to this app like parsing args etc. */
    my_win_main(autorun, test_win_only); /* create main window */
-   elm_run(); /* and run the program now  and handle all events etc. */
+   elm_run(); /* and run the program now and handle all events etc. */
    /* if the mainloop that elm_run() runs exist - we exit the app */
    elm_shutdown(); /* clean up and shut down */
    /* exit code */