summaryrefslogtreecommitdiff
path: root/tests/basic
diff options
context:
space:
mode:
authorJon Dufresne <jon.dufresne@gmail.com>2015-04-04 12:22:30 -0700
committerClaude Paroz <claude@2xlibre.net>2015-04-06 22:43:51 +0200
commit2cf58e80d1be46ae95f77c95fe014921742295dd (patch)
tree6f26f2fbeb8f330d495437f361682bd9eb1a9b03 /tests/basic
parentad53213066ad25545959170f40322fa5b094989b (diff)
Fixed #24584 -- Fixed microsecond handling with older MySQLdb
Diffstat (limited to 'tests/basic')
-rw-r--r--tests/basic/tests.py23
1 files changed, 19 insertions, 4 deletions
diff --git a/tests/basic/tests.py b/tests/basic/tests.py
index d2a96799cf..0fd673fca6 100644
--- a/tests/basic/tests.py
+++ b/tests/basic/tests.py
@@ -192,15 +192,30 @@ class ModelTest(TestCase):
@skipIfDBFeature('supports_microsecond_precision')
def test_microsecond_precision_not_supported(self):
- # In MySQL, microsecond-level precision isn't available. You'll lose
- # microsecond-level precision once the data is saved.
+ # In MySQL, microsecond-level precision isn't always available. You'll
+ # lose microsecond-level precision once the data is saved.
a9 = Article(
headline='Article 9',
pub_date=datetime(2005, 7, 31, 12, 30, 45, 180),
)
a9.save()
- self.assertEqual(Article.objects.get(id__exact=a9.id).pub_date,
- datetime(2005, 7, 31, 12, 30, 45))
+ self.assertEqual(
+ Article.objects.get(id__exact=a9.id).pub_date,
+ datetime(2005, 7, 31, 12, 30, 45),
+ )
+
+ @skipIfDBFeature('supports_microsecond_precision')
+ def test_microsecond_precision_not_supported_edge_case(self):
+ # In MySQL, microsecond-level precision isn't always available. You'll
+ # lose microsecond-level precision once the data is saved.
+ a = Article.objects.create(
+ headline='Article',
+ pub_date=datetime(2008, 12, 31, 23, 59, 59, 999999),
+ )
+ self.assertEqual(
+ Article.objects.get(pk=a.pk).pub_date,
+ datetime(2008, 12, 31, 23, 59, 59),
+ )
def test_manually_specify_primary_key(self):
# You can manually specify the primary key when creating a new object.