mirror of
				https://github.com/ets-labs/python-dependency-injector.git
				synced 2025-11-04 01:47:36 +03:00 
			
		
		
		
	Add tests and fixes
This commit is contained in:
		
							parent
							
								
									1aadb1a3cb
								
							
						
					
					
						commit
						68732385d9
					
				
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| 
						 | 
					@ -2699,13 +2699,16 @@ cdef class Resource(Provider):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if self.__shutdowner:
 | 
					        if self.__shutdowner:
 | 
				
			||||||
            try:
 | 
					            try:
 | 
				
			||||||
                if iscoroutinefunction(self.__shutdowner):
 | 
					                shutdown = self.__shutdowner(self.__resource)
 | 
				
			||||||
                    loop = asyncio.get_event_loop()
 | 
					 | 
				
			||||||
                    loop.run_until_complete(self.__shutdowner(self.__resource))
 | 
					 | 
				
			||||||
                else:
 | 
					 | 
				
			||||||
                    self.__shutdowner(self.__resource)
 | 
					 | 
				
			||||||
            except StopIteration:
 | 
					            except StopIteration:
 | 
				
			||||||
                pass
 | 
					                pass
 | 
				
			||||||
 | 
					            else:
 | 
				
			||||||
 | 
					                if inspect.isawaitable(shutdown):
 | 
				
			||||||
 | 
					                    loop = asyncio.get_event_loop()
 | 
				
			||||||
 | 
					                    try:
 | 
				
			||||||
 | 
					                        loop.run_until_complete(shutdown)
 | 
				
			||||||
 | 
					                    except StopAsyncIteration:
 | 
				
			||||||
 | 
					                        pass
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.__resource = None
 | 
					        self.__resource = None
 | 
				
			||||||
        self.__initialized = False
 | 
					        self.__initialized = False
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -352,26 +352,31 @@ class AsyncResourceTests(AsyncTestCase):
 | 
				
			||||||
        self.assertEqual(_init.counter, 1)
 | 
					        self.assertEqual(_init.counter, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_async_init_function(self):
 | 
					    def test_async_init_function(self):
 | 
				
			||||||
 | 
					        resource = object()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        async def _init():
 | 
					        async def _init():
 | 
				
			||||||
            _init.counter += 1
 | 
					            _init.counter += 1
 | 
				
			||||||
 | 
					            return resource
 | 
				
			||||||
        _init.counter = 0
 | 
					        _init.counter = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        provider = providers.Resource(_init)
 | 
					        provider = providers.Resource(_init)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        result1 = provider()
 | 
					        result1 = provider()
 | 
				
			||||||
        self.assertIsNone(result1)
 | 
					        self.assertIs(result1, resource)
 | 
				
			||||||
        self.assertEqual(_init.counter, 1)
 | 
					        self.assertEqual(_init.counter, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        result2 = provider()
 | 
					        result2 = provider()
 | 
				
			||||||
        self.assertIsNone(result2)
 | 
					        self.assertIs(result2, resource)
 | 
				
			||||||
        self.assertEqual(_init.counter, 1)
 | 
					        self.assertEqual(_init.counter, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        provider.shutdown()
 | 
					        provider.shutdown()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_async_init_generator(self):
 | 
					    def test_async_init_generator(self):
 | 
				
			||||||
 | 
					        resource = object()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        async def _init():
 | 
					        async def _init():
 | 
				
			||||||
            _init.init_counter += 1
 | 
					            _init.init_counter += 1
 | 
				
			||||||
            yield
 | 
					            yield resource
 | 
				
			||||||
            _init.shutdown_counter += 1
 | 
					            _init.shutdown_counter += 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        _init.init_counter = 0
 | 
					        _init.init_counter = 0
 | 
				
			||||||
| 
						 | 
					@ -380,7 +385,7 @@ class AsyncResourceTests(AsyncTestCase):
 | 
				
			||||||
        provider = providers.Resource(_init)
 | 
					        provider = providers.Resource(_init)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        result1 = provider()
 | 
					        result1 = provider()
 | 
				
			||||||
        self.assertIsNone(result1)
 | 
					        self.assertIs(result1, resource)
 | 
				
			||||||
        self.assertEqual(_init.init_counter, 1)
 | 
					        self.assertEqual(_init.init_counter, 1)
 | 
				
			||||||
        self.assertEqual(_init.shutdown_counter, 0)
 | 
					        self.assertEqual(_init.shutdown_counter, 0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -389,7 +394,7 @@ class AsyncResourceTests(AsyncTestCase):
 | 
				
			||||||
        self.assertEqual(_init.shutdown_counter, 1)
 | 
					        self.assertEqual(_init.shutdown_counter, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        result2 = provider()
 | 
					        result2 = provider()
 | 
				
			||||||
        self.assertIsNone(result2)
 | 
					        self.assertIs(result2, resource)
 | 
				
			||||||
        self.assertEqual(_init.init_counter, 2)
 | 
					        self.assertEqual(_init.init_counter, 2)
 | 
				
			||||||
        self.assertEqual(_init.shutdown_counter, 1)
 | 
					        self.assertEqual(_init.shutdown_counter, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -397,67 +402,33 @@ class AsyncResourceTests(AsyncTestCase):
 | 
				
			||||||
        self.assertEqual(_init.init_counter, 2)
 | 
					        self.assertEqual(_init.init_counter, 2)
 | 
				
			||||||
        self.assertEqual(_init.shutdown_counter, 2)
 | 
					        self.assertEqual(_init.shutdown_counter, 2)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # def test_init_class(self):
 | 
					    def test_async_init_class(self):
 | 
				
			||||||
    #     class TestResource(resources.Resource):
 | 
					        class TestResource(resources.AsyncResource):
 | 
				
			||||||
    #         init_counter = 0
 | 
					            init_counter = 0
 | 
				
			||||||
    #         shutdown_counter = 0
 | 
					            shutdown_counter = 0
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #         def init(self):
 | 
					            async def init(self):
 | 
				
			||||||
    #             self.__class__.init_counter += 1
 | 
					                self.__class__.init_counter += 1
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #         def shutdown(self, _):
 | 
					            async def shutdown(self, _):
 | 
				
			||||||
    #             self.__class__.shutdown_counter += 1
 | 
					                self.__class__.shutdown_counter += 1
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #     provider = providers.Resource(TestResource)
 | 
					        provider = providers.Resource(TestResource)
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #     result1 = provider()
 | 
					        result1 = provider()
 | 
				
			||||||
    #     self.assertIsNone(result1)
 | 
					        self.assertIsNone(result1)
 | 
				
			||||||
    #     self.assertEqual(TestResource.init_counter, 1)
 | 
					        self.assertEqual(TestResource.init_counter, 1)
 | 
				
			||||||
    #     self.assertEqual(TestResource.shutdown_counter, 0)
 | 
					        self.assertEqual(TestResource.shutdown_counter, 0)
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #     provider.shutdown()
 | 
					        provider.shutdown()
 | 
				
			||||||
    #     self.assertEqual(TestResource.init_counter, 1)
 | 
					        self.assertEqual(TestResource.init_counter, 1)
 | 
				
			||||||
    #     self.assertEqual(TestResource.shutdown_counter, 1)
 | 
					        self.assertEqual(TestResource.shutdown_counter, 1)
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #     result2 = provider()
 | 
					        result2 = provider()
 | 
				
			||||||
    #     self.assertIsNone(result2)
 | 
					        self.assertIsNone(result2)
 | 
				
			||||||
    #     self.assertEqual(TestResource.init_counter, 2)
 | 
					        self.assertEqual(TestResource.init_counter, 2)
 | 
				
			||||||
    #     self.assertEqual(TestResource.shutdown_counter, 1)
 | 
					        self.assertEqual(TestResource.shutdown_counter, 1)
 | 
				
			||||||
    #
 | 
					
 | 
				
			||||||
    #     provider.shutdown()
 | 
					        provider.shutdown()
 | 
				
			||||||
    #     self.assertEqual(TestResource.init_counter, 2)
 | 
					        self.assertEqual(TestResource.init_counter, 2)
 | 
				
			||||||
    #     self.assertEqual(TestResource.shutdown_counter, 2)
 | 
					        self.assertEqual(TestResource.shutdown_counter, 2)
 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    # def test_init_not_callable(self):
 | 
					 | 
				
			||||||
    #     provider = providers.Resource(1)
 | 
					 | 
				
			||||||
    #     with self.assertRaises(errors.Error):
 | 
					 | 
				
			||||||
    #         provider.init()
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    # def test_init_and_shutdown(self):
 | 
					 | 
				
			||||||
    #     def _init():
 | 
					 | 
				
			||||||
    #         _init.init_counter += 1
 | 
					 | 
				
			||||||
    #         yield
 | 
					 | 
				
			||||||
    #         _init.shutdown_counter += 1
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     _init.init_counter = 0
 | 
					 | 
				
			||||||
    #     _init.shutdown_counter = 0
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     provider = providers.Resource(_init)
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     result1 = provider.init()
 | 
					 | 
				
			||||||
    #     self.assertIsNone(result1)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.init_counter, 1)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.shutdown_counter, 0)
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     provider.shutdown()
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.init_counter, 1)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.shutdown_counter, 1)
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     result2 = provider.init()
 | 
					 | 
				
			||||||
    #     self.assertIsNone(result2)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.init_counter, 2)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.shutdown_counter, 1)
 | 
					 | 
				
			||||||
    #
 | 
					 | 
				
			||||||
    #     provider.shutdown()
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.init_counter, 2)
 | 
					 | 
				
			||||||
    #     self.assertEqual(_init.shutdown_counter, 2)
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user