1. from django.db import connection
    
  2. from django.db.models import CharField
    
  3. from django.db.models.functions import SHA512
    
  4. from django.test import TestCase
    
  5. from django.test.utils import register_lookup
    
  6. 
    
  7. from ..models import Author
    
  8. 
    
  9. 
    
  10. class SHA512Tests(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.                 sha512_alias=SHA512("alias"),
    
  27.             )
    
  28.             .values_list("sha512_alias", flat=True)
    
  29.             .order_by("pk")
    
  30.         )
    
  31.         self.assertSequenceEqual(
    
  32.             authors,
    
  33.             [
    
  34.                 "ed014a19bb67a85f9c8b1d81e04a0e7101725be8627d79d02ca4f3bd803f33cf"
    
  35.                 "3b8fed53e80d2a12c0d0e426824d99d110f0919298a5055efff040a3fc091518",
    
  36.                 "b09c449f3ba49a32ab44754982d4749ac938af293e4af2de28858858080a1611"
    
  37.                 "2b719514b5e48cb6ce54687e843a4b3e69a04cdb2a9dc99c3b99bdee419fa7d0",
    
  38.                 "b554d182e25fb487a3f2b4285bb8672f98956b5369138e681b467d1f079af116"
    
  39.                 "172d88798345a3a7666faf5f35a144c60812d3234dcd35f444624f2faee16857",
    
  40.                 "cf83e1357eefb8bdf1542850d66d8007d620e4050b5715dc83f4a921d36ce9ce"
    
  41.                 "47d0d13c5d85f2b0ff8318d2877eec2f63b931bd47417a81a538327af927da3e",
    
  42.                 "cf83e1357eefb8bdf1542850d66d8007d620e4050b5715dc83f4a921d36ce9ce"
    
  43.                 "47d0d13c5d85f2b0ff8318d2877eec2f63b931bd47417a81a538327af927da3e"
    
  44.                 if connection.features.interprets_empty_strings_as_nulls
    
  45.                 else None,
    
  46.             ],
    
  47.         )
    
  48. 
    
  49.     def test_transform(self):
    
  50.         with register_lookup(CharField, SHA512):
    
  51.             authors = Author.objects.filter(
    
  52.                 alias__sha512=(
    
  53.                     "ed014a19bb67a85f9c8b1d81e04a0e7101725be8627d79d02ca4f3bd8"
    
  54.                     "03f33cf3b8fed53e80d2a12c0d0e426824d99d110f0919298a5055eff"
    
  55.                     "f040a3fc091518"
    
  56.                 ),
    
  57.             ).values_list("alias", flat=True)
    
  58.             self.assertSequenceEqual(authors, ["John Smith"])