Skip to content

Commit

Permalink
Move tests for write_documents from DocumentStoreBaseTests to separat…
Browse files Browse the repository at this point in the history
…e class (#6334)
  • Loading branch information
silvanocerza authored Nov 17, 2023
1 parent 326f51d commit 53b77dd
Showing 1 changed file with 59 additions and 43 deletions.
102 changes: 59 additions & 43 deletions haystack/preview/testing/document_store.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,65 @@ def test_count_not_empty(self, docstore: DocumentStore):
assert docstore.count_documents() == 3


class DocumentStoreBaseTests(CountDocumentsTest):
class WriteDocumentsTest:
"""
Utility class to test a Document Store `write_documents` method.
To use it create a custom test class and override the `docstore` fixture to return your Document Store.
Example usage:
```python
class MyDocumentStoreTest(WriteDocumentsTest):
@pytest.fixture
def docstore(self):
return MyDocumentStore()
```
"""

@pytest.mark.unit
def test_write(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_fail(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
with pytest.raises(DuplicateDocumentError, match=f"ID '{doc.id}' already exists."):
docstore.write_documents(documents=[doc], policy=DuplicatePolicy.FAIL)
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_skip(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
docstore.write_documents(documents=[doc], policy=DuplicatePolicy.SKIP)
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_overwrite(self, docstore: DocumentStore):
doc1 = Document(content="test doc 1")
doc2 = Document(content="test doc 2")
object.__setattr__(doc2, "id", doc1.id) # Make two docs with different content but same ID

docstore.write_documents([doc2])
assert docstore.filter_documents(filters={"id": doc1.id}) == [doc2]
docstore.write_documents(documents=[doc1], policy=DuplicatePolicy.OVERWRITE)
assert docstore.filter_documents(filters={"id": doc1.id}) == [doc1]

@pytest.mark.unit
def test_write_not_docs(self, docstore: DocumentStore):
with pytest.raises(ValueError):
docstore.write_documents(["not a document for sure"]) # type: ignore

@pytest.mark.unit
def test_write_not_list(self, docstore: DocumentStore):
with pytest.raises(ValueError):
docstore.write_documents("not a list actually") # type: ignore


class DocumentStoreBaseTests(CountDocumentsTest, WriteDocumentsTest):
@pytest.fixture
def docstore(self) -> DocumentStore:
raise NotImplementedError()
Expand Down Expand Up @@ -559,48 +617,6 @@ def test_filter_nested_multiple_identical_operators_same_level(
)
]

@pytest.mark.unit
def test_write(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_fail(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
with pytest.raises(DuplicateDocumentError, match=f"ID '{doc.id}' already exists."):
docstore.write_documents(documents=[doc], policy=DuplicatePolicy.FAIL)
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_skip(self, docstore: DocumentStore):
doc = Document(content="test doc")
docstore.write_documents([doc])
docstore.write_documents(documents=[doc], policy=DuplicatePolicy.SKIP)
assert docstore.filter_documents(filters={"id": doc.id}) == [doc]

@pytest.mark.unit
def test_write_duplicate_overwrite(self, docstore: DocumentStore):
doc1 = Document(content="test doc 1")
doc2 = Document(content="test doc 2")
object.__setattr__(doc2, "id", doc1.id) # Make two docs with different content but same ID

docstore.write_documents([doc2])
assert docstore.filter_documents(filters={"id": doc1.id}) == [doc2]
docstore.write_documents(documents=[doc1], policy=DuplicatePolicy.OVERWRITE)
assert docstore.filter_documents(filters={"id": doc1.id}) == [doc1]

@pytest.mark.unit
def test_write_not_docs(self, docstore: DocumentStore):
with pytest.raises(ValueError):
docstore.write_documents(["not a document for sure"]) # type: ignore

@pytest.mark.unit
def test_write_not_list(self, docstore: DocumentStore):
with pytest.raises(ValueError):
docstore.write_documents("not a list actually") # type: ignore

@pytest.mark.unit
def test_delete_empty(self, docstore: DocumentStore):
with pytest.raises(MissingDocumentError):
Expand Down

0 comments on commit 53b77dd

Please sign in to comment.