Django Unitest:表不存在

时间:2016-10-15 14:29:39

标签: python mysql django django-unittest

我创建了一个简单的测试用例:

from unittest import TestCase
import user_manager


class UserTest(TestCase):
    def test_register(self):
        email = "dung7@gmail.com"
        password = "123456"
        result, user = user_manager.setup_new_user(email, password)
        self.assertEqual(result, CodeID.SUCCESS)

然后我运行测试用例:

python manage.py test users

这是日志:

Creating test database for alias 'default'...
/Users/admin/Projects/MyApp/venv/lib/python2.7/site-packages/django/db/backends/mysql/base.py:112: Warning: Table 'mysql.column_stats' doesn't exist
  return self.cursor.execute(query, args)
Creating test database for alias 'myapp_log'...
.FE
======================================================================
ERROR: test_register (users.tests.UserTest)
----------------------------------------------------------------------
Traceback (most recent call last):
...
ProgrammingError: (1146, "Table 'test_myapp.user' doesn't exist")

因此它创建了一个测试数据库,但似乎没有创建表。这是我的DATABASES设置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': "myapp",
        'USER': "root",
        'PASSWORD': "",
        'HOST': '127.0.0.1',
        'PORT': '',
    },
    'myapp_log': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': "myapp_log",
        'USER': "root",
        'PASSWORD': "",
        'HOST': '127.0.0.1',
        'PORT': '',
    },
}

我的模特:

class User(BaseModel):
    uid = models.IntegerField(primary_key=True)
    email = models.CharField(max_length=200)
    password = models.CharField(max_length=200)
    create_time = models.IntegerField()
    update_time = models.IntegerField()
    status = models.IntegerField()
    social_token = models.CharField(max_length=200)
    social_app = models.IntegerField()

    class Meta:
        db_table = 'user'

有人知道为什么没有创建表'user'吗?

更新:

来自我的testcase的

user_manager将执行一些查询并在表用户上添加新记录。

我想当我运行测试用例时,Django将以某种方式读取我的模型并使用这些模型中的所有表创建一个测试数据库。我是对的吗?

2 个答案:

答案 0 :(得分:0)

您的测试数据库需要与生产数据库不同。运行测试用例后,测试数据库将被销毁。在您的情况下,未创建数据库。您应该查看此文档以获取详细信息https://docs.djangoproject.com/en/1.10/topics/testing/overview/ 您还可以添加user_manager模块的片段

答案 1 :(得分:0)

所以我发现我需要将models.py放在我的users文件夹中,并将'users'添加到INSTALL_APPS设置中。现在它奏效了。