我创建了这样一个简单的测试用例:
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 = {
'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_manager将执行一些查询,并在表用户上添加新记录。
我想,当我运行这个测试用例时,Django会以某种方式读取我的模型并创建一个包含所有这些模型的表的测试数据库。我说得对吗?
发布于 2016-10-17 10:35:04
因此,我发现我需要将我的models.py放在我的用户文件夹中,并将“用户”添加到INSTALLED_APPS设置中。现在起作用了。
发布于 2016-10-15 14:35:08
您的测试数据库需要与生产数据库不同。一旦运行测试用例,测试数据库就会被销毁。在您的示例中,没有创建数据库。您应该阅读本文档以获得详细信息,https://docs.djangoproject.com/en/1.10/topics/testing/overview/还可以添加user_manager模块的片段吗?
https://stackoverflow.com/questions/40060253
复制相似问题