我有一个看似愚蠢和简单的错误,但对于我的生活,我不明白为什么这不工作。在我的测试中,当我比较两个字典时,我得到以下错误:
Traceback (most recent call last):
File "/path/to_my_app/tests/test_unit.py", line 120, in test_destroy_data
self.assertEqual(obsolete_data, expected_obsolete_data)
AssertionError: {'cou[45 chars]es': {<Category: Test Category>}, 'beers': {<Beer: Test Beer>}} != {'cou[45 chars]es': {<Category: Test Category>}, 'beers': {<Beer: Test Beer>}}
{'beers': {<Beer: Test Beer>},
'categories': {<Category: Test Category>},
'countries': {<Country: Test Country>}}
Django 2.0、Python 3.5
我的方法:
def destroy_data(self):
"""
Remove entries not in the csv file.
"""
obsolete_data = {
'beers': set(Beer.objects.all()) ^ set(self.beer_list),
'categories': set(Category.objects.all()) ^ set(self.category_list),
'countries': set(Country.objects.all()) ^ set(self.country_list),
}
for data in obsolete_data:
[obj.delete() for obj in obsolete_data[data]]
return obsolete_data
我的测试:
def test_destroy_data(self):
"""
Remove old entries.
"""
self.importer.import_data(destroy=False)
obsolete_data = self.importer.destroy_data()
expected_obsolete_data = {
'countries': {self.country},
'categories': {self.category},
'beers': {self.beer},
}
self.assertEqual(obsolete_data, expected_obsolete_data)
当我在调试器中检查这两个值时,它们都是相同的,或者至少它们是这样打印出来的。我试过用unicode写密钥,但也遇到同样的错误。为什么会弹出这个[45个字符]?你知道吗
更新
使用时,我已将maxDiff设置为“无”资产净值,我确实得到了整个错误输出,但错误保持不变:
Traceback (most recent call last):
File "/path/to_my_app/tests/test_unit.py", line 124, in test_destroy_data
self.assertDictEqual(obsolete_data, expected_obsolete_data)
AssertionError: {'cat[35 chars]>}, 'beers': {<Beer: Test Beer>}, 'countries':[22 chars]ry>}} != {'cat[35 chars]>}, 'countries': {<Country: Test Country>}, 'b[22 chars]er>}}
{'beers': {<Beer: Test Beer>},
'categories': {<Category: Test Category>},
'countries': {<Country: Test Country>}}
经过一段时间的调试,我发现了问题所在。我从数据库中删除了这些实例,但它们仍然加载在内存中。因此,当我将它们与返回数据进行比较时,它们是不同的对象,尽管它们包含相同的数据(除了一个)实例id无,其他为1)。 所以我不得不手动测试特定属性:
相关问题 更多 >
编程相关推荐