New submission from Matthijs van der Vleuten:
When calling assertItemsEqual(first,second), if the items in a and b differ,
the AssertionError treats second as the first sequence and first as the second
sequence.
Repro code:
>>> from unittest.case import TestCase
>>> class Foo(TestCase):
... def runTest(self):
... self.assertItemsEqual([1],[])
...
>>> Foo().runTest()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<stdin>", line 3, in runTest
File "/usr/lib/python2.7/unittest/case.py", line 899, in assertItemsEqual
self.fail(msg)
File "/usr/lib/python2.7/unittest/case.py", line 408, in fail
raise self.failureException(msg)
AssertionError: Element counts were not equal:
First has 0, Second has 1: 1
This happens because of this code in unittest/case.py:
def assertItemsEqual(self, expected_seq, actual_seq, msg=None):
# (skip docstring)
first_seq, second_seq = list(actual_seq), list(expected_seq)
list(actual_seq) is assigned to first_seq, even though it's actually the second
argument.
This would be fixed either by swapping expected_seq and actual_seq in the
function's arguments, or swapping the assignment of first_seq and second_seq.
----------
components: Library (Lib)
messages: 184452
nosy: Zr40
priority: normal
severity: normal
status: open
title: unittest.assertItemsEqual reports wrong order
type: behavior
versions: Python 2.7
_______________________________________
Python tracker <[email protected]>
<http://bugs.python.org/issue17459>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe:
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com