nikhil_staging / src /signals /splitters /chunk_splitter_test.py
nsthorat's picture
Push
e4f9cbe
raw
history blame
No virus
1.55 kB
"""Tests the chunk splitter."""
from .chunk_splitter import ChunkSplitter
from .text_splitter_test_utils import spans_to_text, text_to_expected_spans
def test_paragraphs_no_overlap() -> None:
signal = ChunkSplitter(chunk_size=12, chunk_overlap=0)
text = 'Hello.\n\nThis will get split.\n\nThe sentence\n\nA.\n\nB.\n\nC.'
split_items = list(signal.compute([text]))
# "This will get split" should split in 2 chunks, and "A.\n\nB.\n\nC." should be 1 chunk.
expected_spans = text_to_expected_spans(
text, ['Hello.', 'This will', 'get split.', 'The sentence', 'A.\n\nB.\n\nC.'])
assert split_items == [expected_spans]
def test_single_world_is_too_long_no_overlap() -> None:
signal = ChunkSplitter(chunk_size=6, chunk_overlap=0)
text = 'ThisIsASingleWordThatIsTooLong'
split_items = list(signal.compute([text]))
expected_spans = text_to_expected_spans(text, ['ThisIs', 'ASingl', 'eWordT', 'hatIsT', 'ooLong'])
assert split_items == [expected_spans]
def test_newlines_with_overlap() -> None:
signal = ChunkSplitter(chunk_size=12, chunk_overlap=5)
text = 'Hello.\n\nWorld.\n\nThis will get split.'
spans = list(signal.compute([text]))[0]
expected_chunks = ['Hello.', 'World.', 'This will', 'will get', 'get split.']
assert spans_to_text(text, spans) == expected_chunks
def test_serialization() -> None:
signal = ChunkSplitter(chunk_size=12, chunk_overlap=5)
assert signal.dict() == {
'signal_name': 'chunk',
'chunk_size': 12,
'chunk_overlap': 5,
'separators': ['\n\n', '\n', ' ', '']
}