mirror of
https://github.com/Monadical-SAS/reflector.git
synced 2025-12-20 12:19:06 +00:00
* feat: remove support of sqlite, 100% postgres * fix: more migration and make datetime timezone aware in postgres * fix: change how database is get, and use contextvar to have difference instance between different loops * test: properly use client fixture that handle lifetime/database connection * fix: add missing client fixture parameters to test functions This commit fixes NameError issues where test functions were trying to use the 'client' fixture but didn't have it as a parameter. The changes include: 1. Added 'client' parameter to test functions in: - test_transcripts_audio_download.py (6 functions including fixture) - test_transcripts_speaker.py (3 functions) - test_transcripts_upload.py (1 function) - test_transcripts_rtc_ws.py (2 functions + appserver fixture) 2. Resolved naming conflicts in test_transcripts_rtc_ws.py where both HTTP client and StreamClient were using variable name 'client'. StreamClient instances are now named 'stream_client' to avoid conflicts. 3. Added missing 'from reflector.app import app' import in rtc_ws tests. Background: Previously implemented contextvars solution with get_database() function resolves asyncio event loop conflicts in Celery tasks. The global client fixture was also created to replace manual AsyncClient instances, ensuring proper FastAPI application lifecycle management and database connections during tests. All tests now pass except for 2 pre-existing RTC WebSocket test failures related to asyncpg connection issues unrelated to these fixes. * fix: ensure task are correctly closed * fix: make separate event loop for the live server * fix: make default settings pointing at postgres * build: remove pytest-docker deps out of dev, just tests group
152 lines
5.1 KiB
Python
152 lines
5.1 KiB
Python
import pytest
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_transcript_participants(client):
|
|
response = await client.post("/transcripts", json={"name": "test"})
|
|
assert response.status_code == 200
|
|
assert response.json()["participants"] == []
|
|
|
|
# create a participant
|
|
transcript_id = response.json()["id"]
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants", json={"name": "test"}
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["id"] is not None
|
|
assert response.json()["speaker"] is None
|
|
assert response.json()["name"] == "test"
|
|
|
|
# create another one with a speaker
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test2", "speaker": 1},
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["id"] is not None
|
|
assert response.json()["speaker"] == 1
|
|
assert response.json()["name"] == "test2"
|
|
|
|
# get all participants via transcript
|
|
response = await client.get(f"/transcripts/{transcript_id}")
|
|
assert response.status_code == 200
|
|
assert len(response.json()["participants"]) == 2
|
|
|
|
# get participants via participants endpoint
|
|
response = await client.get(f"/transcripts/{transcript_id}/participants")
|
|
assert response.status_code == 200
|
|
assert len(response.json()) == 2
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_transcript_participants_same_speaker(client):
|
|
response = await client.post("/transcripts", json={"name": "test"})
|
|
assert response.status_code == 200
|
|
assert response.json()["participants"] == []
|
|
transcript_id = response.json()["id"]
|
|
|
|
# create a participant
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test", "speaker": 1},
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["speaker"] == 1
|
|
|
|
# create another one with the same speaker
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test2", "speaker": 1},
|
|
)
|
|
assert response.status_code == 400
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_transcript_participants_update_name(client):
|
|
response = await client.post("/transcripts", json={"name": "test"})
|
|
assert response.status_code == 200
|
|
assert response.json()["participants"] == []
|
|
transcript_id = response.json()["id"]
|
|
|
|
# create a participant
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test", "speaker": 1},
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["speaker"] == 1
|
|
|
|
# update the participant
|
|
participant_id = response.json()["id"]
|
|
response = await client.patch(
|
|
f"/transcripts/{transcript_id}/participants/{participant_id}",
|
|
json={"name": "test2"},
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["name"] == "test2"
|
|
|
|
# verify the participant was updated
|
|
response = await client.get(
|
|
f"/transcripts/{transcript_id}/participants/{participant_id}"
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["name"] == "test2"
|
|
|
|
# verify the participant was updated in transcript
|
|
response = await client.get(f"/transcripts/{transcript_id}")
|
|
assert response.status_code == 200
|
|
assert len(response.json()["participants"]) == 1
|
|
assert response.json()["participants"][0]["name"] == "test2"
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_transcript_participants_update_speaker(client):
|
|
response = await client.post("/transcripts", json={"name": "test"})
|
|
assert response.status_code == 200
|
|
assert response.json()["participants"] == []
|
|
transcript_id = response.json()["id"]
|
|
|
|
# create a participant
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test", "speaker": 1},
|
|
)
|
|
assert response.status_code == 200
|
|
participant1_id = response.json()["id"]
|
|
|
|
# create another participant
|
|
response = await client.post(
|
|
f"/transcripts/{transcript_id}/participants",
|
|
json={"name": "test2", "speaker": 2},
|
|
)
|
|
assert response.status_code == 200
|
|
participant2_id = response.json()["id"]
|
|
|
|
# update the participant, refused as speaker is already taken
|
|
response = await client.patch(
|
|
f"/transcripts/{transcript_id}/participants/{participant2_id}",
|
|
json={"speaker": 1},
|
|
)
|
|
assert response.status_code == 400
|
|
|
|
# delete the participant 1
|
|
response = await client.delete(
|
|
f"/transcripts/{transcript_id}/participants/{participant1_id}"
|
|
)
|
|
assert response.status_code == 200
|
|
|
|
# update the participant 2 again, should be accepted now
|
|
response = await client.patch(
|
|
f"/transcripts/{transcript_id}/participants/{participant2_id}",
|
|
json={"speaker": 1},
|
|
)
|
|
assert response.status_code == 200
|
|
|
|
# ensure participant2 name is still there
|
|
response = await client.get(
|
|
f"/transcripts/{transcript_id}/participants/{participant2_id}"
|
|
)
|
|
assert response.status_code == 200
|
|
assert response.json()["name"] == "test2"
|
|
assert response.json()["speaker"] == 1
|