1
0
mirror of https://github.com/django/django.git synced 2025-01-22 00:02:15 +00:00
django/tests/db_functions/text/test_upper.py

44 lines
1.4 KiB
Python
Raw Normal View History

2018-08-16 00:45:11 +01:00
from django.db.models import CharField
from django.db.models.functions import Upper
from django.test import TestCase
from django.test.utils import register_lookup
2018-08-16 00:45:11 +01:00
from ..models import Author
class UpperTests(TestCase):
def test_basic(self):
Author.objects.create(name="John Smith", alias="smithj")
Author.objects.create(name="Rhonda")
authors = Author.objects.annotate(upper_name=Upper("name"))
2018-08-16 00:45:11 +01:00
self.assertQuerysetEqual(
authors.order_by("name"),
[
"JOHN SMITH",
"RHONDA",
2018-08-16 00:45:11 +01:00
],
lambda a: a.upper_name,
2018-08-16 00:45:11 +01:00
)
Author.objects.update(name=Upper("name"))
2018-08-16 00:45:11 +01:00
self.assertQuerysetEqual(
authors.order_by("name"),
[
("JOHN SMITH", "JOHN SMITH"),
("RHONDA", "RHONDA"),
2018-08-16 00:45:11 +01:00
],
lambda a: (a.upper_name, a.name),
2018-08-16 00:45:11 +01:00
)
def test_transform(self):
with register_lookup(CharField, Upper):
Author.objects.create(name="John Smith", alias="smithj")
Author.objects.create(name="Rhonda")
authors = Author.objects.filter(name__upper__exact="JOHN SMITH")
2018-08-16 00:45:11 +01:00
self.assertQuerysetEqual(
authors.order_by("name"),
[
"John Smith",
2018-08-16 00:45:11 +01:00
],
lambda a: a.name,
2018-08-16 00:45:11 +01:00
)