Jason Swett
Jason Swett

Reputation: 45174

Organizing Django unit tests

Right now I have my Django unit tests living at mcif/tests.py. I would prefer to have something more like mcif/tests/foo_test.py, mcif/tests/bar_test.py, etc., but if I organize my tests that way, Django flips out.

Is there a way to do what I'm trying to do or do I have to have all my tests in one file?

Upvotes: 59

Views: 15928

Answers (5)

Matan Dobrushin
Matan Dobrushin

Reputation: 195

As @artur-soler explained,

Let's say you have an app named "AppName":

AppName tests

Your __init__.py inside the tests folder should consists of something like -

from AppName.tests import *

Upvotes: 0

geckon
geckon

Reputation: 8774

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"

Upvotes: 3

dappawit
dappawit

Reputation: 12590

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]

Upvotes: 17

Artur Soler
Artur Soler

Reputation: 3024

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.

Upvotes: 146

Evgeny Zislis
Evgeny Zislis

Reputation: 6967

In your __init__.py put something like:

from foo_test import *
from bar_test import *

Upvotes: 2

Related Questions