From 43148acf2cdc01fdc97b1c5b94d7d779e0d38d01 Mon Sep 17 00:00:00 2001 From: Chris Mayo Date: Sun, 24 Nov 2024 17:11:47 +0000 Subject: [PATCH] Test without sqlalchemy-citext The last sqlalchemy-citext update was in 2021 and it has various compatibility issues. SQLAlchemy now has CITEXT support. --- doc/changelog.rst | 1 + flask_admin/tests/sqla/test_postgres.py | 8 ++++++-- pyproject.toml | 1 - tox.ini | 1 + 4 files changed, 8 insertions(+), 3 deletions(-) diff --git a/doc/changelog.rst b/doc/changelog.rst index 26d88a81d..a33548127 100644 --- a/doc/changelog.rst +++ b/doc/changelog.rst @@ -8,6 +8,7 @@ Fixes: * Jinja templates can now be loaded in StrictUndefined mode. * Remove an implicit dependency on `packaging` +* Remove `sqlalchemy-citext1 from the optional dependencies. CITEXT supported by SQLAlchemy since 2.0.19. 2.0.0a2 ------- diff --git a/flask_admin/tests/sqla/test_postgres.py b/flask_admin/tests/sqla/test_postgres.py index a9cbc30c1..e3b76e679 100644 --- a/flask_admin/tests/sqla/test_postgres.py +++ b/flask_admin/tests/sqla/test_postgres.py @@ -1,4 +1,8 @@ -from citext import CIText +try: + from citext import CIText as CITEXT +except ImportError: + # SQLAlchemy >= 2.0.7, although there is an issue until 2.0.19 + from sqlalchemy.dialects.postgresql import CITEXT # type: ignore[attr-defined] from sqlalchemy import text from sqlalchemy.dialects.postgresql import HSTORE from sqlalchemy.dialects.postgresql import JSON @@ -94,7 +98,7 @@ class CITextModel(postgres_db.Model): id = postgres_db.Column( postgres_db.Integer, primary_key=True, autoincrement=True ) - citext_test = postgres_db.Column(CIText) + citext_test = postgres_db.Column(CITEXT) with postgres_db.engine.begin() as connection: connection.execute(text("CREATE EXTENSION IF NOT EXISTS citext")) diff --git a/pyproject.toml b/pyproject.toml index 3a76e0180..26485ffb4 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -36,7 +36,6 @@ sqlalchemy = [ sqlalchemy-with-utils = [ "Flask-Admin[sqlalchemy]", "sqlalchemy_utils>=0.38.0", - "sqlalchemy-citext>=1.8.0", "colour>=0.1.5", "email_validator>=2", "arrow>=0.13.0", diff --git a/tox.ini b/tox.ini index 3dfd6a524..e158bbef4 100644 --- a/tox.ini +++ b/tox.ini @@ -22,6 +22,7 @@ setenv = AZURE_STORAGE_CONNECTION_STRING = DefaultEndpointsProtocol=http;AccountName=devstoreaccount1;AccountKey=Eby8vdM02xNOcqFlqUwJPLlmEtlCDXJ1OUzFT50uSRZ6IFsuFq2UVErCz4I6tq/K1SZFPTOtr/KBHBeksoGMGw==;BlobEndpoint=http://127.0.0.1:10000/devstoreaccount1; deps = sqlalchemy1: sqlalchemy<2 + sqlalchemy1: sqlalchemy-citext -r requirements/tests.txt commands_pre = noflaskbabel: pip uninstall -y flask-babel