адрес уже используется в клиентских тестах 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>
а теперь перезапустите свою службу. Я не уверен в асинхронных тестах.