Refs -- Added __repr__() to BaseDatabaseWrapper, JoinPromoter, and SQLCompiler.

This commit is contained in:
Jonny Park 2021-03-26 16:14:09 +09:00 committed by Mariusz Felisiak
parent 5e218cc0b7
commit 6fa2930573
6 changed files with 52 additions and 1 deletions
django/db
backends/base
models/sql
tests

View File

@ -120,6 +120,12 @@ class BaseDatabaseWrapper:
self.ops = self.ops_class(self) self.ops = self.ops_class(self)
self.validation = self.validation_class(self) self.validation = self.validation_class(self)
def __repr__(self):
return (
f'<{self.__class__.__qualname__} '
f'vendor={self.vendor!r} alias={self.alias!r}>'
)
def ensure_timezone(self): def ensure_timezone(self):
""" """
Ensure the connection's timezone is set to `self.timezone_name` and Ensure the connection's timezone is set to `self.timezone_name` and

View File

@ -44,6 +44,13 @@ class SQLCompiler:
self.klass_info = None self.klass_info = None
self._meta_ordering = None self._meta_ordering = None
def __repr__(self):
return (
f'<{self.__class__.__qualname__} '
f'model={self.query.model.__qualname__} '
f'connection={self.connection!r} using={self.using!r}>'
)
def setup_query(self): def setup_query(self):
if all(self.query.alias_refcount[a] == 0 for a in self.query.alias_map): if all(self.query.alias_refcount[a] == 0 for a in self.query.alias_map):
self.query.get_initial_alias() self.query.get_initial_alias()

View File

@ -2393,6 +2393,12 @@ class JoinPromoter:
# inner and/or outer joins. # inner and/or outer joins.
self.votes = Counter() self.votes = Counter()
def __repr__(self):
return (
f'{self.__class__.__qualname__}(connector={self.connector!r}, '
f'num_children={self.num_children!r}, negated={self.negated!r})'
)
def add_votes(self, votes): def add_votes(self, votes):
""" """
Add single vote per item to self.votes. Parameter can be any Add single vote per item to self.votes. Parameter can be any

View File

@ -9,6 +9,13 @@ from ..models import Square
class DatabaseWrapperTests(SimpleTestCase): class DatabaseWrapperTests(SimpleTestCase):
def test_repr(self):
conn = connections[DEFAULT_DB_ALIAS]
self.assertEqual(
repr(conn),
f"<DatabaseWrapper vendor={connection.vendor!r} alias='default'>",
)
def test_initialization_class_attributes(self): def test_initialization_class_attributes(self):
""" """
The "initialization" class attributes like client_class and The "initialization" class attributes like client_class and

View File

@ -6,7 +6,7 @@ from django.db.models.expressions import Col, Func
from django.db.models.fields.related_lookups import RelatedIsNull from django.db.models.fields.related_lookups import RelatedIsNull
from django.db.models.functions import Lower from django.db.models.functions import Lower
from django.db.models.lookups import Exact, GreaterThan, IsNull, LessThan from django.db.models.lookups import Exact, GreaterThan, IsNull, LessThan
from django.db.models.sql.query import Query from django.db.models.sql.query import JoinPromoter, Query
from django.db.models.sql.where import OR from django.db.models.sql.where import OR
from django.test import SimpleTestCase from django.test import SimpleTestCase
from django.test.utils import register_lookup from django.test.utils import register_lookup
@ -150,3 +150,11 @@ class TestQuery(SimpleTestCase):
msg = 'Cannot filter against a non-conditional expression.' msg = 'Cannot filter against a non-conditional expression.'
with self.assertRaisesMessage(TypeError, msg): with self.assertRaisesMessage(TypeError, msg):
query.build_where(Func(output_field=CharField())) query.build_where(Func(output_field=CharField()))
class JoinPromoterTest(SimpleTestCase):
def test_repr(self):
self.assertEqual(
repr(JoinPromoter('AND', 3, True)),
"JoinPromoter(connector='AND', num_children=3, negated=True)",
)

View File

@ -0,0 +1,17 @@
from django.db import DEFAULT_DB_ALIAS, connection
from django.db.models.sql import Query
from django.test import SimpleTestCase
from .models import Item
class SQLCompilerTest(SimpleTestCase):
def test_repr(self):
query = Query(Item)
compiler = query.get_compiler(DEFAULT_DB_ALIAS, connection)
self.assertEqual(
repr(compiler),
f"<SQLCompiler model=Item connection="
f"<DatabaseWrapper vendor={connection.vendor!r} alias='default'> "
f"using='default'>"
)