1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- from sympy.multipledispatch.conflict import (supercedes, ordering, ambiguities,
- ambiguous, super_signature, consistent)
- class A: pass
- class B(A): pass
- class C: pass
- def test_supercedes():
- assert supercedes([B], [A])
- assert supercedes([B, A], [A, A])
- assert not supercedes([B, A], [A, B])
- assert not supercedes([A], [B])
- def test_consistent():
- assert consistent([A], [A])
- assert consistent([B], [B])
- assert not consistent([A], [C])
- assert consistent([A, B], [A, B])
- assert consistent([B, A], [A, B])
- assert not consistent([B, A], [B])
- assert not consistent([B, A], [B, C])
- def test_super_signature():
- assert super_signature([[A]]) == [A]
- assert super_signature([[A], [B]]) == [B]
- assert super_signature([[A, B], [B, A]]) == [B, B]
- assert super_signature([[A, A, B], [A, B, A], [B, A, A]]) == [B, B, B]
- def test_ambiguous():
- assert not ambiguous([A], [A])
- assert not ambiguous([A], [B])
- assert not ambiguous([B], [B])
- assert not ambiguous([A, B], [B, B])
- assert ambiguous([A, B], [B, A])
- def test_ambiguities():
- signatures = [[A], [B], [A, B], [B, A], [A, C]]
- expected = {((A, B), (B, A))}
- result = ambiguities(signatures)
- assert set(map(frozenset, expected)) == set(map(frozenset, result))
- signatures = [[A], [B], [A, B], [B, A], [A, C], [B, B]]
- expected = set()
- result = ambiguities(signatures)
- assert set(map(frozenset, expected)) == set(map(frozenset, result))
- def test_ordering():
- signatures = [[A, A], [A, B], [B, A], [B, B], [A, C]]
- ord = ordering(signatures)
- assert ord[0] == (B, B) or ord[0] == (A, C)
- assert ord[-1] == (A, A) or ord[-1] == (A, C)
- def test_type_mro():
- assert super_signature([[object], [type]]) == [type]
|