From 16cc5db4f7d259f85ad701cc9f8e7a8aa893a45b Mon Sep 17 00:00:00 2001 From: Mike Fiedler Date: Thu, 2 Jan 2025 14:39:06 -0500 Subject: [PATCH] feat: debugging printer with variable substitution (#17333) --- tests/unit/utils/db/test_query_printer.py | 30 +++++++++++++++++++++ warehouse/utils/db/query_printer.py | 33 +++++++++++++++++++++++ 2 files changed, 63 insertions(+) create mode 100644 tests/unit/utils/db/test_query_printer.py create mode 100644 warehouse/utils/db/query_printer.py diff --git a/tests/unit/utils/db/test_query_printer.py b/tests/unit/utils/db/test_query_printer.py new file mode 100644 index 000000000000..65999e57c606 --- /dev/null +++ b/tests/unit/utils/db/test_query_printer.py @@ -0,0 +1,30 @@ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import logging + +from sqlalchemy import select + +from warehouse.packaging.models import Project +from warehouse.utils.db import query_printer + + +def test_print_query_renders_params(caplog): + caplog.set_level(logging.DEBUG) + + query = select(Project.id, Project.name).where(Project.name == "value") + assert "WHERE projects.name = :name_1" in str(query) + + query_printer.print_query(query) + + assert ":name_1" not in caplog.text + assert "WHERE projects.name = 'value'" in caplog.text diff --git a/warehouse/utils/db/query_printer.py b/warehouse/utils/db/query_printer.py new file mode 100644 index 000000000000..dd61d44cc6b3 --- /dev/null +++ b/warehouse/utils/db/query_printer.py @@ -0,0 +1,33 @@ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +""" Logs the query with the parameters embedded into the query.""" + +import logging + +from sqlalchemy.dialects import postgresql + + +def print_query(query) -> None: + """ + Prints the query with the parameters embedded into the query. + + Useful for development/debugging purposes. + """ + logging.debug( + str( + query.compile( + dialect=postgresql.dialect(), + compile_kwargs={"literal_binds": True}, + ) + ) + )