Kokoro-FastAPI/api/tests/test_text_processor.py

121 lines
4 KiB
Python
Raw Normal View History

import pytest
2025-02-09 18:32:17 -07:00
from api.src.services.text_processing.text_processor import (
get_sentence_info,
2025-02-09 18:32:17 -07:00
process_text_chunk,
smart_split,
)
2025-02-09 18:32:17 -07:00
def test_process_text_chunk_basic():
"""Test basic text chunk processing."""
text = "Hello world"
tokens = process_text_chunk(text)
assert isinstance(tokens, list)
assert len(tokens) > 0
2025-02-09 18:32:17 -07:00
def test_process_text_chunk_empty():
"""Test processing empty text."""
text = ""
tokens = process_text_chunk(text)
assert isinstance(tokens, list)
assert len(tokens) == 0
2025-02-09 18:32:17 -07:00
def test_process_text_chunk_phonemes():
"""Test processing with skip_phonemize."""
phonemes = "h @ l @U" # Example phoneme sequence
tokens = process_text_chunk(phonemes, skip_phonemize=True)
assert isinstance(tokens, list)
assert len(tokens) > 0
2025-02-09 18:32:17 -07:00
def test_get_sentence_info():
"""Test sentence splitting and info extraction."""
text = "This is sentence one. This is sentence two! What about three?"
results = get_sentence_info(text, {})
2025-02-09 18:32:17 -07:00
assert len(results) == 3
for sentence, tokens, count in results:
assert isinstance(sentence, str)
assert isinstance(tokens, list)
assert isinstance(count, int)
assert count == len(tokens)
assert count > 0
2025-04-04 16:58:07 -06:00
def test_get_sentence_info_phenomoes():
"""Test sentence splitting and info extraction."""
2025-04-04 16:58:07 -06:00
text = (
"This is sentence one. This is </|custom_phonemes_0|/> two! What about three?"
)
results = get_sentence_info(text, {"</|custom_phonemes_0|/>": r"sˈɛntᵊns"})
assert len(results) == 3
# Verify the original sentence text contains the placeholder
assert "</|custom_phonemes_0|/>" in results[1][0]
# Optional: Verify the tokens list is not empty (implies processing happened)
assert len(results[1][1]) > 0
for sentence, tokens, count in results:
assert isinstance(sentence, str)
assert isinstance(tokens, list)
assert isinstance(count, int)
assert count == len(tokens)
# Allow zero tokens for empty/newline-only sentences processed by get_sentence_info
if sentence.strip() and sentence != "\n":
assert count > 0
else:
assert count == 0
2025-02-09 18:32:17 -07:00
2025-04-04 16:58:07 -06:00
@pytest.mark.asyncio
async def test_smart_split_short_text():
"""Test smart splitting with text under max tokens."""
text = "This is a short test sentence."
chunks = []
# Unpack all three values yielded by smart_split
async for chunk_text, chunk_tokens, _ in smart_split(text):
# Append only text and tokens if pause duration is not needed for assert
chunks.append((chunk_text, chunk_tokens))
2025-02-09 18:32:17 -07:00
assert len(chunks) == 1
assert isinstance(chunks[0][0], str)
assert isinstance(chunks[0][1], list)
2025-02-09 18:32:17 -07:00
@pytest.mark.asyncio
async def test_smart_split_long_text():
"""Test smart splitting with longer text."""
# Create text that should split into multiple chunks
text = ". ".join(["This is test sentence number " + str(i) for i in range(20)])
2025-02-09 18:32:17 -07:00
chunks = []
# Unpack all three values yielded by smart_split
async for chunk_text, chunk_tokens, _ in smart_split(text):
# Append only text and tokens if pause duration is not needed for assert
chunks.append((chunk_text, chunk_tokens))
2025-02-09 18:32:17 -07:00
assert len(chunks) > 1
for chunk_text, chunk_tokens in chunks:
assert isinstance(chunk_text, str)
assert isinstance(chunk_tokens, list)
assert len(chunk_tokens) > 0
2025-02-09 18:32:17 -07:00
@pytest.mark.asyncio
async def test_smart_split_with_punctuation():
"""Test smart splitting handles punctuation correctly."""
text = "First sentence! Second sentence? Third sentence; Fourth sentence: Fifth sentence."
2025-02-09 18:32:17 -07:00
chunks = []
# Unpack all three values yielded by smart_split
async for chunk_text, chunk_tokens, _ in smart_split(text):
# Append only text if tokens/pause duration are not needed for assert
chunks.append(chunk_text)
2025-02-09 18:32:17 -07:00
# Verify punctuation is preserved
2025-02-09 18:32:17 -07:00
assert all(any(p in chunk for p in "!?;:.") for chunk in chunks)