generated from RnD-2020/admin-C-Learner
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathunit4_lesson_01_understanding_modules.py
139 lines (104 loc) · 3.73 KB
/
unit4_lesson_01_understanding_modules.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
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
__author__ = 'Kalyan'
notes = '''
modules are a abstraction feature which greatly aids in building large applications.
modules are defined in .py file (socket.py, random.py, csv.py ...) and usually contain
a set of function, data and class definitions which provide a specific functionality. This
allows for easy reuse and discovery of functionality. e.g. you can be pretty sure that
socket module exposes functionality related to communication using sockets.
Each of our lesson and assignments is a module too (though they do not expose any useful api).
Reading material:
- http://effbot.org/zone/import-confusion.htm
'''
notes_1 = '''
All these tests uses module1.py to module4.py. Take a look at them before starting on the tests.
'''
#this is a global import, generally you use only these. rarely will you use function level imports, but we are doing that
#here for the sake of testing how import works by limiting the scope of the import to each function.
import sys
import placeholders
from placeholders import *
def test_module_without_import():
try:
module1.greet("jack")
except ___ : # what specific exception did you get here, replace ___ with that
print() # print it out and see
assert ___
def test_module_usage_needs_import():
import module1
assert __ == module1.greet("jack")
def test_module_usage_multiple():
import module1
import module2
assert __ == module1.greet("jack")
assert __ == module2.greet("jack")
def test_module_import_affects_current_namespace():
import module1
def inner_func():
import module2
assert __ == ('module2' in locals())
return module2.greet("jack")
assert __ == module1.greet("jack")
assert __ == inner_func()
assert __ == ('placeholders' in locals())
assert __ == ('placeholders' in globals())
assert __ == ('module1' in locals())
assert __ == ('module1' in globals())
assert __ == ('module2' in locals())
assert __ == ('module2' in globals())
def test_module_type():
assert __ == type(placeholders).__name__
def test_module_is_an_object():
assert __ == len(dir(placeholders))
assert __ == placeholders.__name__
assert __ == placeholders.__doc__
def test_module_from_import():
from module1 import greet
assert __ == ('module1' in locals())
assert __ == ('greet' in locals())
try:
module1.greet()
except __ :
pass
assert __ == greet("jack")
def test_module_why_from_import_is_a_bad_idea():
from module1 import greet
from module2 import greet
assert __ == greet("jack")
def test_modules_are_cached():
import module1
import module1 as new_name
def inner():
import module1
return module1.some_attr
try:
inner()
except __: # what exception do you get here?
pass
module1.some_attr = 10
assert __ == inner()
def inner2():
import module1
return module1.some_attr
assert __ == inner2()
assert __ == type(sys.modules).__name__
assert __ == (module1 is sys.modules['module1'])
assert __ == ('new_name' in sys.modules)
assert __ == (new_name is module1)
assert __ == (new_name is sys.modules['module1'])
s1 = set()
s2 = set()
s3 = set()
s1 = set(dir())
from module3 import *
s2 = set(dir())
from module4 import *
s3 = set(dir())
def test_module_star_import():
# * imports are not allowed within functions, so we had to do it at global scope
assert __ == (s2 - s1) # what did module3 import bring in.
assert __ == (s3 - s2) # what did module4 import bring in.
three_things_i_learnt = """
-
-
-
"""