From a11c9762132021770b6d6763b68169801a281e86 Mon Sep 17 00:00:00 2001 From: Roman Mogylatov Date: Sun, 17 Oct 2021 21:22:04 -0400 Subject: [PATCH] Migrate injection tests --- tests/unit/providers/injections/__init__.py | 1 + .../injections/test_named_py2_py3.py | 55 ++++++++++ .../injections/test_positional_py2_py3.py | 51 +++++++++ .../unit/providers/test_injections_py2_py3.py | 101 ------------------ 4 files changed, 107 insertions(+), 101 deletions(-) create mode 100644 tests/unit/providers/injections/__init__.py create mode 100644 tests/unit/providers/injections/test_named_py2_py3.py create mode 100644 tests/unit/providers/injections/test_positional_py2_py3.py delete mode 100644 tests/unit/providers/test_injections_py2_py3.py diff --git a/tests/unit/providers/injections/__init__.py b/tests/unit/providers/injections/__init__.py new file mode 100644 index 00000000..9de62e7f --- /dev/null +++ b/tests/unit/providers/injections/__init__.py @@ -0,0 +1 @@ +"""Tests for injection objects.""" diff --git a/tests/unit/providers/injections/test_named_py2_py3.py b/tests/unit/providers/injections/test_named_py2_py3.py new file mode 100644 index 00000000..7d88db93 --- /dev/null +++ b/tests/unit/providers/injections/test_named_py2_py3.py @@ -0,0 +1,55 @@ +"""Named injection tests.""" + +from dependency_injector import providers + + +def test_isinstance(): + injection = providers.NamedInjection("name", 1) + assert isinstance(injection, providers.Injection) + + +def test_get_name(): + injection = providers.NamedInjection("name", 123) + assert injection.get_name() == "name" + + +def test_get_value_with_not_provider(): + injection = providers.NamedInjection("name", 123) + assert injection.get_value() == 123 + + +def test_get_value_with_factory(): + injection = providers.NamedInjection("name", providers.Factory(object)) + + obj1 = injection.get_value() + obj2 = injection.get_value() + + assert type(obj1) is object + assert type(obj2) is object + assert obj1 is not obj2 + + +def test_get_original_value(): + provider = providers.Factory(object) + injection = providers.NamedInjection("name", provider) + assert injection.get_original_value() is provider + + +def test_deepcopy(): + provider = providers.Factory(object) + injection = providers.NamedInjection("name", provider) + + injection_copy = providers.deepcopy(injection) + + assert injection_copy is not injection + assert injection_copy.get_original_value() is not injection.get_original_value() + +def test_deepcopy_memo(): + provider = providers.Factory(object) + injection = providers.NamedInjection("name", provider) + injection_copy_orig = providers.NamedInjection("name", provider) + + injection_copy = providers.deepcopy(injection, {id(injection): injection_copy_orig}) + + assert injection_copy is injection_copy_orig + assert injection_copy.get_original_value() is injection.get_original_value() diff --git a/tests/unit/providers/injections/test_positional_py2_py3.py b/tests/unit/providers/injections/test_positional_py2_py3.py new file mode 100644 index 00000000..9cf41464 --- /dev/null +++ b/tests/unit/providers/injections/test_positional_py2_py3.py @@ -0,0 +1,51 @@ +"""Positional injection tests.""" + +from dependency_injector import providers + + +def test_isinstance(): + injection = providers.PositionalInjection(1) + assert isinstance(injection, providers.Injection) + + +def test_get_value_with_not_provider(): + injection = providers.PositionalInjection(123) + assert injection.get_value() == 123 + + +def test_get_value_with_factory(): + injection = providers.PositionalInjection(providers.Factory(object)) + + obj1 = injection.get_value() + obj2 = injection.get_value() + + assert type(obj1) is object + assert type(obj2) is object + assert obj1 is not obj2 + + +def test_get_original_value(): + provider = providers.Factory(object) + injection = providers.PositionalInjection(provider) + assert injection.get_original_value() is provider + + +def test_deepcopy(): + provider = providers.Factory(object) + injection = providers.PositionalInjection(provider) + + injection_copy = providers.deepcopy(injection) + + assert injection_copy is not injection + assert injection_copy.get_original_value() is not injection.get_original_value() + + +def test_deepcopy_memo(): + provider = providers.Factory(object) + injection = providers.PositionalInjection(provider) + injection_copy_orig = providers.PositionalInjection(provider) + + injection_copy = providers.deepcopy(injection, {id(injection): injection_copy_orig}) + + assert injection_copy is injection_copy_orig + assert injection_copy.get_original_value() is injection.get_original_value() diff --git a/tests/unit/providers/test_injections_py2_py3.py b/tests/unit/providers/test_injections_py2_py3.py deleted file mode 100644 index 4d9042a9..00000000 --- a/tests/unit/providers/test_injections_py2_py3.py +++ /dev/null @@ -1,101 +0,0 @@ -"""Dependency injector injections unit tests.""" - -import unittest - -from dependency_injector import providers - - -class PositionalInjectionTests(unittest.TestCase): - - def test_isinstance(self): - injection = providers.PositionalInjection(1) - assert isinstance(injection, providers.Injection) - - def test_get_value_with_not_provider(self): - injection = providers.PositionalInjection(123) - assert injection.get_value() == 123 - - def test_get_value_with_factory(self): - injection = providers.PositionalInjection(providers.Factory(object)) - - obj1 = injection.get_value() - obj2 = injection.get_value() - - assert type(obj1) is object - assert type(obj2) is object - assert obj1 is not obj2 - - def test_get_original_value(self): - provider = providers.Factory(object) - injection = providers.PositionalInjection(provider) - assert injection.get_original_value() is provider - - def test_deepcopy(self): - provider = providers.Factory(object) - injection = providers.PositionalInjection(provider) - - injection_copy = providers.deepcopy(injection) - - assert injection_copy is not injection - assert injection_copy.get_original_value() is not injection.get_original_value() - - def test_deepcopy_memo(self): - provider = providers.Factory(object) - injection = providers.PositionalInjection(provider) - injection_copy_orig = providers.PositionalInjection(provider) - - injection_copy = providers.deepcopy( - injection, {id(injection): injection_copy_orig}) - - assert injection_copy is injection_copy_orig - assert injection_copy.get_original_value() is injection.get_original_value() - - -class NamedInjectionTests(unittest.TestCase): - - def test_isinstance(self): - injection = providers.NamedInjection("name", 1) - assert isinstance(injection, providers.Injection) - - def test_get_name(self): - injection = providers.NamedInjection("name", 123) - assert injection.get_name() == "name" - - def test_get_value_with_not_provider(self): - injection = providers.NamedInjection("name", 123) - assert injection.get_value() == 123 - - def test_get_value_with_factory(self): - injection = providers.NamedInjection("name", providers.Factory(object)) - - obj1 = injection.get_value() - obj2 = injection.get_value() - - assert type(obj1) is object - assert type(obj2) is object - assert obj1 is not obj2 - - def test_get_original_value(self): - provider = providers.Factory(object) - injection = providers.NamedInjection("name", provider) - assert injection.get_original_value() is provider - - def test_deepcopy(self): - provider = providers.Factory(object) - injection = providers.NamedInjection("name", provider) - - injection_copy = providers.deepcopy(injection) - - assert injection_copy is not injection - assert injection_copy.get_original_value() is not injection.get_original_value() - - def test_deepcopy_memo(self): - provider = providers.Factory(object) - injection = providers.NamedInjection("name", provider) - injection_copy_orig = providers.NamedInjection("name", provider) - - injection_copy = providers.deepcopy( - injection, {id(injection): injection_copy_orig}) - - assert injection_copy is injection_copy_orig - assert injection_copy.get_original_value() is injection.get_original_value()