Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/joke2k/django-faker

Django-faker uses fake-factory to generate test data for Django models and templates
https://github.com/joke2k/django-faker

Last synced: about 1 month ago
JSON representation

Django-faker uses fake-factory to generate test data for Django models and templates

Lists

README

        

Django-faker
============

*Django-faker* uses the `Faker`_ package to generate test data for Django models and templates.

|pypi| |unix_build| |windows_build| |coverage| |downloads| |license|

How to use
----------

To install Django-faker you can use pip::

pip install django-faker

Configuration
~~~~~~~~~~~~~

In django application `settings.py`::

INSTALLED_APPS = (

# ...
'django_faker',
)

FAKER_LOCALE = None # settings.LANGUAGE_CODE is loaded
FAKER_PROVIDERS = None # faker.DEFAULT_PROVIDERS is loaded (all)

Populating Django Models
~~~~~~~~~~~~~~~~~~~~~~~~

*Django-faker* provides an adapter for Django Models, for easy population of test databases.
To populate with Model instances, create a new Populator class,
then list the class and number of all of Models that must be generated. To launch the actual data population,
call `execute()` method.

Here is an example showing how to populate 5 `Game` and 10 `Player` objects::

from django_faker import Faker
# this Populator is only a function thats return a django_faker.populator.Populator instance
# correctly initialized with a faker.generator.Generator instance, configured as above
populator = Faker.getPopulator()

from myapp.models import Game, Player
populator.addEntity(Game,5)
populator.addEntity(Player,10)

insertedPks = populator.execute()

The populator uses name and column type guessers to populate each column with relevant data.
For instance, Django-faker populates a column named `first_name` using the `firstName` formatter, and a column with
a `datetime` instance using the `dateTime`.
The resulting entities are therefore coherent. If Django-faker misinterprets a column name, you can still specify a custom
function to be used for populating a particular column, using the third argument to `addEntity()`::

populator.addEntity(Player, 10, {
'score': lambda x: populator.generator.randomInt(0,1000),
'nickname': lambda x: populator.generator.email(),
})
populator.execute()

Of course, Django-faker does not populate autoincremented primary keys.
In addition, `django_faker.populator.Populator.execute()` returns the list of inserted PKs, indexed by class::

print insertedPks
{
: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],
: [1, 2, 3, 4, 5]
}

In the previous example, the `Player` and `Game` models share a relationship. Since `Game` entities are populated first,
Faker is smart enough to relate the populated `Player` entities to one of populated `Game` entities.

Template tags and filter
~~~~~~~~~~~~~~~~~~~~~~~~

Django-faker offers a useful template tags and filters for interact with `PyFaker`_::

{% fake 'name' as myname %}{% fake 'dateTimeBetween' '-10d' as mydate %}

{{ myname|title }} - {{ mydate|date:"M Y" }}

{% load fakers %}



{% fake 'randomInt' 10 20 as times %}
{% for i in 10|get_range %}


{% if 'boolean'|fake:25 %}

{% endif %}


{% fakestr 'streetAddress' %}
{% fakestr 'city' %}
{% fakestr 'postcode' %}
{% fakestr 'state' %}


{% if 'boolean'|fake:25 %}
{% fakestr 'bs' %}
{% endif %}
{% if 'boolean'|fake:33 %}

{% endif %}

{% if 'boolean'|fake:15 %}



{% endif %}

{% endfor %}

Page preview
~~~~~~~~~~~~
Open `url.py` in your main application and add this url::

urlpatterns = patterns('',
...
url(r'', include('django_faker.urls')),
...
)

http://127.0.0.1:8000/preview/ shows a faked browser windows, useful for screenshots.

Running the Tests
-----------------

Run django tests in a django environment:

$ python runtests.py

or if you have 'django_faker' in INSTALLED_APPS:

$ python manage.py test django_faker

Changelog
---------

`0.3dev `__
------------------------------------------------------------------------

- fake-factory package was renamed to Faker, requires a minimum version of 0.7.3

`0.2 - 23-January-2013 `__
-------------------------------------------------------------------------------------

- Add requirements
- Fake browser preview

0.1 - 01-December-2012
----------------------

- Add django Model instance generator
- Add django template tag and filter

.. _Faker: https://www.github.com/joke2k/faker/

.. |pypi| image:: https://img.shields.io/pypi/v/django-faker.svg?style=flat-square&label=version
:target: https://pypi.python.org/pypi/django-faker
:alt: Latest version released on PyPi

.. |coverage| image:: https://img.shields.io/coveralls/joke2k/django-faker/master.svg?style=flat-square
:target: https://coveralls.io/r/joke2k/django-faker?branch=master
:alt: Test coverage

.. |unix_build| image:: https://img.shields.io/travis/joke2k/django-faker/master.svg?style=flat-square&label=unix%20build
:target: http://travis-ci.org/joke2k/django-faker
:alt: Build status of the master branch on Mac/Linux

.. |windows_build| image:: https://img.shields.io/appveyor/ci/joke2k/django-faker.svg?style=flat-square&label=windows%20build
:target: https://ci.appveyor.com/project/joke2k/django-faker
:alt: Build status of the master branch on Windows

.. |downloads| image:: https://img.shields.io/pypi/dm/django-faker.svg?style=flat-square
:target: https://pypi.python.org/pypi/django-faker
:alt: Monthly downloads

.. |license| image:: https://img.shields.io/badge/license-MIT-blue.svg?style=flat-square
:target: https://raw.githubusercontent.com/joke2k/django-faker/master/LICENSE.txt
:alt: Package license