1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
from multipledispatch.conflict import (
supercedes,
ordering,
ambiguities,
ambiguous,
super_signature,
consistent,
)
from multipledispatch.dispatcher import Variadic
class A(object):
pass
class B(A):
pass
class C(object):
pass
def _test_supercedes(a, b):
assert supercedes(a, b)
assert not supercedes(b, a)
def test_supercedes():
_test_supercedes([B], [A])
_test_supercedes([B, A], [A, A])
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 = set([((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]
def test_supercedes_variadic():
_test_supercedes((Variadic[B],), (Variadic[A],))
_test_supercedes((B, Variadic[A]), (Variadic[A],))
_test_supercedes((Variadic[A],), (Variadic[(A, C)],))
_test_supercedes((A, B, Variadic[C]), (Variadic[object],))
_test_supercedes((A, Variadic[B]), (Variadic[A],))
_test_supercedes(tuple([]), (Variadic[A],))
_test_supercedes((A, A, A), (A, Variadic[A]))
def test_consistent_variadic():
# basic check
assert consistent((Variadic[A],), (Variadic[A],))
assert consistent((Variadic[B],), (Variadic[B],))
assert not consistent((Variadic[C],), (Variadic[A],))
# union types
assert consistent((Variadic[(A, C)],), (Variadic[A],))
assert consistent((Variadic[(A, C)],), (Variadic[(C, A)],))
assert consistent((Variadic[(A, B, C)],), (Variadic[(C, B, A)],))
assert consistent((A, B, C), (Variadic[(A, B, C)],))
assert consistent((A, B, C), (A, Variadic[(B, C)]))
# more complex examples
assert consistent(tuple([]), (Variadic[object],))
assert consistent((A, A, B), (A, A, Variadic[B]))
assert consistent((A, A, B), (A, A, Variadic[A]))
assert consistent((A, B, Variadic[C]), (B, A, Variadic[C]))
assert consistent((A, B, Variadic[C]), (B, A, Variadic[(C, B)]))
# not consistent
assert not consistent((C,), (Variadic[A],))
assert not consistent((A, A, Variadic[C]), (A, Variadic[C]))
assert not consistent((A, B, Variadic[C]), (C, B, Variadic[C]))
|