[Feature] Add support for deploying local pipelines to Embedchain platform (#847)
This commit is contained in:
16
tests/conftest.py
Normal file
16
tests/conftest.py
Normal file
@@ -0,0 +1,16 @@
|
||||
import os
|
||||
|
||||
import pytest
|
||||
|
||||
|
||||
def clean_db():
|
||||
db_path = os.path.expanduser("~/.embedchain/embedchain.db")
|
||||
if os.path.exists(db_path):
|
||||
os.remove(db_path)
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def setup():
|
||||
clean_db()
|
||||
yield
|
||||
clean_db()
|
||||
@@ -16,19 +16,20 @@ def app(mocker):
|
||||
|
||||
|
||||
def test_add(app):
|
||||
app.add("https://example.com", metadata={"meta": "meta-data"})
|
||||
assert app.user_asks == [["https://example.com", "web_page", {"meta": "meta-data"}]]
|
||||
app.add("https://example.com", metadata={"foo": "bar"})
|
||||
assert app.user_asks == [["https://example.com", "web_page", {"foo": "bar"}]]
|
||||
|
||||
|
||||
def test_add_sitemap(app):
|
||||
app.add("https://www.google.com/sitemap.xml", metadata={"meta": "meta-data"})
|
||||
assert app.user_asks == [["https://www.google.com/sitemap.xml", "sitemap", {"meta": "meta-data"}]]
|
||||
# TODO: Make this test faster by generating a sitemap locally rather than using a remote one
|
||||
# def test_add_sitemap(app):
|
||||
# app.add("https://www.google.com/sitemap.xml", metadata={"foo": "bar"})
|
||||
# assert app.user_asks == [["https://www.google.com/sitemap.xml", "sitemap", {"foo": "bar"}]]
|
||||
|
||||
|
||||
def test_add_forced_type(app):
|
||||
data_type = "text"
|
||||
app.add("https://example.com", data_type=data_type, metadata={"meta": "meta-data"})
|
||||
assert app.user_asks == [["https://example.com", data_type, {"meta": "meta-data"}]]
|
||||
app.add("https://example.com", data_type=data_type, metadata={"foo": "bar"})
|
||||
assert app.user_asks == [["https://example.com", data_type, {"foo": "bar"}]]
|
||||
|
||||
|
||||
def test_dry_run(app):
|
||||
|
||||
53
tests/test_client.py
Normal file
53
tests/test_client.py
Normal file
@@ -0,0 +1,53 @@
|
||||
import pytest
|
||||
|
||||
from embedchain import Client
|
||||
|
||||
|
||||
class TestClient:
|
||||
@pytest.fixture
|
||||
def mock_requests_post(self, mocker):
|
||||
return mocker.patch("embedchain.client.requests.post")
|
||||
|
||||
def test_valid_api_key(self, mock_requests_post):
|
||||
mock_requests_post.return_value.status_code = 200
|
||||
client = Client(api_key="valid_api_key")
|
||||
assert client.check("valid_api_key") is True
|
||||
|
||||
def test_invalid_api_key(self, mock_requests_post):
|
||||
mock_requests_post.return_value.status_code = 401
|
||||
with pytest.raises(ValueError):
|
||||
Client(api_key="invalid_api_key")
|
||||
|
||||
def test_update_valid_api_key(self, mock_requests_post):
|
||||
mock_requests_post.return_value.status_code = 200
|
||||
client = Client(api_key="valid_api_key")
|
||||
client.update("new_valid_api_key")
|
||||
assert client.get() == "new_valid_api_key"
|
||||
|
||||
def test_clear_api_key(self, mock_requests_post):
|
||||
mock_requests_post.return_value.status_code = 200
|
||||
client = Client(api_key="valid_api_key")
|
||||
client.clear()
|
||||
assert client.get() is None
|
||||
|
||||
def test_save_api_key(self, mock_requests_post):
|
||||
mock_requests_post.return_value.status_code = 200
|
||||
api_key_to_save = "valid_api_key"
|
||||
client = Client(api_key=api_key_to_save)
|
||||
client.save()
|
||||
assert client.get() == api_key_to_save
|
||||
|
||||
def test_load_api_key_from_config(self, mocker):
|
||||
mocker.patch("embedchain.Client.load_config", return_value={"api_key": "test_api_key"})
|
||||
client = Client()
|
||||
assert client.get() == "test_api_key"
|
||||
|
||||
def test_load_invalid_api_key_from_config(self, mocker):
|
||||
mocker.patch("embedchain.Client.load_config", return_value={})
|
||||
with pytest.raises(ValueError):
|
||||
Client()
|
||||
|
||||
def test_load_missing_api_key_from_config(self, mocker):
|
||||
mocker.patch("embedchain.Client.load_config", return_value={})
|
||||
with pytest.raises(ValueError):
|
||||
Client()
|
||||
@@ -1,9 +1,10 @@
|
||||
import os
|
||||
import shutil
|
||||
import pytest
|
||||
from unittest.mock import patch
|
||||
|
||||
import pytest
|
||||
from chromadb.config import Settings
|
||||
|
||||
from embedchain import App
|
||||
from embedchain.config import AppConfig, ChromaDbConfig
|
||||
from embedchain.vectordb.chroma import ChromaDB
|
||||
|
||||
Reference in New Issue
Block a user