From 5b12c004d96564da8c9cc420f0730093445ada4e Mon Sep 17 00:00:00 2001 From: Sriram Viswanathan Date: Wed, 5 Apr 2017 17:59:25 -0300 Subject: [#938] Adds smoke test for account recovery flow with @anikarni --- .../functional/features/steps/account_recovery.py | 50 ++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 service/test/functional/features/steps/account_recovery.py (limited to 'service/test/functional/features/steps/account_recovery.py') diff --git a/service/test/functional/features/steps/account_recovery.py b/service/test/functional/features/steps/account_recovery.py new file mode 100644 index 00000000..639b1c83 --- /dev/null +++ b/service/test/functional/features/steps/account_recovery.py @@ -0,0 +1,50 @@ +# +# Copyright (c) 2017 ThoughtWorks, Inc. +# +# Pixelated is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Pixelated is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with Pixelated. If not, see . + +from behave import given, when, then + +from common import ( + fill_by_css_selector, + find_element_by_css_selector) + + +@given(u'I am on the account recovery page') +def account_recovery_page(context): + context.browser.get(context.account_recovery_url) + + +@when(u'I submit admin recovery code') +def submit_admin_recovery_code(context): + fill_by_css_selector(context, 'input[name="admin-code"]', '1234') + find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + + +@when(u'I submit user recovery code') +def submit_user_recovery_code(context): + fill_by_css_selector(context, 'input[name="user-code"]', '5678') + find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + + +@when(u'I submit new password') +def submit_new_password(context): + fill_by_css_selector(context, 'input[name="new-password"]', 'new test password') + fill_by_css_selector(context, 'input[name="confirm-password"]', 'new test password') + find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + + +@then(u'I see the backup account step') +def backup_account_step(context): + find_element_by_css_selector(context, 'a[href="/backup-account"]', timeout=50) -- cgit v1.2.3 From a85e533dfe833f397af18be7c4784c9a049eac7f Mon Sep 17 00:00:00 2001 From: Sriram Viswanathan Date: Thu, 6 Apr 2017 11:47:18 -0300 Subject: [#938] Uses PageObject pattern for functional test with @anikarni --- .../functional/features/steps/account_recovery.py | 27 +++++++++++----------- 1 file changed, 13 insertions(+), 14 deletions(-) (limited to 'service/test/functional/features/steps/account_recovery.py') diff --git a/service/test/functional/features/steps/account_recovery.py b/service/test/functional/features/steps/account_recovery.py index 639b1c83..ac66cf76 100644 --- a/service/test/functional/features/steps/account_recovery.py +++ b/service/test/functional/features/steps/account_recovery.py @@ -16,35 +16,34 @@ from behave import given, when, then -from common import ( - fill_by_css_selector, - find_element_by_css_selector) +from ..page_objects import AccountRecoveryPage @given(u'I am on the account recovery page') def account_recovery_page(context): - context.browser.get(context.account_recovery_url) + AccountRecoveryPage(context).visit() @when(u'I submit admin recovery code') def submit_admin_recovery_code(context): - fill_by_css_selector(context, 'input[name="admin-code"]', '1234') - find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + AccountRecoveryPage(context).submit_admin_recovery_code('1234') @when(u'I submit user recovery code') def submit_user_recovery_code(context): - fill_by_css_selector(context, 'input[name="user-code"]', '5678') - find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + AccountRecoveryPage(context).submit_user_recovery_code('5678') @when(u'I submit new password') def submit_new_password(context): - fill_by_css_selector(context, 'input[name="new-password"]', 'new test password') - fill_by_css_selector(context, 'input[name="confirm-password"]', 'new test password') - find_element_by_css_selector(context, '.submit-button button[type="submit"]').click() + AccountRecoveryPage(context).submit_new_password('new test password', 'new test password') -@then(u'I see the backup account step') -def backup_account_step(context): - find_element_by_css_selector(context, 'a[href="/backup-account"]', timeout=50) +@when(u'I click on the backup account link') +def go_to_backup_account(context): + AccountRecoveryPage(context).go_to_backup_account() + + +@then(u'I see the backup account page') +def verify_backup_account_page(context): + assert('/backup-account' in context.browser.current_url) -- cgit v1.2.3