8000 Add docs and example · kiq7/python-dependency-injector@ef91b6f · GitHub
[go: up one dir, main page]

Skip to content

Commit ef91b6f

Browse files
committed
Add docs and example
1 parent d48e2ea commit ef91b6f

File tree

3 files changed

+43
-4
lines changed

3 files changed

+43
-4
lines changed

docs/providers/singleton.rst

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,14 @@ provider.
5454
Resetting of the memorized object clears the reference to it. Further object's lifecycle is
5555
managed by the garbage collector.
5656

57+
Method ``.reset()`` resets only current provider. To reset all dependent singleton providers
58+
call ``.full_reset()`` method.
59+
60+
.. literalinclude:: ../../examples/providers/singleton_full_resetting.py
61+
:language: python
62+
:lines: 3-
63+
:emphasize-lines: 25
64+
5765
Using singleton with multiple threads
5866
-------------------------------------
5967

Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
"""`Singleton` provider full resetting example."""
2+
3+
from dependency_injector import containers, providers
4+
5+
6+
class Database:
7+
...
8+
9+
10+
class UserService:
11+
def __init__(self, db: Database):
12+
self.db = db
13+
14+
15+
class Container(containers.DeclarativeContainer):
16+
17+
database = providers.Singleton(Database)
18+
19+
user_service = providers.Singleton(UserService, db=database)
20+
21+
22+
if __name__ == '__main__':
23+
container = Container()
24+
25+
user_service1 = container.user_service()
26+
27+
container.user_service.full_reset()
28+
29+
user_service2 = container.user_service()
30+
assert user_service2 is not user_service1
31+
assert user_service2.db is not user_service1.db

examples/providers/singleton_resetting.py

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -9,15 +9,15 @@ class UserService:
99

1010
class Container(containers.DeclarativeContainer):
1111

12-
user_service_provider = providers.Singleton(UserService)
12+
user_service = providers.Singleton(UserService)
1313

1414

1515
if __name__ == '__main__':
1616
container = Container()
1717

18-
user_service1 = container.user_service_provider()
18+
user_service1 = container.user_service()
1919

20-
container.user_service_provider.reset()
20+
container.user_service.reset()
2121

22-
user_service2 = container.user_service_provider()
22+
user_service2 = container.user_service()
2323
assert user_service2 is not user_service1

0 commit comments

Comments
 (0)
0