From d5ac6e79f1ef9fb0bc4765fa6dd3d734d224ef50 Mon Sep 17 00:00:00 2001 From: Roman Mogylatov Date: Sun, 31 Jan 2021 10:47:05 -0500 Subject: [PATCH] Add ItemGetter provider tests --- tests/unit/providers/test_traversal_py3.py | 29 ++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/tests/unit/providers/test_traversal_py3.py b/tests/unit/providers/test_traversal_py3.py index 0fe06f88..0aac714d 100644 --- a/tests/unit/providers/test_traversal_py3.py +++ b/tests/unit/providers/test_traversal_py3.py @@ -781,3 +781,32 @@ class AttributeGetterTests(unittest.TestCase): self.assertIn(provider1, all_providers) self.assertIn(provider2, all_providers) self.assertIn(provided, all_providers) + + +class ItemGetterTests(unittest.TestCase): + + def test_traverse(self): + provider1 = providers.Provider() + provided = provider1.provided + provider = provided['item'] + + all_providers = list(provider.traverse()) + + self.assertEqual(len(all_providers), 2) + self.assertIn(provider1, all_providers) + self.assertIn(provided, all_providers) + + def test_traverse_overridden(self): + provider1 = providers.Provider() + provided = provider1.provided + provider2 = providers.Provider() + + provider = provided['item'] + provider.override(provider2) + + all_providers = list(provider.traverse()) + + self.assertEqual(len(all_providers), 3) + self.assertIn(provider1, all_providers) + self.assertIn(provider2, all_providers) + self.assertIn(provided, all_providers)