Refs #24121 -- Added __repr__() to BaseDatabaseWrapper, JoinPromoter, and SQLCompiler.
This commit is contained in:
parent
5e218cc0b7
commit
6fa2930573
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)",
|
||||||
|
)
|
||||||
|
|
|
@ -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'>"
|
||||||
|
)
|
Loading…
Reference in New Issue