Python怪异[n chars]编码错误?

时间:2018-03-27 08:53:45

标签: python django python-3.x encoding

我有一个看似愚蠢和简单的错误,但对于我的生活,我无法弄清楚为什么这不起作用。在我的测试中,当我比较两个词典时,我得到了这个错误:

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>}}

1 个答案:

答案 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
)