我有一个看似愚蠢和简单的错误,但对于我的生活,我无法弄清楚为什么这不起作用。在我的测试中,当我比较两个词典时,我得到了这个错误:
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 chars] ?
更新
我在使用self.assertDictEqual时将maxDiff设置为None,我确实得到了整个错误输出,但错误保持不变:
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>}}
答案 0 :(得分:0)
经过一些调试后,我发现了问题。我从数据库中删除了这些实例,但它们仍然在内存中加载。因此,当我将它们与返回数据进行比较时,它们是不同的对象,即使它们保存相同的数据(除了一个instance.id是None,另一个是1)。 所以我不得不手动测试特定的属性:
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['countries'][0].name,
expected_obsolete_data['countries'][0].name
)
self.assertEqual(
obsolete_data['categories'][0].name,
expected_obsolete_data['categories'][0].name
)
self.assertEqual(
obsolete_data['beers'][0].name,
expected_obsolete_data['beers'][0].name
)