mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	[1.0.X] Fixed #5079 -- Avoid converting Decimals to floats during save to the database.
[9394] from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.0.X@9395 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -124,4 +124,9 @@ def format_number(value, max_digits, decimal_places): | ||||
|     Formats a number into a string with the requisite number of digits and | ||||
|     decimal places. | ||||
|     """ | ||||
|     return u"%.*f" % (decimal_places, value) | ||||
|     if isinstance(value, decimal.Decimal): | ||||
|         context = decimal.getcontext().copy() | ||||
|         context.prec = max_digits | ||||
|         return u'%s' % str(value.quantize(decimal.Decimal(".1") ** decimal_places, context=context)) | ||||
|     else: | ||||
|         return u"%.*f" % (decimal_places, value) | ||||
|   | ||||
| @@ -32,6 +32,9 @@ class Whiz(models.Model): | ||||
|         (0,'Other'), | ||||
|     ) | ||||
|     c = models.IntegerField(choices=CHOICES, null=True) | ||||
|      | ||||
| class BigD(models.Model): | ||||
|     d = models.DecimalField(max_digits=38, decimal_places=30) | ||||
|  | ||||
| __test__ = {'API_TESTS':""" | ||||
| # Create a couple of Places. | ||||
| @@ -78,5 +81,11 @@ u'' | ||||
| >>> Foo.objects.filter(d=u'1.23') | ||||
| [] | ||||
|  | ||||
|  | ||||
| # Regression test for #5079 -- ensure decimals don't go through a corrupting | ||||
| # float conversion during save.   | ||||
| >>> bd = BigD(d="12.9") | ||||
| >>> bd.save() | ||||
| >>> bd = BigD.objects.get(pk=bd.pk) | ||||
| >>> bd.d == decimal.Decimal("12.9") | ||||
| True | ||||
| """} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user