123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- import datetime
- from django.test import TestCase, skipIfDBFeature
- from .models import Donut, RumBaba
- class DataTypesTestCase(TestCase):
- def test_boolean_type(self):
- d = Donut(name="Apple Fritter")
- self.assertFalse(d.is_frosted)
- self.assertIsNone(d.has_sprinkles)
- d.has_sprinkles = True
- self.assertTrue(d.has_sprinkles)
- d.save()
- d2 = Donut.objects.get(name="Apple Fritter")
- self.assertFalse(d2.is_frosted)
- self.assertTrue(d2.has_sprinkles)
- def test_date_type(self):
- d = Donut(name="Apple Fritter")
- d.baked_date = datetime.date(year=1938, month=6, day=4)
- d.baked_time = datetime.time(hour=5, minute=30)
- d.consumed_at = datetime.datetime(
- year=2007, month=4, day=20, hour=16, minute=19, second=59
- )
- d.save()
- d2 = Donut.objects.get(name="Apple Fritter")
- self.assertEqual(d2.baked_date, datetime.date(1938, 6, 4))
- self.assertEqual(d2.baked_time, datetime.time(5, 30))
- self.assertEqual(d2.consumed_at, datetime.datetime(2007, 4, 20, 16, 19, 59))
- def test_time_field(self):
- # Test for ticket #12059: TimeField wrongly handling datetime.datetime object.
- d = Donut(name="Apple Fritter")
- d.baked_time = datetime.datetime(
- year=2007, month=4, day=20, hour=16, minute=19, second=59
- )
- d.save()
- d2 = Donut.objects.get(name="Apple Fritter")
- self.assertEqual(d2.baked_time, datetime.time(16, 19, 59))
- def test_year_boundaries(self):
- """Year boundary tests (ticket #3689)"""
- Donut.objects.create(
- name="Date Test 2007",
- baked_date=datetime.datetime(year=2007, month=12, day=31),
- consumed_at=datetime.datetime(
- year=2007, month=12, day=31, hour=23, minute=59, second=59
- ),
- )
- Donut.objects.create(
- name="Date Test 2006",
- baked_date=datetime.datetime(year=2006, month=1, day=1),
- consumed_at=datetime.datetime(year=2006, month=1, day=1),
- )
- self.assertEqual(
- "Date Test 2007", Donut.objects.filter(baked_date__year=2007)[0].name
- )
- self.assertEqual(
- "Date Test 2006", Donut.objects.filter(baked_date__year=2006)[0].name
- )
- Donut.objects.create(
- name="Apple Fritter",
- consumed_at=datetime.datetime(
- year=2007, month=4, day=20, hour=16, minute=19, second=59
- ),
- )
- self.assertEqual(
- ["Apple Fritter", "Date Test 2007"],
- list(
- Donut.objects.filter(consumed_at__year=2007)
- .order_by("name")
- .values_list("name", flat=True)
- ),
- )
- self.assertEqual(0, Donut.objects.filter(consumed_at__year=2005).count())
- self.assertEqual(0, Donut.objects.filter(consumed_at__year=2008).count())
- def test_textfields_str(self):
- """TextField values returned from the database should be str."""
- d = Donut.objects.create(name="Jelly Donut", review="Outstanding")
- newd = Donut.objects.get(id=d.id)
- self.assertIsInstance(newd.review, str)
- @skipIfDBFeature("supports_timezones")
- def test_error_on_timezone(self):
- """Regression test for #8354: the MySQL and Oracle backends should raise
- an error if given a timezone-aware datetime object."""
- dt = datetime.datetime(2008, 8, 31, 16, 20, tzinfo=datetime.UTC)
- d = Donut(name="Bear claw", consumed_at=dt)
- # MySQL backend does not support timezone-aware datetimes.
- with self.assertRaises(ValueError):
- d.save()
- def test_datefield_auto_now_add(self):
- """Regression test for #10970, auto_now_add for DateField should store
- a Python datetime.date, not a datetime.datetime"""
- b = RumBaba.objects.create()
- # Verify we didn't break DateTimeField behavior
- self.assertIsInstance(b.baked_timestamp, datetime.datetime)
- # We need to test this way because datetime.datetime inherits
- # from datetime.date:
- self.assertIsInstance(b.baked_date, datetime.date)
- self.assertNotIsInstance(b.baked_date, datetime.datetime)
|