Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse code

Fixed #14453 -- Changed handling of microseconds part in typecast_tim…

…estamp() DB backend helper function to be more correct. Thanks philipn for the report and fix.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@14664 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information...
commit 67742073947efe60b103b2ebd07217d2a1c67e9d 1 parent f27e6f0
Ramiro Morales authored November 21, 2010
2  django/db/backends/util.py
@@ -92,7 +92,7 @@ def typecast_timestamp(s): # does NOT store time zone information
92 92
     else:
93 93
         microseconds = '0'
94 94
     return datetime.datetime(int(dates[0]), int(dates[1]), int(dates[2]),
95  
-        int(times[0]), int(times[1]), int(seconds), int(float('.'+microseconds) * 1000000))
  95
+        int(times[0]), int(times[1]), int(seconds), int((microseconds + '000000')[:6]))
96 96
 
97 97
 def typecast_boolean(s):
98 98
     if s is None: return None
8  tests/regressiontests/db_typecasts/tests.py
@@ -35,6 +35,12 @@
35 35
         ('2005-08-11 8:50:30.9', datetime.datetime(2005, 8, 11, 8, 50, 30, 900000)),
36 36
         ('2005-08-11 8:50:30.312-05', datetime.datetime(2005, 8, 11, 8, 50, 30, 312000)),
37 37
         ('2005-08-11 8:50:30.312+02', datetime.datetime(2005, 8, 11, 8, 50, 30, 312000)),
  38
+        # ticket 14453
  39
+        ('2010-10-12 15:29:22.063202', datetime.datetime(2010, 10, 12, 15, 29, 22, 63202)),
  40
+        ('2010-10-12 15:29:22.063202-03', datetime.datetime(2010, 10, 12, 15, 29, 22, 63202)),
  41
+        ('2010-10-12 15:29:22.063202+04', datetime.datetime(2010, 10, 12, 15, 29, 22, 63202)),
  42
+        ('2010-10-12 15:29:22.0632021', datetime.datetime(2010, 10, 12, 15, 29, 22, 63202)),
  43
+        ('2010-10-12 15:29:22.0632029', datetime.datetime(2010, 10, 12, 15, 29, 22, 63202)),
38 44
     ),
39 45
     'typecast_boolean': (
40 46
         (None, None),
@@ -53,4 +59,4 @@ def test_typeCasts(self):
53 59
                 assert got == expected, "In %s: %r doesn't match %r. Got %r instead." % (k, inpt, expected, got)
54 60
 
55 61
 if __name__ == '__main__':
56  
-    unittest.main()
  62
+    unittest.main()

0 notes on commit 6774207

Please sign in to comment.
Something went wrong with that request. Please try again.