-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathunit2_lesson_02_understanding_truth.py
80 lines (68 loc) · 2.98 KB
/
unit2_lesson_02_understanding_truth.py
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
__author__ = 'Kalyan'
from placeholders import *
notes = '''
Just like C, python has notions on what values are considered true
and what values are considered false.
Assigning truth equivalence to non-bool types leads to much more
elegant way of writing code instead of having explicit comparisons
with base values of the data types like 0, '', [] etc.
'''
#None is a first class object in python
def test_none_type():
assert 'NoneType' == type(None).__name__
#In control flow, builtin objects like string, list, tuple have truth
#and false values
def test_truth_none():
value = None
result = "not-set"
#is None treated as true or false?
if value:
result = "true"
else:
result = "false"
assert "false" == result
# a helper function used to test the truth value of an object.
def truth_test(object, description):
if object:
return description + " is treated as true"
else:
return description + " is treated as false"
def test_truth_values():
assert 'empty string is treated as false' == truth_test("", "empty string")
assert 'empty tuple is treated as false' == truth_test((), "empty tuple")
assert 'empty list is treated as false' == truth_test([], "empty list")
assert 'empty dict is treated as false' == truth_test({}, "empty dict")
assert 'empty set is treated as false' == truth_test(set(), "empty set")
assert 'white space is treated as true' == truth_test(" ", "white space")
assert '0 is treated as false' == truth_test(0, "0")
assert '1 is treated as true' == truth_test(1, "1")
assert 'non-empty-string is treated as true' == truth_test("a", "non-empty-string")
assert 'non-empty-tuple is treated as true' == truth_test((1,2), "non-empty-tuple")
assert 'non-empty-list is treated as true' == truth_test([1], "non-empty-list")
assert 'non-empty-dict is treated as true' == truth_test({1:2}, "non-empty-dict")
assert 'non-empty-set is treated as true' == truth_test({1}, "non-empty-set")
# The fact that certain things are treated as True or False by
# control flow statements does not mean that they are equal to True or False.
def test_equality():
assert False == ("" == True)
assert False == (() == True)
assert False == ([] == True)
assert False == (set() == True)
assert False == (0 == True)
assert False == ("" == False)
assert False == (() == False)
assert False == ([] == False)
assert False == (set() == False)
assert True == (0 == False) # what happened here?
assert True == (1 == True)
assert False == ("a" == True)
assert False == ((1,2) == True)
assert False == ([1] == True)
assert False == ({1} == True)
three_things_i_learnt = """
-Assigning truth equivalence to non-bool types leads to much more
elegant way of writing code instead of having explicit comparisons
with base values of the data types like 0, '', []
-None is a first class object in python
-
"""