One and Done is written with Playdoh and Django.
If you're interested in helping us out, please read through the project wiki and reach out to us!
About the project:
Contribute to Mozilla QA - One task at a time, One day at a time.
One and Done gives users a wide variety of ways to contribute to Mozilla. You can pick an easy task that only takes a few minutes - or take on a bigger challenge. This includes working on manual testing, automation, bug verification, mobile testing and more. Tasks are from all QA teams - so you can get involved with Automation, Firefox OS, Desktop Firefox, Mozilla websites, Services, or Thunderbird.
These instructions assume you have git, python, and pip
installed. If
you don't have pip
installed, you can install it with easy_install pip
.
-
Start by getting the source:
$ git clone --recursive git@github.com:mozilla/oneanddone.git $ cd oneanddone
Note you may want to fork and clone the repo as described in the github docs if you are doing active development.
-
Create a virtualenv for One and Done. Skip the first step if you already have
virtualenv
installed.$ pip install virtualenv $ virtualenv venv $ source venv/bin/activate
-
Set up MySQL locally. The MySQL Installation Documentation explains how to do this.
-
Create the initial empty database; make sure it's utf8:
# Start the MySQL server $ mysql.server start # Once successfully started, log into the console # using your username and password $ mysql -uroot -p
In the mysql console:
CREATE DATABASE oneanddone DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;
To run all parts of the application, you will eventually need to populate this empty database with some example data, especially Tasks. There are many ways to populate the database. The method you choose may depend on the kind of data you want to add.
- Use the create/edit features of your local One and Done instance. For example sign in with an administrator account and go to the
/tasks/create/
URL of the app to create Tasks. - Use the Django admin section of your local One and Done instance by going to the
/admin
URL -- this also relies on an admin account. You can define Task Teams here, for example. - Use an external tool like MySQL Workbench.
- Ask another active developer for a mysqldump of their local database.
- Use the create/edit features of your local One and Done instance. For example sign in with an administrator account and go to the
-
Install the compiled and development requirements:
$ pip install -r requirements/compiled.txt $ pip install -r requirements/dev.txt
Note: On OS X (in particular 10.8.5, Xcode 5.1), you may encounter the following error:
clang: error: unknown argument. '-mno-fused-madd'
. Try running pip with theARCHFLAGS
environment variable set, as follows:ARCHFLAGS=-Wno-error=unused-command-line-argument-hard-error-in-future pip install -r requirements/compiled.txt
-
Configure your local settings by copying
oneanddone/settings/local.py-dist
tooneanddone/settings/local.py
and customizing the settings in it:$ cp oneanddone/settings/local.py-dist oneanddone/settings/local.py
The file is commented to explain what each setting does and how to customize them. Here are some highlights:
- If you are running this locally and not over HTTPS, uncomment
SESSION_COOKIE_SECURE = False
- The
HMAC_KEYS
dictionary should not be empty. - Provide a value for
SECRET_KEY
.
- If you are running this locally and not over HTTPS, uncomment
-
Initialize your database structure:
$ python manage.py syncdb
If you are asked to create a superuser, do so. Don't worry if you miss this step: see the Users section below for more information.
Once finished, the syncdb
command should produce a message about which models have been synced. At the bottom, the message will include something like this:
Not synced (use migrations):
- oneanddone.tasks
- oneanddone.users
- rest_framework.authtoken
This means that you must also run ./manage.py migrate [model]
for each model that is not synced with syncdb
. More information about South migrations is included under the Applying Migrations section below.
Playdoh uses BrowserID, a.k.a. Mozilla Persona, for user authentication. To add users to your local database, simply sign into your local One and Done instance. You may want to use dummy email accounts as described in Mozilla's guide to testing Persona.
You need at least one superuser to be able to develop and test administrative features of the project. You can create as many superusers as you like with python manage.py createsuperuser
. After that, sign into your local One and Done instance with the superuser's email address as usual.
We're using South to handle database migrations. To apply the migrations, run the following:
$ ./manage.py migrate oneanddone.tasks && ./manage.py migrate oneanddone.users
If you make changes to an existing model, say oneanddone.tasks
, you will need to regeneratre the schema migration as follows:
$ ./manage.py schemamigration oneanddone.tasks --auto
To generate a blank data migration:
# ./manage.py datamigration [model] [data_migration_name]
# Example:
$ ./manage.py datamigration oneanddone.tasks task_data
Then fill in the generated file with logic, fixtures, etc. You can then apply this migration as above with:
$ ./manage.py migrate oneanddone.tasks
You can launch the development server like so:
$ python manage.py runserver
You can run all the unit tests in verbose mode as follows:
$ python manage.py test -v 2
You can also run spefic tests:
# All tests in tasks/tests/test_helpers module.
$ python manage.py test oneanddone.tasks.tests.test_helpers -v 2
# Just one test (PageUrlTests.test_basic)
$ python manage.py test oneanddone.tasks.tests.test_helpers:PageUrlTests.test_basic -v 2
There is a REST API support which enables:
- Getting complete list of Tasks.
- Getting detail about a Task with particular id.
- Create and Delete Tasks with particular id.
The Task queries can be made by appending
api/v1/task/
to the base url.
GET and DELETE queries example.
curl -X GET http://127.0.0.1:8000/api/v1/task/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
curl -X GET http://127.0.0.1:8000/api/v1/task/1/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
curl -X DELETE http://127.0.0.1:8000/api/v1/task/1/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
- Getting complete list of Users.
- Getting details about a User with particular email.
- Create and Delete Users with with particular email.
The User queries can be made by appending
api/v1/user/
to the base url.
GET and DELETE queries example.
curl -X GET http://127.0.0.1:8000/api/v1/user/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
curl -X GET http://127.0.0.1:8000/api/v1/user/testuser@tesmail.com/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
curl -X DELETE http://127.0.0.1:8000/api/v1/user/testuser@testmail.com/ -H 'Authorization: Token d81e33c57b2d9471f4d6849bab3cb233b3b30468'
Token used in examples above is just a sample and actual Tokens can be generated from the admin pannel by going to Authtoken > Tokens
.
Functional (Selenium) tests for oneanddone are maintained by the Web QA team and can be found at oneanddone-tests.
This software is licensed under the Mozilla Public License v. 2.0. For more
information, read the file LICENSE
.