From: Alexander Belopolsky Date: Mon, 5 Jul 2010 15:05:33 +0000 (+0000) Subject: Added more tests for utctimetuple() X-Git-Tag: v3.2a1~303 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f34e82ef49728f73254b1eff12bfe643c2cd2124;p=python Added more tests for utctimetuple() --- diff --git a/Lib/test/test_datetime.py b/Lib/test/test_datetime.py index fb1ce4ce24..4423d9b26b 100644 --- a/Lib/test/test_datetime.py +++ b/Lib/test/test_datetime.py @@ -3008,7 +3008,7 @@ class TestDateTimeTZ(TestDateTime, TZInfoBase, unittest.TestCase): def test_utctimetuple(self): class DST(tzinfo): - def __init__(self, dstvalue): + def __init__(self, dstvalue=0): if isinstance(dstvalue, int): dstvalue = timedelta(minutes=dstvalue) self.dstvalue = dstvalue @@ -3043,6 +3043,26 @@ class TestDateTimeTZ(TestDateTime, TZInfoBase, unittest.TestCase): # is never in effect for a UTC time. self.assertEqual(0, t.tm_isdst) + # For naive datetime, utctimetuple == timetuple except for isdst + d = cls(1, 2, 3, 10, 20, 30, 40) + t = d.utctimetuple() + self.assertEqual(t[:-1], d.timetuple()[:-1]) + self.assertEqual(0, t.tm_isdst) + # Same if utcoffset is None + class NOFS(DST): + def utcoffset(self, dt): + return None + d = cls(1, 2, 3, 10, 20, 30, 40, tzinfo=NOFS()) + t = d.utctimetuple() + self.assertEqual(t[:-1], d.timetuple()[:-1]) + self.assertEqual(0, t.tm_isdst) + # Check that bad tzinfo is detected + class BOFS(DST): + def utcoffset(self, dt): + return "EST" + d = cls(1, 2, 3, 10, 20, 30, 40, tzinfo=BOFS()) + self.assertRaises(TypeError, d.utctimetuple) + # Check that utctimetuple() is the same as # astimezone(utc).timetuple() d = cls(2010, 11, 13, 14, 15, 16, 171819)