From f5733ddb5e1e13fb2d7e8563924295f31bacabd9 Mon Sep 17 00:00:00 2001 From: =?utf8?q?=C5=BDeljko=20Filipin?= Date: Thu, 19 Jan 2017 17:17:01 +0100 Subject: [PATCH] Fix Selenium tests The tests were broken because the feedback meesage is no longer displayed as part of the page, but using HTML5 `required` attribute. Bug: T155640 Change-Id: I9c46db374ec7f50262f84d721a21110aa6e81699 --- tests/browser/features/login.feature | 4 ++-- tests/browser/features/step_definitions/login_steps.rb | 8 ++++++++ tests/browser/features/support/pages/create_account_page.rb | 2 +- tests/browser/features/support/pages/login_page.rb | 2 ++ 4 files changed, 13 insertions(+), 3 deletions(-) diff --git a/tests/browser/features/login.feature b/tests/browser/features/login.feature index c18f087250c..89222346231 100644 --- a/tests/browser/features/login.feature +++ b/tests/browser/features/login.feature @@ -11,11 +11,11 @@ Feature: Log in Scenario: Log in without entering credentials When I log in without entering credentials - Then error box should be visible + Then error message should be displayed for username Scenario: Log in without entering password When I log in without entering password - Then error box should be visible + Then error message should be displayed for password Scenario: Log in with incorrect username When I log in with incorrect username diff --git a/tests/browser/features/step_definitions/login_steps.rb b/tests/browser/features/step_definitions/login_steps.rb index 9b35e998c5e..14a2d76ad15 100644 --- a/tests/browser/features/step_definitions/login_steps.rb +++ b/tests/browser/features/step_definitions/login_steps.rb @@ -30,6 +30,14 @@ Then(/^error box should not be visible$/) do expect(on(LoginPage).error_message_element).not_to exist end +Then(/^error message should be displayed for username$/) do + expect(on(LoginPage).username_error_element).to exist +end + +Then(/^error message should be displayed for password$/) do + expect(on(LoginPage).password_error_element).to exist +end + Then(/^feedback should be (.+)$/) do |feedback| on(LoginPage) do |page| page.feedback_element.when_present.click diff --git a/tests/browser/features/support/pages/create_account_page.rb b/tests/browser/features/support/pages/create_account_page.rb index 20e274425c5..de12aeeb4dd 100644 --- a/tests/browser/features/support/pages/create_account_page.rb +++ b/tests/browser/features/support/pages/create_account_page.rb @@ -4,5 +4,5 @@ class CreateAccountPage page_url '<%=params[:page_title]%>' button(:create_account, id: 'wpCreateaccount') - element(:error_message, css: 'div#userloginForm div.error') + element(:error_message, css: 'input#wpName2:required:invalid') end diff --git a/tests/browser/features/support/pages/login_page.rb b/tests/browser/features/support/pages/login_page.rb index 47273188b77..c119b38af1a 100644 --- a/tests/browser/features/support/pages/login_page.rb +++ b/tests/browser/features/support/pages/login_page.rb @@ -10,10 +10,12 @@ class LoginPage button(:login, id: 'wpLoginAttempt') li(:logout, id: 'pt-logout') text_field(:password, id: 'wpPassword1') + element(:password_error, css: 'input#wpPassword1:required:invalid') a(:password_strength, text: 'password strength') a(:phishing, text: 'phishing') text_field(:username, id: 'wpName1') a(:username_displayed, title: /Your user page/) + element(:username_error, css: 'input#wpName1:required:invalid') def logged_in_as_element @browser.div(id: 'mw-content-text').p.b -- 2.11.4.GIT