- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
classmethod TestCase.setUpTestData()
The class-level atomic block described above allows the creation of initial data at the class level, once for the whole TestCase.
[...]
Be careful not to modify any objects created in setUpTestData() in your test methods. Modifications to in-memory objects from setup work done at the class level will persist between test methods.
引用。 django.test.TestCase.setUpTestData
考虑这个例子:
class FoobarTest(TestCase):
@classmethod
def setUpTestData(cls):
cls.post = Post()
cls.post.stats = {}
cls.post.save()
def setUp(self):
self.post.refresh_from_db()
def test_foo(self):
self.post.stats['foo'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'foo': 1}) # this should fail
def test_bar(self): # this run first cause alphabetical order
self.post.stats['bar'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'bar': 1})
自
Modifications to in-memory objects from setup work done at the class level will persist between test methods
我预计这两种测试方法中的一种会失败,因为 post
对象也将具有不同的属性并且相等性应该会失败。
但是这个测试毫无问题地通过了。
如果我强制执行顺序,它实际上表现得像预期的那样:
class FoobarTest(TestCase):
@classmethod
def setUpTestData(cls):
cls.post = Post()
cls.post.stats = {}
cls.post.save()
def setUp(self):
self.post.refresh_from_db()
def _foo(self):
self.post.stats['foo'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'foo': 1})
def _bar(self):
self.post.stats['bar'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'bar': 1})
def test_foo_bar(self):
self._foo()
self._bar() # this fail
问题是:
在第一个示例中,测试方法是否以某种并行方式运行?他们真的会在一些与时间相关的巧合下失败吗?
关于 order in which tests are executed 的 Django 文档不谈测试方法。
在this post我发现测试方法的顺序可以改变,但是一个接一个,没有并行性,除非我使用 python manage.py test --parallel
。
最佳答案
这是我的测试,使用内存而不是数据库:
from django.test import TestCase
class Post(object):
def __init__(self):
self.stats = {}
def refresh_from_db(self):
pass
def save(self):
pass
class FoobarTest(TestCase):
@classmethod
def setUpTestData(cls):
cls.post = Post()
cls.post.stats = {}
def setUp(self):
self.post.refresh_from_db()
def test_foo(self):
self.post.stats['foo'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'foo': 1}) # this should fail
def test_bar(self): # this run first cause alphabetical order
self.post.stats['bar'] = 1
self.post.save()
self.assertEquals(self.post.stats, {'bar': 1})
这是我的结果:
self.assertEquals(self.post.stats, {'foo': 1}) # this should fail
AssertionError: {'bar': 1, 'foo': 1} != {'foo': 1}
- {'bar': 1, 'foo': 1}
+ {'foo': 1}
将方法foo
改成afoo
,结果符合预期:
self.assertEquals(self.post.stats, {'bar': 1})
AssertionError: {'foo': 1, 'bar': 1} != {'bar': 1}
- {'bar': 1, 'foo': 1}
+ {'bar': 1}
所以这可能是数据库问题?
在您的断言中,您正在检查内存中的对象:如果 save
失败,refresh_from_db
返回起始空对象,因此下一次检查通过。
尝试在保存
后取回数据,然后检查它们。
关于python - 使用 setUpTestData 的 Django 测试不会保留测试之间的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58234957/
我需要在我的 setUpTestData 序列中添加多对多关系,这样我的测试才能正确运行。 根据 the docs ,在保存对象之前无法创建多对多关系,因为主键必须首先存在。这意味着我不能像处理其他变
我正在运行 django + django_tenants + django_restframework。在 Multi-Tenancy 环境中,每个模式的租户表中都需要有一个实例 - 在我的测试中,
我真的很享受 Django 1.8 中 setUpTestData 和 --keepdb 带来的便利! 但是,我遇到了在多个测试文件中保持数据一致的问题。我想将我的 setUpTestData 类方法
Django 1.8 附带 a refactored TestCase它允许通过 setUpTestData() 使用事务和保存点在类级别初始化数据方法。这与 unittest 的 setUp() 形
classmethod TestCase.setUpTestData() The class-level atomic block described above allows the creatio
我正在尝试使用测试运行程序测试 Django 应用程序。我想设置一次测试数据以运行多个不同的测试类,而不是在每个测试类中设置相同的数据。因此,我使用 setUpTestData() 而不是 setUp
继承母类使其类方法 setUpTestData 为每个子类调用。这是我异常(exception)但不是我想要的。 这是一个极简主义的例子 from django.test import TestCas
我有一堆 fixture 东西,我想为测试类做一次,但我也不希望相关的测试弄乱它。 我还没有真正了解 py.test fixture 系统,所以我不知道应该如何完成。 在 vanilla Django
更具体地说,每个的用例是什么? 目前我所了解的内容: 设置类 此方法在测试类中的所有测试之前运行一次 设置测试数据 如果数据库支持事务,则此方法运行一次。否则它会在每次测试之前运行。 设置 此方法在测
我在单元测试中遇到了数据库问题。我认为这与我使用 TestCase 和 setUpData 的方式有关。 当我尝试使用某些值设置我的测试数据时,测试会抛出以下错误: django.db.utils.I
我是一名优秀的程序员,十分优秀!