2023-03-03 05:02:15 +00:00
|
|
|
from invokeai.app.services.sqlite import SqliteItemStorage, sqlite_memory
|
2022-12-01 05:33:20 +00:00
|
|
|
from pydantic import BaseModel, Field
|
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
import pytest
|
|
|
|
import sqlite3
|
2022-12-01 05:33:20 +00:00
|
|
|
|
|
|
|
class TestModel(BaseModel):
|
|
|
|
id: str = Field(description="ID")
|
|
|
|
name: str = Field(description="Name")
|
|
|
|
|
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def db() -> SqliteItemStorage[TestModel]:
|
|
|
|
db_conn = sqlite3.connect(sqlite_memory, check_same_thread=False)
|
|
|
|
return SqliteItemStorage[TestModel](db_conn, "test", "id")
|
|
|
|
|
|
|
|
def test_sqlite_service_can_create_and_get(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
assert db.get("1") == TestModel(id="1", name="Test")
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_list(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.list()
|
|
|
|
assert results.page == 0
|
|
|
|
assert results.pages == 1
|
|
|
|
assert results.per_page == 10
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [
|
|
|
|
TestModel(id="1", name="Test"),
|
|
|
|
TestModel(id="2", name="Test"),
|
|
|
|
TestModel(id="3", name="Test"),
|
|
|
|
]
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_delete(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.delete("1")
|
|
|
|
assert db.get("1") is None
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_calls_set_callback(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
called = False
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
def on_changed(item: TestModel):
|
|
|
|
nonlocal called
|
|
|
|
called = True
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
db.on_changed(on_changed)
|
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
assert called
|
|
|
|
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_calls_delete_callback(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
called = False
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
def on_deleted(item_id: str):
|
|
|
|
nonlocal called
|
|
|
|
called = True
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
db.on_deleted(on_deleted)
|
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.delete("1")
|
|
|
|
assert called
|
|
|
|
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_list_with_pagination(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.list(page=0, per_page=2)
|
|
|
|
assert results.page == 0
|
|
|
|
assert results.pages == 2
|
|
|
|
assert results.per_page == 2
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [TestModel(id="1", name="Test"), TestModel(id="2", name="Test")]
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_list_with_pagination_and_offset(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.list(page=1, per_page=2)
|
|
|
|
assert results.page == 1
|
|
|
|
assert results.pages == 2
|
|
|
|
assert results.per_page == 2
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [TestModel(id="3", name="Test")]
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_search(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.search(query="Test")
|
|
|
|
assert results.page == 0
|
|
|
|
assert results.pages == 1
|
|
|
|
assert results.per_page == 10
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [
|
|
|
|
TestModel(id="1", name="Test"),
|
|
|
|
TestModel(id="2", name="Test"),
|
|
|
|
TestModel(id="3", name="Test"),
|
|
|
|
]
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_search_with_pagination(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.search(query="Test", page=0, per_page=2)
|
|
|
|
assert results.page == 0
|
|
|
|
assert results.pages == 2
|
|
|
|
assert results.per_page == 2
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [TestModel(id="1", name="Test"), TestModel(id="2", name="Test")]
|
2023-07-27 14:54:01 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-08-16 18:35:49 +00:00
|
|
|
def test_sqlite_service_can_search_with_pagination_and_offset(db: SqliteItemStorage[TestModel]):
|
2022-12-01 05:33:20 +00:00
|
|
|
db.set(TestModel(id="1", name="Test"))
|
|
|
|
db.set(TestModel(id="2", name="Test"))
|
|
|
|
db.set(TestModel(id="3", name="Test"))
|
|
|
|
results = db.search(query="Test", page=1, per_page=2)
|
|
|
|
assert results.page == 1
|
|
|
|
assert results.pages == 2
|
|
|
|
assert results.per_page == 2
|
|
|
|
assert results.total == 3
|
|
|
|
assert results.items == [TestModel(id="3", name="Test")]
|