How can I enable foreign-key checks in pytest using sqllite(如何使用sqllite在pytest中启用外键检查)
问题描述
我有一个Django项目,其测试在我调用py.test
时运行,但我最近注意到它没有检查外键约束。如何让它检查外键约束?
显然,foreign key constraints weren't even possible until sqlite 3,但是我真的不知道我正在运行什么版本,因为我没有sqlite的CLI,但是它只是被Django自动包括在内?(我使用的是Django 1.9.10),但是sqlite3是在2009年发布的,所以这不是问题所在,对吧?
也许it must still be enabled by the application at runtime, using the PRAGMA foreign_keys command.,但我不知道如何使我的测试做到这一点?
[更新] 因此,看起来sqlite开箱即用并未检查它们。
class Referenced(models.Model):
pass
class Referencer(models.Model):
fk = models.ForeignKey(Referenced)
>>> Referencer.objects.create(fk_id=-1)
<Referencer>
>>> Referencer.objects.all()[0].fk
DoesNotExist
推荐答案
我最终创建了一个包来解决此问题。
pip install sqlite_checkforeignkeys
然后配置数据库:
DATABASES = {
'default': {
'ENGINE': 'sqlite_checkforeignkeys_engine',
'TEST': {'NAME': ':memory:'},
}
}
它涉及重写现有的SQLite引擎以强制执行外键
有关详细信息,请访问https://github.com/hulu/sqlite_checkforeignkeys
这篇关于如何使用sqllite在pytest中启用外键检查的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何使用sqllite在pytest中启用外键检查


基础教程推荐
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 在多列上分布任意行 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01