You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
langchain/libs/community/tests/unit_tests/document_loaders/test_assemblyai.py

49 lines
1.5 KiB
Python

import pytest
from pytest_mock import MockerFixture
from langchain_community.document_loaders import AssemblyAIAudioTranscriptLoader
from langchain_community.document_loaders.assemblyai import TranscriptFormat
@pytest.mark.requires("assemblyai")
def test_initialization() -> None:
loader = AssemblyAIAudioTranscriptLoader(
file_path="./testfile.mp3", api_key="api_key"
)
assert loader.file_path == "./testfile.mp3"
assert loader.transcript_format == TranscriptFormat.TEXT
@pytest.mark.requires("assemblyai")
def test_load(mocker: MockerFixture) -> None:
mocker.patch(
"assemblyai.Transcriber.transcribe",
return_value=mocker.MagicMock(
text="Test transcription text", json_response={"id": "1"}, error=None
),
)
loader = AssemblyAIAudioTranscriptLoader(
file_path="./testfile.mp3", api_key="api_key"
)
docs = loader.load()
assert len(docs) == 1
assert docs[0].page_content == "Test transcription text"
assert docs[0].metadata == {"id": "1"}
@pytest.mark.requires("assemblyai")
def test_transcription_error(mocker: MockerFixture) -> None:
mocker.patch(
"assemblyai.Transcriber.transcribe",
return_value=mocker.MagicMock(error="Test error"),
)
loader = AssemblyAIAudioTranscriptLoader(
file_path="./testfile.mp3", api_key="api_key"
)
expected_error = "Could not transcribe file: Test error"
with pytest.raises(ValueError, match=expected_error):
loader.load()