为什么在Django单元测试期间我的表不可用?

时间:2013-10-09 15:53:24

标签: python django sqlite unit-testing django-south

当我尝试运行我的单元测试时,我收到一条错误,指出数据库中没有表。我的测试一天前运行良好,而且自那以后我改变的头脑风暴并没有让人想起任何接近导致这个问题的事情。

我认为这是syncdbSouthsqlite数据库中未正确创建表格的问题,并试图对其进行故障排除。

带回溯的错误消息

$ ./manage.py test --settings=settings.test -v2

Creating test database for alias 'default' (':memory:')...
Syncing...
Creating tables ...
Creating table django_admin_log
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table django_content_type
Creating table django_session
Creating table django_site
Creating table south_migrationhistory
Installing custom SQL ...
Installing indexes ...

Synced:
 > grappelli
 > django.contrib.admin
 > django.contrib.admindocs
 > django.contrib.auth
 > django.contrib.contenttypes
 > django.contrib.messages
 > django.contrib.sessions
 > django.contrib.sites
 > django.contrib.staticfiles
 > crispy_forms
 > floppyforms
 > south
 > subdomains
 > widget_tweaks

Not synced (use migrations):
 - apps.application
 - apps.app_app
 - apps.accounts
 - apps.rampup
 - apps.students
 - apps.automated_responses
(use ./manage.py migrate to migrate these)

======================================================================
ERROR: test_can_save_form_with_clean_passwords (apps.accounts.tests.test_admin.TestCreateUserForm)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/Users/chaz/dev/projects/si/apps/accounts/tests/test_admin.py", line 17, in setUp
    self.user = SIDummyUserFactory.create()
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/factory/base.py", line 452, in create
    attrs = cls.attributes(create=True, extra=kwargs)
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/factory/base.py", line 316, in attributes
    force_sequence=force_sequence,
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/factory/containers.py", line 263, in build
    sequence = self.factory._generate_next_sequence()
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/factory/base.py", line 287, in _generate_next_sequence
    cls._next_sequence = cls._setup_next_sequence()
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/factory/django.py", line 71, in _setup_next_sequence
    ).order_by('-pk')[0]
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/models/query.py", line 231, in __getitem__
    return list(qs)[0]
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/models/query.py", line 108, in __len__
    self._result_cache.extend(self._iter)
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/models/query.py", line 1140, in iterator
    for row in self.query.get_compiler(self.db).results_iter():
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 775, in results_iter
    for rows in self.execute_sql(MULTI):
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 840, in execute_sql
    cursor.execute(sql, params)
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/backends/sqlite3/base.py", line 366, in execute
    six.reraise(utils.DatabaseError, utils.DatabaseError(*tuple(e.args)), sys.exc_info()[2])
  File "/Users/chaz/dev/envs/startupinst/lib/python2.7/site-packages/django/db/backends/sqlite3/base.py", line 362, in execute
    return Database.Cursor.execute(self, query, params)
DatabaseError: no such table: accounts_siuser

相关设置

INSTALLED_APPS

In [2]: settings.INSTALLED_APPS  
Out[2]:
('grappelli',  
 'django.contrib.admin',  
 'django.contrib.admindocs',  
 'django.contrib.auth',  
 'django.contrib.contenttypes',  
 'django.contrib.messages',  
 'django.contrib.sessions',  
 'django.contrib.sites',  
 'django.contrib.staticfiles',  
 'crispy_forms',  
 'floppyforms',  
 'south',  
 'subdomains',  
 'widget_tweaks',  
 'gunicorn',  
 'apps.application',  
 'apps.app_app',  
 'apps.automated_responses',  
 'apps.accounts',  
 'apps.rampup',  
 'apps.students',  
 'utils.context_processors',  
 'discover_runner')  

pip freeze --local

 Django==1.5.4  
 Pygments==1.6  
 South==0.7.6  
 argparse==1.2.1  
 bpython==0.12  
 coverage==3.6  
 dj-database-url==0.2.1  
 django-braces==1.2.2  
 django-crispy-forms==1.2.2  
 django-debug-toolbar==0.9.4  
 django-discover-runner==0.4  
 django-filepicker==0.1.4  
 django-floppyforms==1.1  
 django-grappelli==2.4.4  
 django-parsley==0.0.2a0  
 django-subdomains==2.0.1  
 django-templated-email==0.4.7  
 django-widget-tweaks==1.1.2  
 envoy==0.0.2  
 factory-boy==2.1.1  
 gunicorn==0.16.1  
 ipdb==0.7  
 ipython==0.13.2  
 psycopg2==2.4.5  
 pytz==2013b  
 requests==2.0.0  
 simplejson==3.3.1  
 six==1.4.1  
 stripe==1.7.7  
 zulip==0.2.1  

设置/ test.py

""" Test settings and globals which allow us to write our tests locally."""
from .common import *

########
# APPS #
########
INSTALLED_APPS += (
    'discover_runner',
)

#################
# TEST SETTINGS #
#################
#TEST_RUNNER = 'django_pytest.test_runner.TestRunner'
TEST_RUNNER = "discover_runner.DiscoverRunner"
TEST_DISCOVER_TOP_LEVEL = PROJECT_ROOT
TEST_DISCOVER_PATTERN = "test_*"
SOUTH_TESTS_MIGRATE = False


###########################
# IN MEMORY TEST DATABASE #
###########################

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.sqlite3",
        "NAME": ":memory:",
    },
}

类似的SO问题没有解决问题

到目前为止我尝试了什么

  • 在另一个分支上运行测试,在发生这种情况时没有更改 结果:获得完全相同的错误和引用
  • 吹走我的虚拟环境,开始新的虚拟环境 结果:无变化

1 个答案:

答案 0 :(得分:0)

我最终从我的South文件*中删除了settings/test.py,并且数据库已正确创建。如果有人对为什么会发生这种情况有任何想法,我们很乐意听到。下面的设置应该禁用South,导致Django的syncdb创建正确的表。

SOUTH_TESTS_MIGRATE = False  
SOUTH_SKIP_TESTS = True

*我有每个环境的设置文件,所以只需将South放在需要它的那些文件中,而不是将它放在base.py中,这是它们都继承的地方。