gpt4 book ai didi

mysql - 当我在测试期间更改表时,为什么我的 Django 测试套件无法在测试之间刷新数据库?

转载 作者:行者123 更新时间:2023-11-29 02:24:05 24 4
gpt4 key购买 nike

我已将我的 auth.user 模型替换为一个自定义用户模型,该模型的用户名是 unique_together with the company。为了完成这项工作,我手动(通过迁移)从用户表中删除了唯一约束。我想编写一个测试来验证它是否按预期工作(在适当的时候返回错误消息等),但我无法理解为什么测试框架的行为不像我期望的那样。这是我在测试中所做的:

class UserTests(TestCase):
def setUp(self):
self.client = Client()
# Setup: Create users, companies, etc. to use in the test

def test_create_dup_staffuser(self):
cursor = connection.cursor()
try:
cursor.execute("alter table config_user drop index `username`;")
finally:
cursor.close()

# Test code: Create some data, pass it to my 'create user' view,
# verify the results

def test_user_something_else(self):
# Test other things

测试本身有效。约束已按预期移除,并且我的测试通过,允许我在公司内创建具有重复用户名的用户。问题是,约束删除阻止了我的数据库在下一次测试之前刷新,并且 test_user_something_else 开始时所有数据仍然来自 test_create_dup_staffuser(我通过注释掉 alter 表来验证这一点,这使所有内容都可以刷新)。

我怀疑从进入 TestCase 开始,我的更改以某种方式阻止了测试结束时的事务回滚,但我不确定如何或如何处理它。我尝试在测试结束时放回约束,但得到了相同的结果。我还尝试手动添加一个 tearDown 并从我的数据库中删除我的所有数据,但这也没有用。当我在下一次测试的设置开始时遇到我的断点时,数据又回来了。

有人可以解释这里发生了什么,并建议我如何合理地测试这个功能吗?我的下一步可能是打开数据库日志记录以尝试弄清楚发生了什么,但除此之外,我没有想法。

我已经考虑过的解决方法:

  • 使用迁移:我们的迁移很复杂并且有一些错误。修复/压缩它们在列表中,但还没有。
  • 重做类:我(现在)可以想出各种方法来更改我的自定义用户类以使其不那么复杂,但是这段代码已经在生产和工作中,所以我现在不能真正这样做,要么。
  • 升级到 django 1.7:它已经在列表中,但不会进入此开发周期。
  • 暂时跳过该测试:这是我当前的备份计划。

使用 django 1.5.8/python 2.7/mysql 5.5

最佳答案

I suspect from stepping down into TestCase that my change is preventing the transaction rollback at the end of the test somehow, but I'm not really sure how yet or what to do about it.

我想就是这样。我建议转到 TransactionTestCase,它不使用事务来重置数据库。

在您的案例中,为什么交易会搞砸?请记住,这些事情不断变化,这 answer (用户 joeforker)表示您使用的 MySQL 将改变模式的指令视为“导致[ing]隐式提交”,这肯定会弄乱 TestCase 的预期。因此,您的 alter table 命令会从 TestCase 的脚下“拉下地毯”(可以这么说)。

关于mysql - 当我在测试期间更改表时,为什么我的 Django 测试套件无法在测试之间刷新数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26385478/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com