Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
122376df
Commit
122376df
authored
Aug 29, 2019
by
Justin Blanchard
Committed by
Serhiy Storchaka
Aug 29, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-37372: Fix error unpickling datetime.time objects from Python 2 with seconds>=24. (GH-14307)
parent
e64f948e
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
22 additions
and
10 deletions
+22
-10
Lib/test/datetimetester.py
Lib/test/datetimetester.py
+18
-9
Misc/ACKS
Misc/ACKS
+1
-0
Misc/NEWS.d/next/Library/2019-06-22-12-30-00.bpo-37372.kIKqZ6.rst
...S.d/next/Library/2019-06-22-12-30-00.bpo-37372.kIKqZ6.rst
+2
-0
Modules/_datetimemodule.c
Modules/_datetimemodule.c
+1
-1
No files found.
Lib/test/datetimetester.py
View file @
122376df
...
@@ -3324,16 +3324,25 @@ class TestTime(HarmlessMixedComparison, unittest.TestCase):
...
@@ -3324,16 +3324,25 @@ class TestTime(HarmlessMixedComparison, unittest.TestCase):
def
test_compat_unpickle
(
self
):
def
test_compat_unpickle
(
self
):
tests
=
[
tests
=
[
b"cdatetime
\
n
time
\
n
(S'
\
\
x14;
\
\
x10
\
\
x00
\
\
x10
\
\
x00'
\
n
tR."
,
(
b"cdatetime
\
n
time
\
n
(S'
\
\
x14;
\
\
x10
\
\
x00
\
\
x10
\
\
x00'
\
n
tR."
,
b'cdatetime
\
n
time
\
n
(U
\
x06
\
x14
;
\
x10
\
x00
\
x10
\
x00
tR.'
,
(
20
,
59
,
16
,
64
**
2
)),
b'
\
x80
\
x02
cdatetime
\
n
time
\
n
U
\
x06
\
x14
;
\
x10
\
x00
\
x10
\
x00
\
x85
R.'
,
(
b'cdatetime
\
n
time
\
n
(U
\
x06
\
x14
;
\
x10
\
x00
\
x10
\
x00
tR.'
,
(
20
,
59
,
16
,
64
**
2
)),
(
b'
\
x80
\
x02
cdatetime
\
n
time
\
n
U
\
x06
\
x14
;
\
x10
\
x00
\
x10
\
x00
\
x85
R.'
,
(
20
,
59
,
16
,
64
**
2
)),
(
b"cdatetime
\
n
time
\
n
(S'
\
\
x14;
\
\
x19
\
\
x00
\
\
x10
\
\
x00'
\
n
tR."
,
(
20
,
59
,
25
,
64
**
2
)),
(
b'cdatetime
\
n
time
\
n
(U
\
x06
\
x14
;
\
x19
\
x00
\
x10
\
x00
tR.'
,
(
20
,
59
,
25
,
64
**
2
)),
(
b'
\
x80
\
x02
cdatetime
\
n
time
\
n
U
\
x06
\
x14
;
\
x19
\
x00
\
x10
\
x00
\
x85
R.'
,
(
20
,
59
,
25
,
64
**
2
)),
]
]
args
=
20
,
59
,
16
,
64
**
2
for
i
,
(
data
,
args
)
in
enumerate
(
tests
):
expected
=
self
.
theclass
(
*
args
)
with
self
.
subTest
(
i
=
i
):
for
data
in
tests
:
expected
=
self
.
theclass
(
*
args
)
for
loads
in
pickle_loads
:
for
loads
in
pickle_loads
:
derived
=
loads
(
data
,
encoding
=
'latin1'
)
derived
=
loads
(
data
,
encoding
=
'latin1'
)
self
.
assertEqual
(
derived
,
expected
)
self
.
assertEqual
(
derived
,
expected
)
def
test_bool
(
self
):
def
test_bool
(
self
):
# time is always True.
# time is always True.
...
...
Misc/ACKS
View file @
122376df
...
@@ -162,6 +162,7 @@ Roy Bixler
...
@@ -162,6 +162,7 @@ Roy Bixler
Daniel Black
Daniel Black
Jonathan Black
Jonathan Black
Renaud Blanch
Renaud Blanch
Justin Blanchard
Mike Bland
Mike Bland
Martin Bless
Martin Bless
Pablo Bleyer
Pablo Bleyer
...
...
Misc/NEWS.d/next/Library/2019-06-22-12-30-00.bpo-37372.kIKqZ6.rst
0 → 100644
View file @
122376df
Fix error unpickling datetime.time objects from Python 2 with seconds>=24.
Patch by Justin Blanchard.
Modules/_datetimemodule.c
View file @
122376df
...
@@ -4078,7 +4078,7 @@ time_new(PyTypeObject *type, PyObject *args, PyObject *kw)
...
@@ -4078,7 +4078,7 @@ time_new(PyTypeObject *type, PyObject *args, PyObject *kw)
return
NULL
;
return
NULL
;
}
}
if
(
PyUnicode_GET_LENGTH
(
state
)
==
_PyDateTime_TIME_DATASIZE
&&
if
(
PyUnicode_GET_LENGTH
(
state
)
==
_PyDateTime_TIME_DATASIZE
&&
(
0x7F
&
PyUnicode_READ_CHAR
(
state
,
2
))
<
24
)
(
0x7F
&
PyUnicode_READ_CHAR
(
state
,
0
))
<
24
)
{
{
state
=
PyUnicode_AsLatin1String
(
state
);
state
=
PyUnicode_AsLatin1String
(
state
);
if
(
state
==
NULL
)
{
if
(
state
==
NULL
)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment