Skip to main content

Mozilla Firefox Accounts Page Object Model

Project description

Firefox Accounts Page Object Model

[Selenium WebDriver][webdriver] compatible page object model and utilities for [Firefox Accounts][FxA]

[FxA]: https://accounts.firefox.com [webdriver]: http://docs.seleniumhq.org/docs/03_webdriver.jsp

Overview

This package contains a utility to create a test Firefox Account on either the dev or prod instance of Firefox Accounts, as well as a set of page objects that can be used to interact with Firefox Accounts’ sign in screens.

Usage

To create a test Firefox Account, use the create_account method in the FxATestAccount object. You can pass the url for the Firefox Accounts API server into the constructor or, if you know you want to create a development Account, you can omit that argument.

There are two constants available to you to specify the url for either the development environment or the production environment, which are: - fxapom.DEV_URL - the url for the development environment - fxapom.PROD_URL - the url for the production environment

Example of creating an account on the development environment, using the default: `python from fxapom.fxapom import FxATestAccount acct = FxATestAccount().create_account() `

Example of creating an account on the development environment, specifying the DEV_URL: `python from fxapom.fxapom import DEV_URL, FxATestAccount acct = FxATestAccount(DEV_URL).create_account() `

To sign in via Firefox Accounts, use the sign_in method in the WebDriverFxA object, passing in the email addresss and password.

Example: `python from fxapom.fxapom import WebDriverFxA fxa = WebDriverFxA(mozwebqa) fxa.sign_in(email_address, password) `

Note that we are passing mozwebqa into the constructor of WebDriverFxA, which is only generally available when using our in-house plugin [pytest-mozwebqa][plugin].

[plugin]: https://github.com/mozilla/pytest-mozwebqa

To create an account and then use it to sign in, use both tools described above.

Example: `python from fxapom.fxapom import FxATestAccount, WebDriverFxA acct = FxATestAccount().create_account() fxa = WebDriverFxA(mozwebqa) fxa.sign_in(acct.email, acct.password) `

Running The Tests

  • Install the requirements using pip install -r requirements.txt

  • Run the tests using a local Firefox browser via py.test –driver=Firefox tests

License

This software is licensed under the [MPL](http://www.mozilla.org/MPL/2.0/) 2.0:

This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.

Change Log

1.3

  • Change FxATestAccount constructor to accept the url to the FxA API server * This is a breaking change

1.2

  • Update required version of PyFxA in setup.py to 0.0.5

1.1

  • Update required version of PyFxA in requirements.txt to 0.0.5

1.0

  • Initial release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fxapom-1.3.tar.gz (4.4 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page