# HG changeset patch # User gibus # Date 1394454282 -3600 # Node ID d334a616c0232aafc22307e478c49504bcb73eb9 # Parent fda73ac53450393cfc2290063f433dba5319e40c# Parent fd05075904139962a14654dc07b57d766de2e82c Merge diff -r fda73ac53450 -r d334a616c023 src/cm/scripts/test-suite/tests/tests.js --- a/src/cm/scripts/test-suite/tests/tests.js Mon Mar 10 13:24:19 2014 +0100 +++ b/src/cm/scripts/test-suite/tests/tests.js Mon Mar 10 13:24:42 2014 +0100 @@ -1,32 +1,39 @@ - -// try to login -// create texts and co-ments -// collect newly created URLs +// " Vim settings +// set tabstop=4 " number of spaces in a tab +// set softtabstop=4 " as above +// set shiftwidth=4 " as above -// Get workspace name, public texts… - -// unlog // check that public texts still work while unlogged // check that non public texts are unavailable - -// Is the workspace name correctly displayed ? // Are the public texts displayed in the login page ? -var w = __karma__.config.w; -const non_visible = false; -var text_nb = 0; -var user_nb = 0; -var pub_text_nb = 0; -var workspace_name = ''; -var workspace_tagline = ''; +var w = __karma__.config.w, + z = {}; +const non_visible = false, no_tagline = false; +const t = { + '#id_workspace_name': 'Test workspace name', + '#id_workspace_tagline': 'Test workspace tagline', + '#id_workspace_registration': 'on', // registration + '#id_workspace_registration_moderation': 'on', // registration moderation + '#id_workspace_role_model': 'generic', + '#id_workspace_category_1': 'ws_cat_1', + '#id_workspace_category_2': 'ws_cat_2', + '#id_workspace_category_3': 'ws_cat_3', + '#id_workspace_category_4': 'ws_cat_4', + '#id_workspace_category_5': 'ws_cat_5', + '#id_custom_css': ".voted {\n color: #008000;\n}\n\n.rejected, .fallen, .withdrawn {\n color: #ff0000;\n}\n\ndiv.frame {\n border: 1px solid #000;\n padding: 5px;\n}\n\ndiv.frame .title {\n font-weight: bold;\n text-align: center; font-color:purple; \n}", + '#id_custom_font': 'Ubuntu', + '#id_custom_titles_font': 'Ubuntu Monospaced', +}; + suite ('comt', function () { this.timeout(150000); - suite ('contact page', function () { + suite ('contact page conformity', function () { test_page_loading ('/contact/', 'Contact'); test_unlogged_header (); test_val ('form#profile[action="."]'); // the form exists @@ -47,13 +54,13 @@ })); }); - suite ('help page', function () { + suite ('help page conformity', function () { test_page_loading ('/help/', 'Help'); test_unlogged_header (); test_unlogged_footer (); }); - suite ('reset password page', function () { + suite ('reset password page conformity', function () { test_page_loading ('/password_reset/', 'Reset my password'); test_unlogged_header (); test_val ('form#profile[action="."]'); @@ -63,7 +70,7 @@ test_unlogged_footer (); }); - suite ('login page', function () { + suite ('login page conformity', function () { test_page_loading ('/', 'Home'); test_unlogged_header (); test_val ('form#login[action="/login/"]'); @@ -85,17 +92,56 @@ })); }); - suite ('admin dashboard', function () { - // Should starts with : - // test_page_loading ('/', 'Dashboard'); - // But its the last thing we did in the previous test + suite ('reading settings', function () { + test_page_loading ('/settings/', 'Settings'); + test_readz_field ('#id_workspace_name'); + test_readz_field ('#id_workspace_tagline'); + test_readz_field ('#id_workspace_registration'); + test_readz_field ('#id_workspace_registration_moderation'); + test_readz_field ('#id_workspace_role_model'); + test_readz_field ('#id_workspace_category_1'); + test_readz_field ('#id_workspace_category_2'); + test_readz_field ('#id_workspace_category_3'); + test_readz_field ('#id_workspace_category_4'); + test_readz_field ('#id_workspace_category_5'); + test_page_loading ('/settings/design/', 'Settings'); + test_readz_field ('#id_custom_css'); + test_readz_field ('#id_custom_font'); + test_readz_field ('#id_custom_titles_font'); + /*test ('display z', dsl(function () { + elt ('#main-tabs').text (function (t) { + console.log ('z '+JSON.stringify(z)); + }); + }));*/ + }); + + suite ('setting settings to test values', function () { + test_page_loading ('/settings/', 'Settings'); + test_fill_settings (t); + test_val ('#id_workspace_name', t['#id_workspace_name']); + test ('Save test settings ', dsl (function () { + elt ('#settings input[type="submit"]').click (); + browser.waitForPageLoad (); + })); + test_page_loading ('/settings/', 'Settings'); + test_text ('#content h1.main_title a[href="/"]', t['#id_workspace_name']); + test_page_loading ('/settings/design/', 'Settings'); + test_fill_design (t); + test ('Save test design settings ', dsl (function () { + elt ('#settings input[type="submit"]').click (); + browser.waitForPageLoad (); + })); + }); + + suite ('admin dashboard page conformity', function () { + test_page_loading ('/', 'Dashboard\n - '+t['#id_workspace_name']); test_logged_header (w.USER_ADMIN); test ('get text and user nb', dsl(function () { element ('span.metadata:eq(0)').text (function (metadata) { var r = metadata.match (/(\d+) texts, (\d+) users/); if (r.length != 3) throw 'expected 3 matches got '+r.length; - text_nb = r[1]; - user_nb = r[2]; + z.text_nb = r[1]; + z.user_nb = r[2]; }); })); test_default_tabs (); @@ -121,10 +167,10 @@ test_unlogged_footer (); }); - suite ('texts list', function () { - test_page_loading ('/text/', 'Texts'); - test_logged_header (w.USER_ADMIN); - test_default_tabs (); + suite ('texts list page conformity', function () { + test_page_loading ('/text/', 'Texts\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); test_count ('#text ul.sub_list:eq(0) a', 3); test_text ('#text ul.sub_list:eq(0) a:eq(0)[href="/create/content/"]', 'Create a text'); test_text ('#text ul.sub_list:eq(0) a:eq(1)[href="/create/upload/"]', 'Upload a text'); @@ -134,7 +180,7 @@ test_text ('select#tag_selected option:eq(0)[selected][value="0"]', '- All -', non_visible); test ('#texts_form input count', dsl (function () { elt ('form#texts_form[action="."] :input').count (function (c) { - var n = 3 + text_nb % 10; + var n = 3 + z.text_nb % 10; if (c != n) throw 'expected computed '+n+' to equal got '+c; }); })); @@ -142,7 +188,7 @@ elt ('span#paginator').text (function (t) { var r = t.match (/\s\d+-\d+ of (\d+)\s/m); if (r.length != 2) throw 'expected 2 matches got '+r.length; - if (r[1] != text_nb) throw 'expected paginator total ('+r[1]+') to be '+text_nb; + if (r[1] != z.text_nb) throw 'expected paginator total ('+r[1]+') to be '+z.text_nb; }); })); // TOTEST : pagination @@ -160,10 +206,244 @@ test_unlogged_footer (); }); - suite ('followup', function () { - test_logged_header (w.USER_ADMIN); - test_default_tabs (); - test_page_loading ('/followup/', 'Followup'); + suite ('create a text page conformity', function () { + test_page_loading ('/create/content/', 'Create a text - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#text ul.sub_list:eq(0) a', 3); + test_text ('#text ul.sub_list:eq(0) a:eq(0)[href="/text/"]', 'Text list'); + test_text ('#text ul.sub_list:eq(0) a:eq(1)[href="/create/upload/"]', 'Upload a text'); + test_text ('#text ul.sub_list:eq(0) a:eq(2)[href="/create/import/"]', 'Import a co-mented text'); + test_count ('#text form[action="."]:eq(0) :input', 6); + test_form_field ('text', 'id_title', 'text', 0, 'Title', true); + test_form_field ('text', 'id_format', 'select', 1, 'Format', true); + test_form_field ('text', 'id_content', 'textarea', 2, 'Content', true); + test_form_field ('text', 'id_tags', 'text', 3, 'Tags'); + test_val ('#text :input:eq(4)[type=submit]', 'Save'); + test_val ('#text :input:eq(5)#cancel_button[type=button]', 'Cancel'); + test_count ('select#id_format option', 3); + test_text ('select#id_format option:eq(0)[value="markdown"][selected]', 'markdown', non_visible); + test_text ('select#id_format option:eq(1)[value="rst"]', 'rst', non_visible); + test_text ('select#id_format option:eq(2)[value="html"]', 'html', non_visible); + test_count ('#markItUpId_content li', 20); + test_unlogged_footer (); + }); + + suite ('upload text page conformity', function () { + test_page_loading ('/create/upload/', 'Upload a text - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#text ul.sub_list:eq(0) a', 3); + test_text ('#text ul.sub_list:eq(0) a:eq(0)[href="/text/"]', 'Text list'); + test_text ('#text ul.sub_list:eq(0) a:eq(1)[href="/create/content/"]', 'Create a text'); + test_text ('#text ul.sub_list:eq(0) a:eq(2)[href="/create/import/"]', 'Import a co-mented text'); + test_count ('#text form[action="."]:eq(0) :input', 6); + test_form_field ('text', 'id_title', 'text', 0, 'Title'); + test_form_field ('text', 'id_format', 'select', 1, 'Format', true); + test_form_field ('text', 'id_tags', 'text', 2, 'Tags'); + test_form_field ('text', 'id_file', 'file', 3, 'Upload file (optional)'); + test_val ('#text :input:eq(4)[type=submit]', 'Save'); + test_val ('#text :input:eq(5)#cancel_button[type=button]', 'Cancel'); + test_count ('select#id_format option', 3); + test_text ('select#id_format option:eq(0)[value="markdown"][selected]', 'markdown', non_visible); + test_text ('select#id_format option:eq(1)[value="rst"]', 'rst', non_visible); + test_text ('select#id_format option:eq(2)[value="html"]', 'html', non_visible); + test_unlogged_footer (); + }); + + suite ('import a co-mented text page conformity', function () { + test_page_loading ('/create/import/', 'Import a co-mented text - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#text ul.sub_list:eq(0) a', 3); + test_text ('#text ul.sub_list:eq(0) a:eq(0)[href="/text/"]', 'Text list'); + test_text ('#text ul.sub_list:eq(0) a:eq(1)[href="/create/content/"]', 'Create a text'); + test_text ('#text ul.sub_list:eq(0) a:eq(2)[href="/create/upload/"]', 'Upload a text'); + test_count ('#text form[action="."]:eq(0) :input', 3); + test_form_field ('text', 'id_file', 'file', 0, 'Upload XML file', true); + test_val ('#text :input:eq(1)[type=submit]', 'Save'); + test_val ('#text :input:eq(2)#cancel_button[type=button]', 'Cancel'); + test_unlogged_footer (); + }); + + suite ('edit profile page conformity', function () { + test_page_loading ('/profile/', 'Your profile [(]'+w.USER_ADMIN+'[)]\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN, no_tagline); + test_count ('#content ul.sub_list:eq(0) a', 1); + test_text ('#content ul.sub_list:eq(0) a:eq(0)[href="/profile-pw/"]', 'Password'); + test_count ('form#profile[action="."]:eq(0) :input', 5); + test_form_field ('profile', 'id_email', 'text', 0, 'E-mail address', true); + test_form_field ('profile', 'id_first_name','text', 1, 'First name'); + test_form_field ('profile', 'id_last_name', 'text', 2, 'Last name'); + test_form_field ('profile', 'id_tags', 'text', 3, 'Tags'); + test_val ('#profile :input:eq(4)[type=submit]', 'Save'); + test_unlogged_footer (); + }); + + suite ('edit password page conformity', function () { + test_page_loading ('/profile-pw/', 'Your profile [(]'+w.USER_ADMIN+'[)]\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN, no_tagline); + test_count ('#content ul.sub_list:eq(0) a', 1); + test_text ('#content ul.sub_list:eq(0) a:eq(0)[href="/profile/"]', 'Profile'); + test_count ('form#profile[action="."]:eq(0) :input', 4); + test_form_field ('profile', 'id_old_password', 'password', 0, 'Old password', true); + test_form_field ('profile', 'id_new_password1', 'password', 1, 'New password', true); + test_form_field ('profile', 'id_new_password2', 'password', 2, 'New password confirmation', true); + test_val ('#profile :input:eq(3)[type=submit]', 'Save'); + test_unlogged_footer (); + }); + + suite ('people list page conformity', function () { + test_page_loading ('/user/', 'People\' list\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#user ul.sub_list:eq(0) a', 2); + test_text ('#user ul.sub_list:eq(0) a:eq(0)[href="/user/add/"]', 'Add a new user'); + test_text ('#user ul.sub_list:eq(0) a:eq(1)[href="/user/mass-add/"]', 'Add users in bulk'); + // TOTEST : filter by tag + test_count ('form#filter_form[action="."] :input', 1); + test_text ('#filter_form a[href="?display=1"]', 'Display suspended users'); + test_text ('select#tag_selected option:eq(0)[selected][value="0"]', '- All -', non_visible); + // TOTEST : pagination + // TOTEST : Bulk Actions -> Apply does enable + test_text ('select#bulk_actions option:eq(0)[selected][value="-1"]', '- Bulk Actions -', non_visible); + test_text ('select#bulk_actions option:eq(1)[value="disable"]', 'Suspend access', non_visible); + test_text ('select#bulk_actions option:eq(2)[value="enable"]', 'Enable access', non_visible); + test_text ('select#bulk_actions option:eq(3)[value="role_1"]', 'Change role to Manager', non_visible); + test_text ('select#bulk_actions option:eq(4)[value="role_2"]', 'Change role to Editor', non_visible); + test_text ('select#bulk_actions option:eq(5)[value="role_3"]', 'Change role to Moderator', non_visible); + test_text ('select#bulk_actions option:eq(6)[value="role_4"]', 'Change role to Commentator', non_visible); + test_text ('select#bulk_actions option:eq(7)[value="role_5"]', 'Change role to Observer', non_visible); + test_val ('form#user_form input#apply[type=button][disabled]', 'Apply'); + test_count ('table.large_table:eq(1) th', 6); + test_val ('table.large_table:eq(1) th:eq(0) input#all_check[type="checkbox"]', 'on'); + test_text ('table.large_table:eq(1) th:eq(1) a[href="?order=user__username"]', 'User'); + test_text ('table.large_table:eq(1) th:eq(2) a[href="?order=user__email"]', 'Email'); + test_text ('table.large_table:eq(1) th:eq(3) a[href="?order=-user__date_joined"]', 'Date joined'); + test_text ('table.large_table:eq(1) th:eq(4) a[href="?order=role__name"]', 'Role'); + test_text ('table.large_table:eq(1) th:eq(5)', 'Last week activity'); + test_text ('table.large_table:eq(1) tr:last a[href="/user/-/edit/"]', 'Anonymous users'); + test_text ('table.large_table:eq(1) a.main_object_title[href="/profile/"]', w.USER_ADMIN); + test_text ('table.large_table:eq(1) div.hidden-user-actions a[href="/profile/"]', 'Your profile'); + test_unlogged_footer (); + }); + + suite ('check user number', function () { + test_page_loading ('/user/?display=1', 'People\' list\n - '+t['#id_workspace_name']); + test ('#user_form input count', dsl (function () { + elt ('form#user_form[action="."] :input').count (function (c) { + var n = 6 + (z.user_nb % 10) * 2; + if (c != n) throw 'expected computed '+n+' to equal got '+c; + }); + })); + test ('#paginator "of #" value', dsl (function () { + elt ('span#paginator').text (function (t) { + var r = t.match (/\s\d+-\d+ of (\d+)\s/m); + if (r.length != 2) throw 'expected 2 matches got '+r.length; + if (r[1] != z.user_nb) throw 'expected paginator total ('+r[1]+') to be '+z.user_nb; + }); + })); + }); + + suite ('add a user page conformity', function () { + test_page_loading ('/user/add/', 'Add a new user\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#user ul.sub_list:eq(0) a', 2); + test_text ('#user ul.sub_list:eq(0) a:eq(0)[href="/user/"]', 'Users\' list'); + test_text ('#user ul.sub_list:eq(0) a:eq(1)[href="/user/mass-add/"]', 'Add users in bulk'); + test_count ('#user form[action="."]:eq(0) :input', 8); + test_form_field ('user', 'id_email', 'text', 0, 'E-mail address', true); + test_form_field ('user', 'id_first_name', 'text', 1, 'First name'); + test_form_field ('user', 'id_last_name', 'text', 2, 'Last name'); + test_form_field ('user', 'id_tags', 'text', 3, 'Tags'); + test_form_field ('user', 'id_role', 'select', 4, 'Workspace level role'); + test_form_field ('user', 'id_note', 'textarea', 5, 'Note'); + test_count ('select#id_role option', 6); + test_text ('select#id_role option:eq(0)[value][selected]', '---------', non_visible); + test_text ('select#id_role option:eq(1)[value="1"]', 'Manager', non_visible); + test_text ('select#id_role option:eq(2)[value="2"]', 'Editor', non_visible); + test_text ('select#id_role option:eq(3)[value="3"]', 'Moderator', non_visible); + test_text ('select#id_role option:eq(4)[value="4"]', 'Commentator', non_visible); + test_text ('select#id_role option:eq(5)[value="5"]', 'Observer', non_visible); + test_val ('#user :input:eq(6)[type=submit]', 'Add user'); + test_val ('#user :input:eq(7)#cancel_button[type=button]', 'Cancel'); + test_unlogged_footer (); + // TOTEST add user (pending) + }); + + suite ('add users in bulk page conformity', function () { + test_page_loading ('/user/mass-add/', 'Add users in bulk\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#user ul.sub_list:eq(0) a', 2); + test_text ('#user ul.sub_list:eq(0) a:eq(0)[href="/user/"]', 'Users\' list'); + test_text ('#user ul.sub_list:eq(0) a:eq(1)[href="/user/add/"]', 'Add a new user'); + test_count ('#user form[action="."]:eq(0) :input', 6); + test_form_field ('user', 'id_email', 'textarea', 0, 'Emails', true); + test_form_field ('user', 'id_tags', 'text', 1, 'Tags'); + test_form_field ('user', 'id_role', 'select', 2, 'Workspace level role'); + test_form_field ('user', 'id_note', 'textarea', 3, 'Note'); + test_count ('select#id_role option', 6); + test_text ('select#id_role option:eq(0)[value][selected]', '---------', non_visible); + test_text ('select#id_role option:eq(1)[value="1"]', 'Manager', non_visible); + test_text ('select#id_role option:eq(2)[value="2"]', 'Editor', non_visible); + test_text ('select#id_role option:eq(3)[value="3"]', 'Moderator', non_visible); + test_text ('select#id_role option:eq(4)[value="4"]', 'Commentator', non_visible); + test_text ('select#id_role option:eq(5)[value="5"]', 'Observer', non_visible); + test_val ('#user :input:eq(4)[type=submit]', 'Add users'); + test_val ('#user :input:eq(5)#cancel_button[type=button]', 'Cancel'); + // X TOTEST add users (pending) -> can't be deleted + test_unlogged_footer (); + }); + + suite ('settings page conformity', function () { + test_page_loading ('/settings/', 'Settings - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#settings ul.sub_list:eq(0) a', 1); + test_text ('#settings ul.sub_list:eq(0) a:eq(0)[href="/settings/design/"]', 'Appearance'); + test_count ('#settings form[action="."]:eq(0) :input', 12); + test_form_field ('settings', 'id_workspace_name', 'text', 0, 'Workspace name'); + test_form_field ('settings', 'id_workspace_tagline', 'text', 1, 'Workspace tagline'); + test_form_field ('settings', 'id_workspace_registration', 'checkbox', 2, 'Workspace registration'); + test_form_field ('settings', 'id_workspace_registration_moderation', 'checkbox', 3, 'Workspace registration moderation'); + test_form_field ('settings', 'id_workspace_role_model', 'select', 4, 'Role model'); + test_text ('select#id_workspace_role_model option:eq(0)[selected][value="generic"]', 'Generic', non_visible); + test_text ('select#id_workspace_role_model option:eq(1)[value="teacher"]', 'Class (education)', non_visible); + test_form_field ('settings', 'id_workspace_category_1', 'text', 5, 'Label for the first category of comments'); + test_form_field ('settings', 'id_workspace_category_2', 'text', 6, 'Label for the second category of comments'); + test_form_field ('settings', 'id_workspace_category_3', 'text', 7, 'Label for the third category of comments'); + test_form_field ('settings', 'id_workspace_category_4', 'text', 8, 'Label for the fourth category of comments'); + test_form_field ('settings', 'id_workspace_category_5', 'text', 9, 'Label for the fifth category of comments'); + test_val ('#settings :input:eq(10)[type=submit]', 'Save'); + test_val ('#settings :input:eq(11)#cancel_button[type=button]', 'Cancel'); + // TOTEST Workspace registration + test_unlogged_footer (); + }); + + suite ('settings design page conformity', function () { + test_page_loading ('/settings/design/', 'Settings - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); + test_count ('#settings ul.sub_list:eq(0) a', 1); + test_text ('#settings ul.sub_list:eq(0) a:eq(0)[href="/settings/"]', 'General'); + test_count ('#settings form[action="."]:eq(0) :input', 7); + test_form_field ('settings', 'id_workspace_logo_file', 'file', 0, 'Workspace logo'); + test_form_field ('settings', 'id_custom_css', 'textarea', 1, 'Custom CSS rules'); + test_form_field ('settings', 'id_custom_font', 'text', 2, 'Custom font'); + test_form_field ('settings', 'id_custom_titles_font', 'text', 3, 'Custom font for titles'); + test_val ('#settings :input:eq(4)[type=submit]', 'Save'); + test_val ('#settings :input:eq(5)#cancel_button[type=button]', 'Cancel'); + test_val ('#settings :input:eq(6)#delete_logo_button[type=submit]', 'Delete logo'); + // TOTEST custom CSS, font, font for titles like the rest of the settings + test_unlogged_footer (); + }); + + suite ('followup page conformity', function () { + test_page_loading ('/followup/', 'Followup\n - '+t['#id_workspace_name']); + test_logged_header (w.USER_ADMIN); + test_default_tabs (); test_text ('#followup a:eq(0)[href="/help/#public_private_feed"]', '?'); test_match ('#followup a:eq(1)[href$="/feed/"]', new RegExp (w.WORKSPACE_URL+'feed/', 'm')); test_text ('#followup a:eq(2)[href="/help/#public_private_feed"]', '?'); @@ -177,6 +457,24 @@ test_unlogged_footer (); }); + + suite ('settings restoration', function () { + test_page_loading ('/settings/', 'Settings'); + test_fill_settings (z); + test ('Restore settings ', dsl (function () { + elt ('#settings input[type="submit"]').click (); + browser.waitForPageLoad (); + })); + test_page_loading ('/settings/design/', 'Settings'); + test_fill_design (z); + test ('Restore design settings ', dsl (function () { + elt ('#settings input[type="submit"]').click (); + browser.waitForPageLoad (); + })); + // next instruction must be a page loading + // test_page_loading ('/settings/', 'Settings'); + }); + }); function test_default_tabs () { @@ -190,17 +488,19 @@ elt ('#main-tabs a[href="/text/"]').text (function (t) { var r = t.match (/^Texts \((\d+)\) $/); if (r.length != 2) throw 'for Texts expected 2 matches got '+r.length; - if (text_nb != r[1]) throw 'expected tab text nb ('+r[1]+') to be '+text_nb; + if (z.text_nb != r[1]) throw 'expected tab text nb ('+r[1]+') to be '+z.text_nb; }); elt ('#main-tabs a[href="/user/"]').text (function (t) { var r = t.match (/^People \((\d+)\)$/); if (r.length != 2) throw 'for People expected 2 matches got '+r.length; - if (user_nb != r[1]) throw 'expected tab people nb ('+r[1]+') to be '+user_nb; + if (z.user_nb != r[1]) throw 'expected tab people nb ('+r[1]+') to be '+z.user_nb; }); })); } -function test_logged_header (username) { +function test_logged_header (username, is_tagline) { + is_tagline = typeof is_tagline == 'undefined' ? true : is_tagline; + test_text ('#header_controls b', username) test_count ('#header_controls a', 6); test_text ('#header_controls a:nth-of-type(1)[href="/"]', 'Home'); @@ -209,6 +509,11 @@ test_text ('#header_controls a:nth-of-type(4)[href="/create/import/"]', 'Import a co-mented text'); test_text ('#header_controls a:nth-of-type(5)[href="/profile/"]', 'Profile'); test_text ('#header_controls a:nth-of-type(6)[href="/logout/"]', 'Logout'); + test_text ('#content h1.main_title a[href="/"]', t['#id_workspace_name']); + + if (is_tagline) { + test_match ('#content h1.main_title + div', new RegExp (t['#id_workspace_tagline'], 'm')); + } } function test_unlogged_header () { @@ -304,7 +609,13 @@ */ function test_form_field (form_id, field_id, type, position, label, mandatory) { test ('has a '+label+' form field', dsl(function () { - var s = type == 'textarea' ? 'textarea#'+field_id : 'input#'+field_id+'[type='+type+']'; + var s = ''; + switch (type) { + case 'textarea':s = 'textarea#'+field_id; break; + case 'select': s = 'select#'+field_id; break; + default: s = 'input#'+field_id+'[type="'+type+'"]'; + } +// var s = type == 'textarea' ? 'textarea#'+field_id : 'input#'+field_id+'[type='+type+']'; expect (elt (s).val ()).toBeDefined (); expect (elt ('#'+form_id+' :input:eq('+position+')#'+field_id).val ()).toBeDefined (); expect (elt ('label[for='+field_id+']').text ()).toBe (label); @@ -314,6 +625,39 @@ })); } +function test_readz_field (field_id) { + test ('get '+field_id, dsl(function () { + element (field_id).val (function (v) { + z[field_id] = v; + }); + })); +} + +function test_fill_field (field_id, stored) { + test ('set '+field_id, dsl(function () { + input (field_id).enter (stored[field_id]); + })); +} + +function test_fill_settings (s) { + test_fill_field ('#id_workspace_name', s); + test_fill_field ('#id_workspace_tagline', s); + test_fill_field ('#id_workspace_registration', s); + test_fill_field ('#id_workspace_registration_moderation', s); + test_fill_field ('#id_workspace_role_model', s); + test_fill_field ('#id_workspace_category_1', s); + test_fill_field ('#id_workspace_category_2', s); + test_fill_field ('#id_workspace_category_3', s); + test_fill_field ('#id_workspace_category_4', s); + test_fill_field ('#id_workspace_category_5', s); +} + +function test_fill_design (s) { + test_fill_field ('#id_custom_css', s); + test_fill_field ('#id_custom_font', s); + test_fill_field ('#id_custom_titles_font', s); +} + /** Ensure the given element is visible * s : CSS selector of the DOM element to check * v : should the element being visible diff -r fda73ac53450 -r d334a616c023 src/cm/scripts/test-suite/workspace.info.js --- a/src/cm/scripts/test-suite/workspace.info.js Mon Mar 10 13:24:19 2014 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,24 +0,0 @@ - -define ("WORKSPACE_URL", 'http://192.168.2.61:8000/'); -define ("USER_ADMIN", 'siltaar'); -define ("PASS_ADMIN", 'oaueoaue'); - -// TODO: decide wether we should populate workspaces with standard users or -// create them on the fly ? - -define ("USER_EDIT", ''); -define ("PASS_EDIT", ''); - -define ("USER_COM", ''); -define ("PASS_COM", ''); - -define ("USER_OBSERV", ''); -define ("PASS_OBSERV", ''); - -function define (name, value) { - Object.defineProperty (exports, name, { - value: value, - enumerable: true - }); -} - diff -r fda73ac53450 -r d334a616c023 src/cm/scripts/test-suite/workspace.info.js.example --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cm/scripts/test-suite/workspace.info.js.example Mon Mar 10 13:24:42 2014 +0100 @@ -0,0 +1,18 @@ + +define ("WORKSPACE_URL", 'http://192.168.2.61:8000/'); +define ("USER_ADMIN", ''); +define ("PASS_ADMIN", ''); + +define ("USER_EDIT", ''); +define ("PASS_EDIT", ''); + +define ("USER_COM", ''); +define ("PASS_COM", ''); + +function define (name, value) { + Object.defineProperty (exports, name, { + value: value, + enumerable: true + }); +} +