From 4f316c459d478be2f95f08bc47ae6caa4497d0a3 Mon Sep 17 00:00:00 2001 From: Frank Yu Date: Tue, 25 Jun 2024 00:19:00 +0800 Subject: [PATCH] add sqlalchemy namespace to flask shell --- CHANGES.rst | 2 +- src/flask_sqlalchemy/cli.py | 4 +++- tests/test_cli.py | 1 + 3 files changed, 5 insertions(+), 2 deletions(-) diff --git a/CHANGES.rst b/CHANGES.rst index 7ac59691..1aecb3a7 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -2,7 +2,7 @@ Version 3.1.2 ------------- - Fix issue with calling ``repr()`` on ``SQLAlchemy`` instance with no default engine. :issue:`1295` - +- Adds ``sqlalchemy``` namespace as ``sa``` to ``flask shell```. :pr:`1350` Version 3.1.1 ------------- diff --git a/src/flask_sqlalchemy/cli.py b/src/flask_sqlalchemy/cli.py index d7d7e4be..9f13a280 100644 --- a/src/flask_sqlalchemy/cli.py +++ b/src/flask_sqlalchemy/cli.py @@ -2,15 +2,17 @@ import typing as t +import sqlalchemy as sa from flask import current_app def add_models_to_shell() -> dict[str, t.Any]: """Registered with :meth:`~flask.Flask.shell_context_processor` if ``add_models_to_shell`` is enabled. Adds the ``db`` instance and all model classes - to ``flask shell``. + to ``flask shell``. Adds the ``sqlalchemy`` namespace as ``sa`` to ``flask shell``. """ db = current_app.extensions["sqlalchemy"] out = {m.class_.__name__: m.class_ for m in db.Model._sa_registry.mappers} + out["sa"] = sa out["db"] = db return out diff --git a/tests/test_cli.py b/tests/test_cli.py index 91672733..8d2f16ca 100644 --- a/tests/test_cli.py +++ b/tests/test_cli.py @@ -11,5 +11,6 @@ @pytest.mark.usefixtures("app_ctx") def test_shell_context(db: SQLAlchemy, Todo: t.Any) -> None: context = add_models_to_shell() + assert "sa" in context assert context["db"] is db assert context["Todo"] is Todo