-
Notifications
You must be signed in to change notification settings - Fork 0
/
example.py
96 lines (64 loc) · 1.27 KB
/
example.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
import asyncio
import pprint
import time
from wraptimer import TimeIt, Timer
# initialize
t = Timer(timer_type="performance")
# start timer
t.start()
# some long running code
time.sleep(1)
# stop timer
t.stop()
# get duration taken to run
print("took", t.time_string)
timeit = TimeIt()
@timeit.byline
def test_by_line():
a = 10
b = 20
time.sleep(0.8)
c = a + b
return [a, b, c]
@timeit.byline
async def test_by_line_async():
a = 10
b = 20
await asyncio.sleep(1.25)
return [a, b]
@timeit.func
def test_func(v=10):
time.sleep(1.5)
x = v * 50
return x
@timeit.func
async def test_func_async(v=10):
await asyncio.sleep(2.34)
x = v * 50
return x
test_by_line()
print()
asyncio.run(test_by_line_async())
test_by_line()
asyncio.run(test_by_line_async())
test_func(200)
asyncio.run(test_func_async(200))
# init
timeit_non_verbose = TimeIt(verbose=False)
# decorate
@timeit_non_verbose.byline
def test_non_verbose(v=1):
time.sleep(1.5)
x = v * 50
return x
resp = test_non_verbose(22)
pprint.pprint(resp)
timeit_non_verbose = TimeIt(show_args=True)
# decorate
@timeit_non_verbose.byline
def test_non_verbose(v=1):
time.sleep(1.5)
x = v * 50
return x
resp = test_non_verbose(22)
pprint.pprint(resp)