circuitpython/tests/basics/set_binop.py

67 lines
1.7 KiB
Python
Raw Normal View History

# test set binary operations
2014-01-12 18:37:45 -05:00
sets = [set(), {1}, {1, 2}, {1, 2, 3}, {2, 3}, {2, 3, 5}, {5}, {7}]
for s in sets:
for t in sets:
print(sorted(s), '|', sorted(t), '=', sorted(s | t))
print(sorted(s), '^', sorted(t), '=', sorted(s ^ t))
print(sorted(s), '&', sorted(t), '=', sorted(s & t))
print(sorted(s), '-', sorted(t), '=', sorted(s - t))
2014-01-12 18:37:45 -05:00
u = s.copy()
u |= t
print(sorted(s), "|=", sorted(t), '-->', sorted(u))
2014-01-12 18:37:45 -05:00
u = s.copy()
u ^= t
print(sorted(s), "^=", sorted(t), '-->', sorted(u))
2014-01-12 18:37:45 -05:00
u = s.copy()
u &= t
print(sorted(s), "&=", sorted(t), "-->", sorted(u))
2014-01-12 18:37:45 -05:00
u = s.copy()
u -= t
print(sorted(s), "-=", sorted(t), "-->", sorted(u))
2014-01-12 18:09:10 -05:00
print(sorted(s), '==', sorted(t), '=', s == t)
print(sorted(s), '!=', sorted(t), '=', s != t)
print(sorted(s), '>', sorted(t), '=', s > t)
print(sorted(s), '>=', sorted(t), '=', s >= t)
print(sorted(s), '<', sorted(t), '=', s < t)
print(sorted(s), '<=', sorted(t), '=', s <= t)
print(set('abc') == 1)
# make sure inplace operators modify the set
s1 = s2 = set('abc')
s1 |= set('ad')
print(s1 is s2, len(s1))
s1 = s2 = set('abc')
s1 ^= set('ad')
print(s1 is s2, len(s1))
s1 = s2 = set('abc')
s1 &= set('ad')
print(s1 is s2, len(s1))
s1 = s2 = set('abc')
s1 -= set('ad')
print(s1 is s2, len(s1))
# RHS must be a set
try:
print(set('12') >= '1')
except TypeError:
print('TypeError')
# RHS must be a set
try:
print(set('12') <= '123')
except TypeError:
print('TypeError')
# unsupported operator
try:
set('abc') * 2
except TypeError:
print('TypeError')