Skip to content

Commit b9a40ac

Browse files
miss-islingtonvstinner
authored andcommitted
bpo-31222: Make (datetime|date|time).replace return subclass type in Pure Python (GH-4176) (#4356)
(cherry picked from commit 191e993)
1 parent 596286f commit b9a40ac

2 files changed

Lines changed: 17 additions & 3 deletions

File tree

Lib/datetime.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -827,7 +827,7 @@ def replace(self, year=None, month=None, day=None):
827827
month = self._month
828828
if day is None:
829829
day = self._day
830-
return date(year, month, day)
830+
return type(self)(year, month, day)
831831

832832
# Comparisons of date objects with other.
833833

@@ -1315,7 +1315,7 @@ def replace(self, hour=None, minute=None, second=None, microsecond=None,
13151315
tzinfo = self.tzinfo
13161316
if fold is None:
13171317
fold = self._fold
1318-
return time(hour, minute, second, microsecond, tzinfo, fold=fold)
1318+
return type(self)(hour, minute, second, microsecond, tzinfo, fold=fold)
13191319

13201320
# Pickle support.
13211321

@@ -1596,7 +1596,7 @@ def replace(self, year=None, month=None, day=None, hour=None,
15961596
tzinfo = self.tzinfo
15971597
if fold is None:
15981598
fold = self.fold
1599-
return datetime(year, month, day, hour, minute, second,
1599+
return type(self)(year, month, day, hour, minute, second,
16001600
microsecond, tzinfo, fold=fold)
16011601

16021602
def _local_timezone(self):

Lib/test/datetimetester.py

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1500,6 +1500,13 @@ def test_replace(self):
15001500
base = cls(2000, 2, 29)
15011501
self.assertRaises(ValueError, base.replace, year=2001)
15021502

1503+
def test_subclass_replace(self):
1504+
class DateSubclass(self.theclass):
1505+
pass
1506+
1507+
dt = DateSubclass(2012, 1, 1)
1508+
self.assertIs(type(dt.replace(year=2013)), DateSubclass)
1509+
15031510
def test_subclass_date(self):
15041511

15051512
class C(self.theclass):
@@ -2599,6 +2606,13 @@ def test_replace(self):
25992606
self.assertRaises(ValueError, base.replace, second=100)
26002607
self.assertRaises(ValueError, base.replace, microsecond=1000000)
26012608

2609+
def test_subclass_replace(self):
2610+
class TimeSubclass(self.theclass):
2611+
pass
2612+
2613+
ctime = TimeSubclass(12, 30)
2614+
self.assertIs(type(ctime.replace(hour=10)), TimeSubclass)
2615+
26022616
def test_subclass_time(self):
26032617

26042618
class C(self.theclass):

0 commit comments

Comments
 (0)