khoj/src/tests/test_main.py

88 lines
2.5 KiB
Python
Raw Normal View History

2021-08-17 12:27:16 +02:00
# Standard Modules
from pathlib import Path
# External Packages
import pytest
from fastapi.testclient import TestClient
# Internal Packages
from main import app, search_settings, model
2021-08-17 12:27:16 +02:00
from search_type import asymmetric
# Arrange
# ----------------------------------------------------------------------------------------------------
client = TestClient(app)
# Test
# ----------------------------------------------------------------------------------------------------
def test_search_with_invalid_search_type():
# Arrange
user_query = "How to call semantic search from Emacs?"
# Act
response = client.get(f"/search?q={user_query}&t=invalid_search_type")
# Assert
assert response.status_code == 422
def test_search_with_valid_search_type():
# Arrange
for search_type in ["notes", "ledger", "music", "image"]:
# Act
response = client.get(f"/search?q=random&t={search_type}")
# Assert
assert response.status_code == 200
def test_regenerate_with_invalid_search_type():
# Act
response = client.get(f"/regenerate?t=invalid_search_type")
# Assert
assert response.status_code == 422
def test_regenerate_with_valid_search_type():
# Arrange
for search_type in ["notes", "ledger", "music", "image"]:
# Act
response = client.get(f"/regenerate?t={search_type}")
# Assert
assert response.status_code == 200
2021-08-17 12:27:16 +02:00
# ----------------------------------------------------------------------------------------------------
def test_notes_search():
# Arrange
input_files = [Path('tests/data/main_readme.org'), Path('tests/data/interface_emacs_readme.org')]
input_filter = None
compressed_jsonl = Path('tests/data/.test.jsonl.gz')
embeddings = Path('tests/data/.test_embeddings.pt')
2021-08-17 12:27:16 +02:00
# Act
# Regenerate embeddings during asymmetric setup
notes_model = asymmetric.setup(input_files, input_filter, compressed_jsonl, embeddings, regenerate=True, verbose=0)
2021-08-17 12:27:16 +02:00
# Assert
assert len(notes_model.entries) == 10
assert len(notes_model.corpus_embeddings) == 10
# Arrange
model.notes_search = notes_model
search_settings.notes_search_enabled = True
user_query = "How to call semantic search from Emacs?"
# Act
response = client.get(f"/search?q={user_query}&n=1&t=notes")
# Assert
assert response.status_code == 200
# assert actual_data contains "Semantic Search via Emacs"
search_result = response.json()[0]["Entry"]
assert "Semantic Search via Emacs" in search_result