From 50a3db6b94002fce370560eee91b6865db3a14f3 Mon Sep 17 00:00:00 2001 From: Roman Mogilatov Date: Thu, 3 Sep 2015 00:24:20 +0300 Subject: [PATCH] Update Factory provider docs --- .../providers/factory_init_injections.png | Bin 18876 -> 17647 bytes .../factory_init_injections_and_contexts.png | Bin 34096 -> 30896 bytes docs/providers/factory.rst | 99 +++++++++++------- examples/providers/factory_init_injections.py | 11 +- .../factory_init_injections_and_contexts.py | 17 ++- 5 files changed, 74 insertions(+), 53 deletions(-) diff --git a/docs/images/providers/factory_init_injections.png b/docs/images/providers/factory_init_injections.png index 8a104712f73a995290b85f6f150e7a1287d2e9a9..b7a4f1fdc3cd4451205306e35f67362961320953 100644 GIT binary patch literal 17647 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 G0{;`)e=Ics literal 18876 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 literal 34096 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

}Zgw72!MI-r2yk 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 diff --git a/docs/providers/factory.rst b/docs/providers/factory.rst index 01e431e8..5f9c6109 100644 --- a/docs/providers/factory.rst +++ b/docs/providers/factory.rst @@ -12,42 +12,33 @@ Nothing could be better than brief example: .. literalinclude:: ../../examples/providers/factory.py :language: python -Factory providers and injections -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -Objects can take dependencies in different forms. Some objects take init -arguments, other are using attributes setting or method calls to be -initialized. It affects how such objects need to be created and initialized, -and that is the place where ``dependency_injector.injections`` need to be used. - -``Factory`` provider takes various number of positional arguments, that define -what kind of dependency injections need to be done. - -All of those instructions are defined in ``dependency_injector.injections`` -module and are subclasses of ``dependency_injector.injections.Injection``. -There are several types of injections that are used by ``Factory`` provider: - -+ ``KwArg`` - injection is done by passing injectable value in object's - ``__init__()`` method in time of object's creation via keyword argument. - Takes keyword name of ``__init__()`` argument and injectable value. -+ ``Attribute`` - injection is done by setting specified attribute with - injectable value right after object's creation. Takes attribute's name - and injectable value. -+ ``Method`` - injection is done by calling of specified method with - injectable value right after object's creation and attribute injections - are done. Takes method name and injectable value. - -All ``Injection``'s injectable values are provided *"as is"*, except of -providers. Providers will be called every time, when injection needs to be -done. - - Factory providers and __init__ injections ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -Example below shows how to create ``Factory`` of particular class with -``__init__`` keyword argument injections which injectable values are also -provided by another factories: +``di.Factory`` takes a various number of keyword arguments that are +transformed into keyword argument injections. Every time, when ``di.Factory`` +creates new one instance, keyword argument injections would be passed as an +instance's keyword arguments. + +All injectable values are provided *"as is"*, except of providers (subclasses +of ``di.Provider``). Providers will be called every time, when injection needs +to be done. For example, if injectable value of keyword argument injection is a +``di.Factory``, it will provide new one instance (as a result of its call) as +an injectable value every time, when injection needs to be done. + +Example below is a little bit more complicated. It shows how to create +``di.Factory`` of particular class with ``__init__`` keyword argument +injections which injectable values are also provided by another factories: + +.. note:: + + Current keyword argument injections syntax (in an example below) is a + **simplified one**. Full syntax and other types of injections could be + found in sections below. + + While keyword argument injections may be the best way of passing + injections, current simplified syntax might be the preferable one and + could be widely used. .. image:: /images/providers/factory_init_injections.png :width: 90% @@ -56,11 +47,14 @@ provided by another factories: .. literalinclude:: ../../examples/providers/factory_init_injections.py :language: python -Next example shows how ``Factory`` provider deals with positional and keyword -``__init__`` context arguments. In few words, ``Factory`` provider fully -passes positional context arguments to class's ``__init__`` method, but -keyword context arguments have priority on ``KwArg`` injections (this could be -useful for testing). +Factory providers and __init__ injections priority +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Next example shows how ``di.Factory`` provider deals with positional and +keyword ``__init__`` context arguments. In few words, ``di.Factory`` +provider fully passes positional context arguments to class's ``__init__`` +method, but keyword context arguments have priority on predefined keyword +argument injections. So, please, follow the example below: @@ -69,6 +63,35 @@ So, please, follow the example below: .. literalinclude:: ../../examples/providers/factory_init_injections_and_contexts.py :language: python + +Factory providers and other types of injections +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Objects can take dependencies in different forms(some objects take init +arguments, other use attributes setting or method calls). It affects how +such objects are created and initialized. + +``di.Factory`` provider takes various number of positional and keyword +arguments, that define what kinds of dependency injections have to be used. + +All of those instructions are defined in ``di.injections`` module and are +subclasses of ``di.injections.Injection`` (shortcut ``di.Injection``). There +are several types of injections that are used by ``di.Factory`` provider: + ++ ``di.KwArg`` - injection is done by passing injectable value in object's + ``__init__()`` method in time of object's creation via keyword argument. + Takes keyword name of ``__init__()`` argument and injectable value. ++ ``di.Attribute`` - injection is done by setting specified attribute with + injectable value right after object's creation. Takes attribute's name + and injectable value. ++ ``di.Method`` - injection is done by calling of specified method with + injectable value right after object's creation and attribute injections + are done. Takes method name and injectable value. + +All ``di.Injection``'s injectable values are provided *"as is"*, except of +providers (subclasses of ``di.Provider``). Providers will be called every time, +when injection needs to be done. + Factory providers and attribute injections ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ diff --git a/examples/providers/factory_init_injections.py b/examples/providers/factory_init_injections.py index adef160e..cc45751e 100644 --- a/examples/providers/factory_init_injections.py +++ b/examples/providers/factory_init_injections.py @@ -1,7 +1,6 @@ -"""`Factory` providers with init injections example.""" +"""`di.Factory` providers with init injections example.""" -from dependency_injector.providers import Factory -from dependency_injector.injections import KwArg +import dependency_injector as di class User(object): @@ -19,9 +18,9 @@ class Photo(object): """Example class Photo.""" # User and Photo factories: -photos_factory = Factory(Photo) -users_factory = Factory(User, - KwArg('main_photo', photos_factory)) +photos_factory = di.Factory(Photo) +users_factory = di.Factory(User, + main_photo=photos_factory) # Creating several User objects: user1 = users_factory() # Same as: user1 = User(main_photo=Photo()) diff --git a/examples/providers/factory_init_injections_and_contexts.py b/examples/providers/factory_init_injections_and_contexts.py index 9058d5b0..da82d0b3 100644 --- a/examples/providers/factory_init_injections_and_contexts.py +++ b/examples/providers/factory_init_injections_and_contexts.py @@ -1,7 +1,6 @@ -"""`Factory` providers with init injections and context arguments example.""" +"""`di.Factory` providers with init injections priority example.""" -from dependency_injector.providers import Factory -from dependency_injector.injections import KwArg +import dependency_injector as di class User(object): @@ -34,11 +33,11 @@ class CreditCard(object): """Example class CreditCard.""" # User, Photo and CreditCard factories: -credit_cards_factory = Factory(CreditCard) -photos_factory = Factory(Photo) -users_factory = Factory(User, - KwArg('main_photo', photos_factory), - KwArg('credit_card', credit_cards_factory)) +credit_cards_factory = di.Factory(CreditCard) +photos_factory = di.Factory(Photo) +users_factory = di.Factory(User, + main_photo=photos_factory, + credit_card=credit_cards_factory) # Creating several User objects: user1 = users_factory(1) @@ -62,7 +61,7 @@ assert isinstance(user2.credit_card, CreditCard) assert user1.main_photo is not user2.main_photo assert user1.credit_card is not user2.credit_card -# Context keyword arguments have priority on KwArg injections priority: +# Context keyword arguments have priority on keyword argument injections: main_photo_mock = Photo() credit_card_mock = CreditCard()