-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample_async.py
63 lines (46 loc) · 1.72 KB
/
example_async.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
#!/usr/bin/env python3
# encoding: utf-8
# -*- coding: utf-8 -*-
import asyncio, time
from cachettl import async_cachettl, async_cachettl_min
@async_cachettl(ttl=7)
async def print_my_data(param):
print("Starting print_my_data() function...")
await asyncio.sleep(1) # Just wait 1 second to simulate an asynchronous operation
return f"- Data for {param}"
async def main():
print("\nTesting with a TTL of 7 seconds\n")
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print("")
print(await print_my_data('Test 2'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 2'))
print(f" {print_my_data.cache_info()}")
print("")
print(await print_my_data('Test 3'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 3'))
print(f" {print_my_data.cache_info()}")
print("\ntime.sleep(1.5)...\n")
time.sleep(1.5)
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 2'))
print(f" {print_my_data.cache_info()}")
print("\ntime.sleep(1.5)...\n")
time.sleep(1.5)
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 2'))
print(f" {print_my_data.cache_info()}")
print("\ntime.sleep(5) to expire the time-to-live cache...\n")
time.sleep(5)
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print(await print_my_data('Test 1'))
print(f" {print_my_data.cache_info()}")
print("")
asyncio.run(main())