import pytest from unittest.mock import patch from swarms.memory.pg import PgVectorVectorStore from dotenv import load_dotenv import os load_dotenv() PSG_CONNECTION_STRING = os.getenv("PSG_CONNECTION_STRING") def test_init(): with patch("sqlalchemy.create_engine") as MockEngine: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) MockEngine.assert_called_once() assert store.engine == MockEngine.return_value def test_init_exception(): with pytest.raises(ValueError): PgVectorVectorStore( connection_string=( "mysql://root:password@localhost:3306/test" ), table_name="test", ) def test_setup(): with patch("sqlalchemy.create_engine") as MockEngine: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) store.setup() MockEngine.execute.assert_called() def test_upsert_vector(): with patch("sqlalchemy.create_engine"), patch( "sqlalchemy.orm.Session" ) as MockSession: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) store.upsert_vector( [1.0, 2.0, 3.0], "test_id", "test_namespace", {"meta": "data"}, ) MockSession.assert_called() MockSession.return_value.merge.assert_called() MockSession.return_value.commit.assert_called() def test_load_entry(): with patch("sqlalchemy.create_engine"), patch( "sqlalchemy.orm.Session" ) as MockSession: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) store.load_entry("test_id", "test_namespace") MockSession.assert_called() MockSession.return_value.get.assert_called() def test_load_entries(): with patch("sqlalchemy.create_engine"), patch( "sqlalchemy.orm.Session" ) as MockSession: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) store.load_entries("test_namespace") MockSession.assert_called() MockSession.return_value.query.assert_called() MockSession.return_value.query.return_value.filter_by.assert_called() MockSession.return_value.query.return_value.all.assert_called() def test_query(): with patch("sqlalchemy.create_engine"), patch( "sqlalchemy.orm.Session" ) as MockSession: store = PgVectorVectorStore( connection_string=PSG_CONNECTION_STRING, table_name="test", ) store.query("test_query", 10, "test_namespace") MockSession.assert_called() MockSession.return_value.query.assert_called() MockSession.return_value.query.return_value.filter_by.assert_called() MockSession.return_value.query.return_value.limit.assert_called() MockSession.return_value.query.return_value.all.assert_called()