2015-06-10 12:00:43 +03:00
|
|
|
Singleton providers
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
``Singleton`` provider creates new instance of specified class on first call
|
|
|
|
and returns same instance on every next call.
|
|
|
|
|
2015-06-24 12:29:58 +03:00
|
|
|
Example:
|
|
|
|
|
2015-07-25 00:51:14 +03:00
|
|
|
.. image:: /images/providers/singleton.png
|
2015-06-26 10:21:23 +03:00
|
|
|
:width: 80%
|
|
|
|
:align: center
|
2015-06-24 12:29:58 +03:00
|
|
|
|
2015-06-10 12:00:43 +03:00
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
"""`Singleton` providers example."""
|
|
|
|
|
|
|
|
from objects.providers import Singleton
|
|
|
|
|
|
|
|
|
|
|
|
class UserService(object):
|
|
|
|
|
|
|
|
"""Example class UserService."""
|
|
|
|
|
|
|
|
# Singleton provider creates new instance of specified class on first call and
|
|
|
|
# returns same instance on every next call.
|
|
|
|
users_service_provider = Singleton(UserService)
|
|
|
|
|
|
|
|
# Retrieving several UserService objects:
|
|
|
|
user_service1 = users_service_provider()
|
|
|
|
user_service2 = users_service_provider()
|
|
|
|
|
|
|
|
# Making some asserts:
|
|
|
|
assert user_service1 is user_service2
|
|
|
|
assert isinstance(user_service1, UserService)
|
|
|
|
assert isinstance(user_service2, UserService)
|
|
|
|
|
|
|
|
Singleton providers and injections
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
``Singleton`` providers use ``Factory`` providers for first creation of
|
|
|
|
specified class instance, so, all of the rules about injections are the same,
|
|
|
|
as for ``Factory`` providers.
|
|
|
|
|
2015-07-25 00:51:14 +03:00
|
|
|
.. image:: /images/providers/singleton_internals.png
|
2015-06-26 10:21:23 +03:00
|
|
|
:width: 80%
|
|
|
|
:align: center
|
2015-06-24 12:29:58 +03:00
|
|
|
|
2015-06-10 12:00:43 +03:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
Due that ``Singleton`` provider creates specified class instance only on
|
|
|
|
the first call, all injections are done once, during the first call, also.
|
|
|
|
Every next call, while instance has been already created and memorized, no
|
|
|
|
injections are done, ``Singleton`` provider just returns memorized earlier
|
|
|
|
instance.
|
|
|
|
|
|
|
|
This may cause some problems, for example, in case of trying to bind
|
|
|
|
``Factory`` provider with ``Singleton`` provider (provided by dependent
|
|
|
|
``Factory`` instance will be injected only once, during the first call).
|
|
|
|
Be aware that such behaviour was made with opened eyes and is not a bug.
|
|
|
|
|
|
|
|
By the way, in such case, ``Delegate`` provider can be useful. It makes
|
|
|
|
possible to inject providers *as is*. Please check out full example in
|
|
|
|
*Providers delegation* section.
|
|
|
|
|
|
|
|
Singleton providers resetting
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Created and memorized by ``Singleton`` instance can be reset. Reset of
|
|
|
|
``Singleton``'s memorized instance is done by clearing reference to it. Further
|
|
|
|
lifecycle of memorized instance is out of ``Singleton`` provider's control.
|
|
|
|
|
2015-06-18 16:35:00 +03:00
|
|
|
Example:
|
|
|
|
|
2015-06-10 12:00:43 +03:00
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
"""`Singleton` providers resetting example."""
|
|
|
|
|
|
|
|
from objects.providers import Singleton
|
|
|
|
|
|
|
|
|
|
|
|
class UserService(object):
|
|
|
|
|
|
|
|
"""Example class UserService."""
|
|
|
|
|
2015-06-18 14:45:26 +03:00
|
|
|
# Users service singleton provider:
|
2015-06-10 12:00:43 +03:00
|
|
|
users_service_provider = Singleton(UserService)
|
|
|
|
|
|
|
|
# Retrieving several UserService objects:
|
|
|
|
user_service1 = users_service_provider()
|
|
|
|
user_service2 = users_service_provider()
|
|
|
|
|
|
|
|
# Making some asserts:
|
|
|
|
assert user_service1 is user_service2
|
|
|
|
assert isinstance(user_service1, UserService)
|
|
|
|
assert isinstance(user_service2, UserService)
|
|
|
|
|
|
|
|
# Resetting of memorized instance:
|
|
|
|
users_service_provider.reset()
|
|
|
|
|
|
|
|
# Retrieving one more UserService object:
|
|
|
|
user_service3 = users_service_provider()
|
|
|
|
|
|
|
|
# Making some asserts:
|
|
|
|
assert user_service3 is not user_service1
|
2015-07-20 19:31:31 +03:00
|
|
|
|
|
|
|
Singleton providers delegation
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
``Singleton`` provider could be delegated to any other provider via any kind of
|
|
|
|
injection. Delegation of ``Singleton`` providers is the same as ``Factory``
|
|
|
|
providers delegation, please follow *Factory providers delegation* section for
|
|
|
|
example.
|
|
|
|
|
|
|
|
``Singleton`` delegate could be created obviously using
|
|
|
|
``Delegate(Singleton())`` or by calling ``Singleton.delegate()`` method.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
"""`Singleton` providers delegation example."""
|
|
|
|
|
|
|
|
from objects.providers import Singleton
|
|
|
|
from objects.providers import Delegate
|
|
|
|
|
|
|
|
|
|
|
|
# Some singleton provider and few delegates of it:
|
|
|
|
singleton_provider = Singleton(object)
|
|
|
|
singleton_provider_delegate1 = singleton_provider.delegate()
|
|
|
|
singleton_provider_delegate2 = Delegate(singleton_provider)
|
|
|
|
|
|
|
|
# Making some asserts:
|
|
|
|
assert singleton_provider_delegate1() is singleton_provider
|
|
|
|
assert singleton_provider_delegate2() is singleton_provider
|