diff options
author | Sriram Viswanathan <sriramv@thoughtworks.com> | 2017-04-05 17:59:25 -0300 |
---|---|---|
committer | Sriram Viswanathan <sriramv@thoughtworks.com> | 2017-04-05 18:49:33 -0300 |
commit | 5b12c004d96564da8c9cc420f0730093445ada4e (patch) | |
tree | 59c0ca2490df9e3303eb0ea0d09caceea5fae9de /service | |
parent | 22c5631039e441bb43f82891d3673224240ec830 (diff) |
[#938] Adds smoke test for account recovery flow
with @anikarni
Diffstat (limited to 'service')
-rw-r--r-- | service/test/functional/features/account_recovery.feature | 7 | ||||
-rw-r--r-- | service/test/functional/features/environment.py | 2 | ||||
-rw-r--r-- | service/test/functional/features/steps/account_recovery.py | 50 |
3 files changed, 59 insertions, 0 deletions
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 <http://www.gnu.org/licenses/>. + +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) |