From 169e848b298baff4386ef6ecb63615fa8a347e24 Mon Sep 17 00:00:00 2001 From: Alexandre Pretto Nunes Date: Fri, 27 Feb 2015 12:07:23 -0300 Subject: Make tests involving adding and selecting tags more robust --- .../test/functional/features/steps/mail_view.py | 1 + service/test/functional/features/steps/tag_list.py | 22 ++++++++++++++++++++-- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/service/test/functional/features/steps/mail_view.py b/service/test/functional/features/steps/mail_view.py index ca0d68dc..46e01515 100644 --- a/service/test/functional/features/steps/mail_view.py +++ b/service/test/functional/features/steps/mail_view.py @@ -46,6 +46,7 @@ def impl(context, tag): e = wait_until_element_is_visible_by_locator(context, (By.ID, 'new-tag-input')) e.send_keys(tag) e.send_keys(Keys.ENTER) + wait_until_element_is_visible_by_locator(context, (By.XPATH, '//li[@data-tag="%s"]' % tag)) @then('I reply to it') diff --git a/service/test/functional/features/steps/tag_list.py b/service/test/functional/features/steps/tag_list.py index 64749c8e..c50387f0 100644 --- a/service/test/functional/features/steps/tag_list.py +++ b/service/test/functional/features/steps/tag_list.py @@ -21,10 +21,28 @@ def click_first_element_with_class(context, classname): elements[0].click() +def is_side_nax_expanded(context): + return context.browser.find_elements_by_class_name('content')[0].get_attribute('class').count(u'move-right') == 1 + + +def ensure_side_nav_is_expanded(context): + if is_side_nax_expanded(context): + return + + toggle = context.browser.find_elements_by_class_name('side-nav-toggle')[0] + toggle.click() + + wait = WebDriverWait(context, 5) + wait.until(is_side_nax_expanded) + + @when('I select the tag \'{tag}\'') def impl(context, tag): wait_for_user_alert_to_disapear(context) - click_first_element_with_class(context, 'side-nav-toggle') - context.browser.execute_script("window.scrollBy(0, -200)") + + ensure_side_nav_is_expanded(context) + + wait_until_element_is_visible_by_locator(context, (By.ID, 'tag-%s' % tag.lower()), 20) + e = find_element_by_id(context, 'tag-%s' % tag.lower()) e.click() -- cgit v1.2.3