我正在使用Robot Framework进行验收测试。
要启动django服务器,我从RobotFramework运行python manage.py runserver
命令。之后,我致电python manage.py migrate
。但测试很慢,因为没有使用内存数据库。
我尝试使用以下配置创建一个名为testing的新设置文件:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': ':memory:',
}
}
使用此配置在运行时设置环境变量DJANGO_SETTINGS_MODULE。
我运行迁移,然后运行runserver,但数据库不存在。我无法弄清楚为什么。如果我使用物理数据库,它就可以工作。
我尝试检查Django TestCase如何运行并创建数据库,但我找不到它。
答案 0 :(得分:0)
您可以在测试开始时使用django.db.connection.creation.create_test_db
函数documented here,然后在完成测试后调用django.db.connection.creation.destroy_test_db
。
答案 1 :(得分:0)
在尝试运行测试用例之前,我尝试通过手动调用make migrate
来模拟execute_from_command_line()
。
所以我选择的命令是:(如果不使用诗歌,则删除poetry run
。
poetry run ./manage.py test --settings=myproject.settings_test
我将此命令放入GNUMakefile
中,以允许我使用make test
。
然后在myproject/settings_test.py
内:
from .settings import *
ALLOWED_HOSTS = [ '127.0.0.1', ]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': ':memory:',
}
}
from django.core.management import execute_from_command_line
execute_from_command_line(['./manage.py', 'migrate'])