mirror of
https://github.com/ets-labs/python-dependency-injector.git
synced 2025-05-22 13:36:15 +03:00
Add @inject to the test samples
This commit is contained in:
parent
3facd648be
commit
8d0b7050d2
|
@ -11,30 +11,37 @@ from .service import Service
|
||||||
|
|
||||||
class TestClass:
|
class TestClass:
|
||||||
|
|
||||||
|
@inject
|
||||||
def __init__(self, service: Service = Provide[Container.service]):
|
def __init__(self, service: Service = Provide[Container.service]):
|
||||||
self.service = service
|
self.service = service
|
||||||
|
|
||||||
|
@inject
|
||||||
def method(self, service: Service = Provide[Container.service]):
|
def method(self, service: Service = Provide[Container.service]):
|
||||||
return service
|
return service
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
@inject
|
||||||
def class_method(cls, service: Service = Provide[Container.service]):
|
def class_method(cls, service: Service = Provide[Container.service]):
|
||||||
return service
|
return service
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
@inject
|
||||||
def static_method(service: Service = Provide[Container.service]):
|
def static_method(service: Service = Provide[Container.service]):
|
||||||
return service
|
return service
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_function(service: Service = Provide[Container.service]):
|
def test_function(service: Service = Provide[Container.service]):
|
||||||
return service
|
return service
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_function_provider(service_provider: Callable[..., Service] = Provider[Container.service]):
|
def test_function_provider(service_provider: Callable[..., Service] = Provider[Container.service]):
|
||||||
service = service_provider()
|
service = service_provider()
|
||||||
return service
|
return service
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_config_value(
|
def test_config_value(
|
||||||
some_value_int: int = Provide[Container.config.a.b.c.as_int()],
|
some_value_int: int = Provide[Container.config.a.b.c.as_int()],
|
||||||
some_value_str: str = Provide[Container.config.a.b.c.as_(str)],
|
some_value_str: str = Provide[Container.config.a.b.c.as_(str)],
|
||||||
|
@ -43,23 +50,28 @@ def test_config_value(
|
||||||
return some_value_int, some_value_str, some_value_decimal
|
return some_value_int, some_value_str, some_value_decimal
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_provide_provider(service_provider: Callable[..., Service] = Provider[Container.service.provider]):
|
def test_provide_provider(service_provider: Callable[..., Service] = Provider[Container.service.provider]):
|
||||||
service = service_provider()
|
service = service_provider()
|
||||||
return service
|
return service
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_provided_instance(some_value: int = Provide[Container.service.provided.foo['bar'].call()]):
|
def test_provided_instance(some_value: int = Provide[Container.service.provided.foo['bar'].call()]):
|
||||||
return some_value
|
return some_value
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_subcontainer_provider(some_value: int = Provide[Container.sub.int_object]):
|
def test_subcontainer_provider(some_value: int = Provide[Container.sub.int_object]):
|
||||||
return some_value
|
return some_value
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_config_invariant(some_value: int = Provide[Container.config.option[Container.config.switch]]):
|
def test_config_invariant(some_value: int = Provide[Container.config.option[Container.config.switch]]):
|
||||||
return some_value
|
return some_value
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_provide_from_different_containers(
|
def test_provide_from_different_containers(
|
||||||
service: Service = Provide[Container.service],
|
service: Service = Provide[Container.service],
|
||||||
some_value: int = Provide[SubContainer.int_object],
|
some_value: int = Provide[SubContainer.int_object],
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
from dependency_injector.wiring import Provide
|
from dependency_injector.wiring import inject, Provide
|
||||||
|
|
||||||
from ...container import Container
|
from ...container import Container
|
||||||
from ...service import Service
|
from ...service import Service
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_function(service: Service = Provide[Container.service]):
|
def test_function(service: Service = Provide[Container.service]):
|
||||||
return service
|
return service
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
from dependency_injector import containers, providers
|
from dependency_injector import containers, providers
|
||||||
from dependency_injector.wiring import Provide, Closing
|
from dependency_injector.wiring import inject, Provide, Closing
|
||||||
|
|
||||||
|
|
||||||
class Service:
|
class Service:
|
||||||
|
@ -32,5 +32,6 @@ class Container(containers.DeclarativeContainer):
|
||||||
service = providers.Resource(init_service)
|
service = providers.Resource(init_service)
|
||||||
|
|
||||||
|
|
||||||
|
@inject
|
||||||
def test_function(service: Service = Closing[Provide[Container.service]]):
|
def test_function(service: Service = Closing[Provide[Container.service]]):
|
||||||
return service
|
return service
|
||||||
|
|
Loading…
Reference in New Issue
Block a user