Organizing Django unit tests

From version 1.6 of Django, the test discovery mechanism changed. You no longer need to import everything from tests/__init__.py, but now you have to make sure that all your files containing tests match the pattern test*.py.

So, instead of having app/tests/models.py and app/tests/views.py, now you should have app/tests/test_models.py and app/tests/test_views.py.

You could also create a file named app/tests/test.py and include your other files from there. The thing is that the runner will look for files matching the pattern test*.py and execute them.


Note: This describes behavior prior to Django 1.6. See Artur Soler's answer for Django 1.6 and later.

Make a package: myapp/tests/

Within the package, put as many different testing modules as you want. In the __init__.py within tests, import the tests from those modules. (Or some variation on this theme.)

edit: Wow, didn't notice you already mentioned a tests package.

The important thing is to get everything available from the package. Django will get the tests from the package, so they have to be visible in __init__.py.

[edit: Added note about Django version 1.6]


Just to add to Artur Soler's great answer...

You can also use the --pattern option to specify how your test files are named.

For example if your test files are named foo_test.py, bar_test.py and similar, you can use:

$ ./manage.py test --pattern="*_test.py"