I have the following models:
class Poll(models.Model):
question = models.CharField(max_length=200)
pub_date = models.DateTimeField(auto_now_add=True)
def __unicode__(self):
return self.question
and the following test
from polls.models import Poll
from django.test import TestCase
from django.utils import timezone
class PollModelTest(TestCase):
def test_poll_save(self):
q = "What is the best OS?"
pd = timezone.now()
p = Poll(question=q,
pub_date=pd)
p.save()
polls = Poll.objects.all()
self.assertEquals(polls.count(), 1)
self.assertEquals(polls[0].question, q)
and the following settings:
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
# Uncomment the next line to enable the admin:
'django.contrib.admin',
# Uncomment the next line to enable admin documentation:
# 'django.contrib.admindocs',
'polls',
'django_nose',
)
TEST_RUNNER = 'django_nose.NoseTestSuiteRunner'
NOSE_ARGS = [
'--with-coverage',
'--cover-package=polls',
'--with-progressive',
'--verbosity=0',
'--with-fixture-bundling',
]
When I try python manage.py test polls
the tests run twice. Following is the output:
Creating test database for alias 'default'...
Name Stmts Miss Cover Missing
--------------------------------------------
polls 0 0 100%
polls.models 6 0 100%
--------------------------------------------
TOTAL 6 0 100%
OK! 2 tests, 0 failures, 0 errors in 0.0s
Destroying test database for alias 'default'...
However when I try without TEST_RUNNER = 'django_nose.NoseTestSuiteRunner'
, then the tests runs only once. Following is the output:
Creating test database for alias 'default'...
.
----------------------------------------------------------------------
Ran 1 test in 0.002s
OK
Destroying test database for alias 'default'...
Please tell me what is wrong? Why is django-nose running tests twice?
OT: django_nose takes more time than unittest, for the same model.
EDIT:
Here is the folder structure:
├── database.sqlite
├── manage.py
├── mysite
│ ├── __init__.py
│ ├── settings.py
│ ├── templates
│ │ ├── 404.html
│ │ ├── 500.html
│ │ └── base.html
│ ├── urls.py
│ └── wsgi.py
└── polls
├── __init__.py
├── models.py
├── tests
│ ├── __init__.py
│ └── test_models.py
├── urls.py
└── views.py