Spaces:
Running
on
CPU Upgrade
Running
on
CPU Upgrade
"""See `tests/openai_timestamp_granularities_test.py` to understand how OpenAI handles `response_type` and `timestamp_granularities`.""" # noqa: E501 | |
from pathlib import Path | |
from openai import AsyncOpenAI | |
import pytest | |
from speaches.api_types import TIMESTAMP_GRANULARITIES_COMBINATIONS, TimestampGranularities | |
async def test_api_json_response_format_and_timestamp_granularities_combinations( | |
openai_client: AsyncOpenAI, | |
timestamp_granularities: TimestampGranularities, | |
) -> None: | |
file_path = Path("audio.wav") | |
await openai_client.audio.transcriptions.create( | |
file=file_path, model="whisper-1", response_format="json", timestamp_granularities=timestamp_granularities | |
) | |
async def test_api_verbose_json_response_format_and_timestamp_granularities_combinations( | |
openai_client: AsyncOpenAI, | |
timestamp_granularities: TimestampGranularities, | |
) -> None: | |
file_path = Path("audio.wav") | |
transcription = await openai_client.audio.transcriptions.create( | |
file=file_path, | |
model="whisper-1", | |
response_format="verbose_json", | |
timestamp_granularities=timestamp_granularities, | |
) | |
assert transcription.__pydantic_extra__ | |
if "word" in timestamp_granularities: | |
assert transcription.__pydantic_extra__.get("segments") is not None | |
assert transcription.__pydantic_extra__.get("words") is not None | |
else: | |
# Unless explicitly requested, words are not present | |
assert transcription.__pydantic_extra__.get("segments") is not None | |
assert transcription.__pydantic_extra__.get("words") is None | |