在内存数据库中使用sqlite运行django

时间:2014-11-27 15:36:06

标签: django sqlite testing robotframework

我正在使用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如何运行并创建数据库,但我找不到它。

2 个答案:

答案 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'])