test_db.py 965 B

123456789101112131415161718192021222324252627
  1. from __future__ import annotations
  2. import unittest
  3. from unittest.mock import patch
  4. from data_collector_mcp import db
  5. class DatabaseTests(unittest.TestCase):
  6. def test_database_url_requires_value(self) -> None:
  7. with patch.dict("os.environ", {}, clear=True):
  8. with self.assertRaisesRegex(ValueError, "DATABASE_URL is required"):
  9. db.database_url()
  10. def test_database_url_rejects_sqlite(self) -> None:
  11. with patch.dict("os.environ", {"DATABASE_URL": "sqlite:///test.db"}, clear=True):
  12. with self.assertRaisesRegex(ValueError, "SQLite is not supported"):
  13. db.database_url()
  14. def test_database_url_accepts_postgres(self) -> None:
  15. url = "postgresql+psycopg2://user:pass@localhost:5432/data-collector-mcp"
  16. with patch.dict("os.environ", {"DATABASE_URL": url}, clear=True):
  17. self.assertEqual(db.database_url(), url)
  18. if __name__ == "__main__":
  19. unittest.main()