адрес уже используется в клиентских тестах async в python

У меня вопрос об асинхронных клиентских тестах. Вот мой код моего теста

class TestSocketClient:
    @classmethod
    def setup_class(cls):
        # enable parallel testing by adding the pytest worker id number to the default port
        worker_id = os.environ.get("PYTEST_XDIST_WORKER", "gw0")
        worker_number = int(worker_id[2:])

        cls.mock_server = ServerMock()
        cls.mock_server.port = ServerMock.port + worker_number

        cls.username = os.environ.get("USERNAME", "")
        cls.password = os.environ.get("PASSWORD", "")
        cls.socket_client = SocketClient(username=cls.username, password=cls.password)
        cls.socket_client.hostname = "0.0.0.0"
        cls.socket_client.port = SocketClient.port + worker_number

    @pytest.mark.asyncio
    async def test_login(self):
        await self.mock_server.start()
        response = await self.socket_client.login()
        assert response == actual_response
        await self.socket_client.close()

    @pytest.mark.asyncio
    async def test_send_heartbeat(self):
        await self.mock_server.start()
        await self.socket_client.login()
        await self.socket_client.send_heartbeat()
        await self.socket_client.close()

Я могу запустить тесты под TestSocketClientиндивидуально и они пройдут индивидуально. Но когда я запускаю тестовые наборы вместе с pytest -n auto, Последний тестовый пример вызовет error while attempting to bind on address ('0.0.0.0', 2056): address already in use. Мой вопрос заключается в том, как обеспечить прохождение тестовых наборов без решения проблем с распределением, чтобы они могли успешно работать в процессе CI. Я буду очень признателен, если появятся более ценные предложения по написанию асинхронных тестов (например, что я должен утверждать, если я хочу только протестировать запрос, который клиент хотел бы отправить на сервер? Должен ли я утверждать сообщение, полученное на на стороне сервера или просто напишите что-нибудь вроде assert_called_onceна стороне клиента). Заранее спасибо!

Обновления:

Я наконец решил проблему с приращением порта в разных тестах, как показано ниже

class TestSocketClient:
    ports_taken = set()

    @classmethod
    def setup_class(cls):

        cls.mock_server = ServerMock()

        cls.username = os.environ.get("USERNAME", "")
        cls.password = os.environ.get("PASSWORD", "")
        cls.socket_client = SocketClient(username=cls.username, password=cls.password)
        cls.socket_client.hostname = "0.0.0.0"
        cls.socket_client.port = cls.mock_server.port
     
     def bump(self):
        if len(self.ports_taken) == 0:
           self.ports_taken.add(self.mock_server.port)
        new_port = max(self.ports_taken) + 1
        self.mock_server.port = new_port
        self.socket_client.port = new_port
        self.ports_taken.add(self.mock_server.port)
     
     async def start(self):
        self.bump()
        try:
           await self.mock_server.start()
        except:
           self.bump()
           await self.mock_server.start()
     
     @pytest.mark.asyncio
     async def test_login(self):
         await self.start()
         ...

Надеюсь, это может быть полезно!

1 ответ

За address already in use, проверьте текущие запущенные процессы,

ps -ax | grep <your app/app port>

Вы заметите, что процесс уже существует. Пожалуйста. убить этот процесс, используя sudo kill -9 <process_id>

а теперь перезапустите свою службу. Я не уверен в асинхронных тестах.

Другие вопросы по тегам