1. from django.db import connection
    
  2. from django.db.models import CharField
    
  3. from django.db.models.functions import SHA256
    
  4. from django.test import TestCase
    
  5. from django.test.utils import register_lookup
    
  6. 
    
  7. from ..models import Author
    
  8. 
    
  9. 
    
  10. class SHA256Tests(TestCase):
    
  11.     @classmethod
    
  12.     def setUpTestData(cls):
    
  13.         Author.objects.bulk_create(
    
  14.             [
    
  15.                 Author(alias="John Smith"),
    
  16.                 Author(alias="Jordan Élena"),
    
  17.                 Author(alias="皇帝"),
    
  18.                 Author(alias=""),
    
  19.                 Author(alias=None),
    
  20.             ]
    
  21.         )
    
  22. 
    
  23.     def test_basic(self):
    
  24.         authors = (
    
  25.             Author.objects.annotate(
    
  26.                 sha256_alias=SHA256("alias"),
    
  27.             )
    
  28.             .values_list("sha256_alias", flat=True)
    
  29.             .order_by("pk")
    
  30.         )
    
  31.         self.assertSequenceEqual(
    
  32.             authors,
    
  33.             [
    
  34.                 "ef61a579c907bbed674c0dbcbcf7f7af8f851538eef7b8e58c5bee0b8cfdac4a",
    
  35.                 "6e4cce20cd83fc7c202f21a8b2452a68509cf24d1c272a045b5e0cfc43f0d94e",
    
  36.                 "3ad2039e3ec0c88973ae1c0fce5a3dbafdd5a1627da0a92312c54ebfcf43988e",
    
  37.                 "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
    
  38.                 "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"
    
  39.                 if connection.features.interprets_empty_strings_as_nulls
    
  40.                 else None,
    
  41.             ],
    
  42.         )
    
  43. 
    
  44.     def test_transform(self):
    
  45.         with register_lookup(CharField, SHA256):
    
  46.             authors = Author.objects.filter(
    
  47.                 alias__sha256=(
    
  48.                     "ef61a579c907bbed674c0dbcbcf7f7af8f851538eef7b8e58c5bee0b8cfdac4a"
    
  49.                 ),
    
  50.             ).values_list("alias", flat=True)
    
  51.             self.assertSequenceEqual(authors, ["John Smith"])