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/account_recovery.feature | 7 +++ service/test/functional/features/environment.py | 2 + .../functional/features/steps/account_recovery.py | 50 ++++++++++++++++++++++ 3 files changed, 59 insertions(+) create mode 100644 service/test/functional/features/steps/account_recovery.py (limited to 'service/test') diff --git a/service/test/functional/features/account_recovery.feature b/service/test/functional/features/account_recovery.feature index 7a8f9fce..bdc0664c 100644 --- a/service/test/functional/features/account_recovery.feature +++ b/service/test/functional/features/account_recovery.feature @@ -27,3 +27,10 @@ Feature: Account Recovery Then I see the confirmation of this submission And I logout from the header And I should see the login page + + Scenario: Recovering an account + Given I am on the account recovery page + When I submit admin recovery code + And I submit user recovery code + And I submit new password + Then I see the backup account step diff --git a/service/test/functional/features/environment.py b/service/test/functional/features/environment.py index 9c6a6b02..f1cc0e44 100644 --- a/service/test/functional/features/environment.py +++ b/service/test/functional/features/environment.py @@ -56,12 +56,14 @@ def before_all(context): context.signup_url = 'https://{}/signup'.format(hostname) context.login_url = 'https://mail.{}/login'.format(hostname) context.backup_account_url = 'https://mail.{}/backup-account'.format(hostname) + context.account_recovery_url = 'https://mail.{}/account-recovery'.format(hostname) context.username = 'testuser_{}'.format(uuid.uuid4()) if 'localhost' in context.host: _mock_user_agent(context) context.login_url = context.multi_user_url + '/login' context.backup_account_url = context.single_user_url + '/backup-account' + context.account_recovery_url = context.single_user_url + '/account-recovery' context.username = 'username' 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