[issue31893] Issues with kqueue

Serhiy Storchaka report at bugs.python.org
Thu Nov 9 06:44:17 EST 2017


Serhiy Storchaka <storchaka+cpython at gmail.com> added the comment:

Oh, I didn't test on 2.7.

The old code contradicted the common comparison behavior. It allowed comparing select.kevent with other objects only for equality as for identity. `kevent == other` always returned False even if `other == kevent` returned True. `kevent < other` raised a TypeError.

The new code uses the default behavior. `kevent == other` returns the same as `other == kevent` (False by default if types are not comparable, but may return True if `other.__eq__(kevent)` returns True). `kevent < other` returns the same as `other > kevent`. E.g. raises a TypeError by default in Python 3. But in Python 2 all objects are comparable by default, and this breaks a test which expects that select.kevent is not comparable.

There are two ways to fix this:

1. Make select.kevent non-comparable again. This contradicts the default behavior and I don't know reasons why it should be non-comparable, but this was an existing behavior.

2. Remove the tests or change them to test that comparing select.kevent with other object doesn't raise an error.

----------

_______________________________________
Python tracker <report at bugs.python.org>
<https://bugs.python.org/issue31893>
_______________________________________


More information about the Python-bugs-list mailing list