Python奇怪的[n chars]编码错误?

Saš*_*aba 5 python django encoding python-3.x

我有一个看似愚蠢而简单的错误,但我一生都无法弄清楚为什么这不起作用。在我的测试中,当我比较两个字典时,出现以下错误:

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>}}
Run Code Online (Sandbox Code Playgroud)

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
Run Code Online (Sandbox Code Playgroud)

我的测试:

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)
Run Code Online (Sandbox Code Playgroud)

当我在调试器中检查这两个值时,它们都是相同的,或者至少它们以这种方式打印出来。我尝试过用 unicode 编写密钥,但遇到了同样的错误。为什么会弹出这个[45个字符] ?

更新

我在使用 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>}}
Run Code Online (Sandbox Code Playgroud)

Saš*_*aba 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
)
Run Code Online (Sandbox Code Playgroud)