Fixed #34098 -- Fixed loss of precision for Decimal values in floatformat filter.

Regression in 12f7928f5a.
This commit is contained in:
Vlastimil Zíma 2022-10-24 12:59:34 +02:00 committed by GitHub
parent 1d6948096f
commit 08c5a78726
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 5 additions and 1 deletions

View File

@ -151,7 +151,7 @@ def floatformat(text, arg=-1):
use_l10n = False
arg = arg[:-1] or -1
try:
input_val = repr(text)
input_val = str(text)
d = Decimal(input_val)
except InvalidOperation:
try:

View File

@ -56,6 +56,10 @@ class FunctionTests(SimpleTestCase):
self.assertEqual(floatformat(0.12345, 2), "0.12")
self.assertEqual(floatformat(Decimal("555.555"), 2), "555.56")
self.assertEqual(floatformat(Decimal("09.000")), "9")
self.assertEqual(
floatformat(Decimal("123456.123456789012345678901"), 21),
"123456.123456789012345678901",
)
self.assertEqual(floatformat("foo"), "")
self.assertEqual(floatformat(13.1031, "bar"), "13.1031")
self.assertEqual(floatformat(18.125, 2), "18.13")