Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
625c88b0
Commit
625c88b0
authored
Nov 18, 2019
by
Jason Madden
Committed by
GitHub
Nov 18, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1483 from gevent/py38-take2
Update Python versions, including 3.8 final on Appveyor
parents
bb1d6c99
e00c797c
Changes
40
Show whitespace changes
Inline
Side-by-side
Showing
40 changed files
with
1239 additions
and
685 deletions
+1239
-685
.pylintrc
.pylintrc
+6
-1
CHANGES.rst
CHANGES.rst
+3
-1
appveyor.yml
appveyor.yml
+13
-4
scripts/install.sh
scripts/install.sh
+7
-7
src/gevent/__init__.py
src/gevent/__init__.py
+16
-18
src/gevent/_compat.py
src/gevent/_compat.py
+32
-1
src/gevent/_imap.py
src/gevent/_imap.py
+1
-2
src/gevent/_socket2.py
src/gevent/_socket2.py
+1
-1
src/gevent/_socket3.py
src/gevent/_socket3.py
+1
-1
src/gevent/_ssl2.py
src/gevent/_ssl2.py
+1
-2
src/gevent/_ssl3.py
src/gevent/_ssl3.py
+58
-45
src/gevent/hub.py
src/gevent/hub.py
+22
-10
src/gevent/subprocess.py
src/gevent/subprocess.py
+37
-9
src/gevent/testing/monkey_test.py
src/gevent/testing/monkey_test.py
+10
-0
src/gevent/testing/openfiles.py
src/gevent/testing/openfiles.py
+25
-2
src/gevent/testing/sysinfo.py
src/gevent/testing/sysinfo.py
+13
-0
src/gevent/testing/util.py
src/gevent/testing/util.py
+34
-0
src/gevent/tests/test___monkey_patching.py
src/gevent/tests/test___monkey_patching.py
+3
-26
src/gevent/tests/test__makefile_ref.py
src/gevent/tests/test__makefile_ref.py
+234
-216
src/gevent/tests/test__monkey_sigchld.py
src/gevent/tests/test__monkey_sigchld.py
+21
-1
src/gevent/tests/test__monkey_sigchld_2.py
src/gevent/tests/test__monkey_sigchld_2.py
+5
-0
src/gevent/tests/test__monkey_sigchld_3.py
src/gevent/tests/test__monkey_sigchld_3.py
+6
-0
src/gevent/tests/test__pywsgi.py
src/gevent/tests/test__pywsgi.py
+2
-2
src/gevent/tests/test__ssl.py
src/gevent/tests/test__ssl.py
+7
-2
src/greentest/3.7/keycert.passwd.pem
src/greentest/3.7/keycert.passwd.pem
+43
-42
src/greentest/3.7/ssl_key.passwd.pem
src/greentest/3.7/ssl_key.passwd.pem
+42
-42
src/greentest/3.7/test_httplib.py
src/greentest/3.7/test_httplib.py
+29
-0
src/greentest/3.7/test_ssl.py
src/greentest/3.7/test_ssl.py
+148
-58
src/greentest/3.7/test_subprocess.py
src/greentest/3.7/test_subprocess.py
+46
-9
src/greentest/3.7/test_wsgiref.py
src/greentest/3.7/test_wsgiref.py
+54
-24
src/greentest/3.7/version
src/greentest/3.7/version
+1
-1
src/greentest/3.8/keycert.passwd.pem
src/greentest/3.8/keycert.passwd.pem
+43
-42
src/greentest/3.8/ssl_key.passwd.pem
src/greentest/3.8/ssl_key.passwd.pem
+42
-42
src/greentest/3.8/test_httplib.py
src/greentest/3.8/test_httplib.py
+29
-0
src/greentest/3.8/test_socket.py
src/greentest/3.8/test_socket.py
+3
-1
src/greentest/3.8/test_ssl.py
src/greentest/3.8/test_ssl.py
+151
-58
src/greentest/3.8/test_subprocess.py
src/greentest/3.8/test_subprocess.py
+46
-9
src/greentest/3.8/test_threading.py
src/greentest/3.8/test_threading.py
+0
-1
src/greentest/3.8/test_wsgiref.py
src/greentest/3.8/test_wsgiref.py
+3
-4
src/greentest/3.8/version
src/greentest/3.8/version
+1
-1
No files found.
.pylintrc
View file @
625c88b0
...
@@ -49,6 +49,9 @@ limit-inference-results=1
...
@@ -49,6 +49,9 @@ limit-inference-results=1
# @property
# @property
# def foo(self):
# def foo(self):
# return None # generates useless-return
# return None # generates useless-return
# Pylint 2.4 adds import-outside-toplevel. But we do that a lot to defer imports because of patching.
# Pylint 2.4 adds self-assigning-variable. But we do *that* to avoid unused-import when we
# "export" the variable and don't have a __all__.
disable=wrong-import-position,
disable=wrong-import-position,
wrong-import-order,
wrong-import-order,
missing-docstring,
missing-docstring,
...
@@ -69,7 +72,9 @@ disable=wrong-import-position,
...
@@ -69,7 +72,9 @@ disable=wrong-import-position,
undefined-all-variable,
undefined-all-variable,
inconsistent-return-statements,
inconsistent-return-statements,
useless-return,
useless-return,
useless-object-inheritance
useless-object-inheritance,
import-outside-toplevel,
self-assigning-variable
[FORMAT]
[FORMAT]
...
...
CHANGES.rst
View file @
625c88b0
...
@@ -7,7 +7,9 @@
...
@@ -7,7 +7,9 @@
1.5a3 (unreleased)
1.5a3 (unreleased)
==================
==================
- Nothing changed yet.
- Python version updates: gevent is now tested with CPython 2.7.17,
3.5.9, 3.6.9, 3.7.5 and 3.8.0 (final). It is also tested with PyPy2
7.2 and PyPy 3.6 7.2
1.5a2 (2019-10-21)
1.5a2 (2019-10-21)
...
...
appveyor.yml
View file @
625c88b0
...
@@ -19,6 +19,10 @@ environment:
...
@@ -19,6 +19,10 @@ environment:
# a later point release.
# a later point release.
# 64-bit
# 64-bit
-
PYTHON
:
"
C:
\\
Python38-x64"
PYTHON_VERSION
:
"
3.8.x"
PYTHON_ARCH
:
"
64"
PYTHON_EXE
:
python
-
PYTHON
:
"
C:
\\
Python37-x64"
-
PYTHON
:
"
C:
\\
Python37-x64"
PYTHON_VERSION
:
"
3.7.x"
PYTHON_VERSION
:
"
3.7.x"
...
@@ -41,13 +45,18 @@ environment:
...
@@ -41,13 +45,18 @@ environment:
PYTHON_EXE
:
python
PYTHON_EXE
:
python
# 32-bit
# 32-bit
-
PYTHON
:
"
C:
\\
pypy2.7-v7.
1
.0-win32"
-
PYTHON
:
"
C:
\\
pypy2.7-v7.
2
.0-win32"
PYTHON_ID
:
"
pypy"
PYTHON_ID
:
"
pypy"
PYTHON_EXE
:
pypy
PYTHON_EXE
:
pypy
PYTHON_VERSION
:
"
2.7.x"
PYTHON_VERSION
:
"
2.7.x"
PYTHON_ARCH
:
"
32"
PYTHON_ARCH
:
"
32"
# 32-bit, wheel only (no testing)
# 32-bit, wheel only (no testing)
-
PYTHON
:
"
C:
\\
Python38"
PYTHON_VERSION
:
"
3.8.x"
PYTHON_ARCH
:
"
32"
PYTHON_EXE
:
python
GWHEEL_ONLY
:
true
-
PYTHON
:
"
C:
\\
Python37"
-
PYTHON
:
"
C:
\\
Python37"
PYTHON_VERSION
:
"
3.7.x"
PYTHON_VERSION
:
"
3.7.x"
...
@@ -110,10 +119,10 @@ install:
...
@@ -110,10 +119,10 @@ install:
New-Item -ItemType directory -Path "$env:PYTMP" | Out-Null;
New-Item -ItemType directory -Path "$env:PYTMP" | Out-Null;
}
}
if ("${env:PYTHON_ID}" -eq "pypy") {
if ("${env:PYTHON_ID}" -eq "pypy") {
if (!(Test-Path "${env:PYTMP}\pypy2-v7.
1
.0-win32.zip")) {
if (!(Test-Path "${env:PYTMP}\pypy2-v7.
2
.0-win32.zip")) {
(New-Object Net.WebClient).DownloadFile('https://bitbucket.org/pypy/pypy/downloads/pypy2.7-v7.
1.0-win32.zip', "${env:PYTMP}\pypy2-v7.1
.0-win32.zip");
(New-Object Net.WebClient).DownloadFile('https://bitbucket.org/pypy/pypy/downloads/pypy2.7-v7.
2.0-win32.zip', "${env:PYTMP}\pypy2-v7.2
.0-win32.zip");
}
}
7z x -y "${env:PYTMP}\pypy2-v7.
1
.0-win32.zip" -oC:\ | Out-Null;
7z x -y "${env:PYTMP}\pypy2-v7.
2
.0-win32.zip" -oC:\ | Out-Null;
& "${env:PYTHON}\pypy.exe" "-mensurepip";
& "${env:PYTHON}\pypy.exe" "-mensurepip";
}
}
...
...
scripts/install.sh
View file @
625c88b0
...
@@ -96,25 +96,25 @@ install () {
...
@@ -96,25 +96,25 @@ install () {
for
var
in
"
$@
"
;
do
for
var
in
"
$@
"
;
do
case
"
${
var
}
"
in
case
"
${
var
}
"
in
2.7
)
2.7
)
install
2.7.1
6
python2.7 2.7.d
install
2.7.1
7
python2.7 2.7.d
;;
;;
3.5
)
3.5
)
install
3.5.
6
python3.5 3.5.d
install
3.5.
9
python3.5 3.5.d
;;
;;
3.6
)
3.6
)
install
3.6.
8
python3.6 3.6.d
install
3.6.
9
python3.6 3.6.d
;;
;;
3.7
)
3.7
)
install
3.7.
4
python3.7 3.7.d
install
3.7.
5
python3.7 3.7.d
;;
;;
3.8
)
3.8
)
install
3.8.0
b4
python3.8 3.8.d
install
3.8.0 python3.8 3.8.d
;;
;;
pypy2.7
)
pypy2.7
)
install
pypy2.7-7.
1
.0 pypy2.7 pypy2.7.d
install
pypy2.7-7.
2
.0 pypy2.7 pypy2.7.d
;;
;;
pypy3.6
)
pypy3.6
)
install
pypy3.6-7.
1
.0 pypy3.6 pypy3.6.d
install
pypy3.6-7.
2
.0 pypy3.6 pypy3.6.d
;;
;;
esac
esac
done
done
src/gevent/__init__.py
View file @
625c88b0
...
@@ -31,29 +31,29 @@ __version__ = '1.5a3.dev0'
...
@@ -31,29 +31,29 @@ __version__ = '1.5a3.dev0'
__all__
=
[
__all__
=
[
'get_hub'
,
'Greenlet'
,
'Greenlet'
,
'GreenletExit'
,
'GreenletExit'
,
'spawn'
,
'spawn_later'
,
'spawn_raw'
,
'iwait'
,
'wait'
,
'killall'
,
'Timeout'
,
'Timeout'
,
'with_timeout'
,
'config'
,
# Added in 1.3a2
'fork'
,
'get_hub'
,
'getcurrent'
,
'getcurrent'
,
'
sleep
'
,
'
getswitchinterval
'
,
'idle'
,
'idle'
,
'iwait'
,
'joinall'
,
'kill'
,
'kill'
,
'signal'
,
# deprecated
'killall'
,
'signal_handler'
,
'fork'
,
'reinit'
,
'reinit'
,
'getswitchinterval'
,
'setswitchinterval'
,
'setswitchinterval'
,
# Added in 1.3a2
'signal'
,
# deprecated
'config'
,
'signal_handler'
,
'sleep'
,
'spawn'
,
'spawn_later'
,
'spawn_raw'
,
'wait'
,
'with_timeout'
,
]
]
...
@@ -89,11 +89,9 @@ from gevent._hub_primitives import iwait_on_objects as iwait
...
@@ -89,11 +89,9 @@ from gevent._hub_primitives import iwait_on_objects as iwait
from
gevent._hub_primitives
import
wait_on_objects
as
wait
from
gevent._hub_primitives
import
wait_on_objects
as
wait
from
gevent.greenlet
import
Greenlet
,
joinall
,
killall
from
gevent.greenlet
import
Greenlet
,
joinall
,
killall
joinall
=
joinall
# export for pylint
spawn
=
Greenlet
.
spawn
spawn
=
Greenlet
.
spawn
spawn_later
=
Greenlet
.
spawn_later
spawn_later
=
Greenlet
.
spawn_later
#: The singleton configuration object for gevent.
#: The singleton configuration object for gevent.
config
=
config
from
gevent.timeout
import
Timeout
,
with_timeout
from
gevent.timeout
import
Timeout
,
with_timeout
from
gevent.hub
import
getcurrent
,
GreenletExit
,
spawn_raw
,
sleep
,
idle
,
kill
,
reinit
from
gevent.hub
import
getcurrent
,
GreenletExit
,
spawn_raw
,
sleep
,
idle
,
kill
,
reinit
...
@@ -163,7 +161,7 @@ del sys
...
@@ -163,7 +161,7 @@ del sys
# outdated on each major release.
# outdated on each major release.
def
__dependencies_for_freezing
():
# pragma: no cover
def
__dependencies_for_freezing
():
# pragma: no cover
# pylint:disable=unused-import
# pylint:disable=unused-import
, import-outside-toplevel
from
gevent
import
core
from
gevent
import
core
from
gevent
import
resolver_thread
from
gevent
import
resolver_thread
from
gevent
import
resolver_ares
from
gevent
import
resolver_ares
...
...
src/gevent/_compat.py
View file @
625c88b0
...
@@ -47,6 +47,14 @@ def NativeStrIO():
...
@@ -47,6 +47,14 @@ def NativeStrIO():
import
io
import
io
return
io
.
BytesIO
()
if
str
is
bytes
else
io
.
StringIO
()
return
io
.
BytesIO
()
if
str
is
bytes
else
io
.
StringIO
()
try
:
from
abc
import
ABC
except
ImportError
:
import
abc
ABC
=
abc
.
ABCMeta
(
'ABC'
,
(
object
,),
{
'__slots__'
:
()})
del
abc
## Exceptions
## Exceptions
if
PY3
:
if
PY3
:
def
reraise
(
t
,
value
,
tb
=
None
):
# pylint:disable=unused-argument
def
reraise
(
t
,
value
,
tb
=
None
):
# pylint:disable=unused-argument
...
@@ -87,6 +95,16 @@ else:
...
@@ -87,6 +95,16 @@ else:
from
itertools
import
izip
# python 3: pylint:disable=no-member,no-name-in-module
from
itertools
import
izip
# python 3: pylint:disable=no-member,no-name-in-module
izip
=
izip
izip
=
izip
## The __fspath__ protocol
try
:
from
os
import
PathLike
# pylint:disable=unused-import
except
ImportError
:
class
PathLike
(
ABC
):
@
classmethod
def
__subclasshook__
(
cls
,
subclass
):
return
hasattr
(
subclass
,
'__fspath__'
)
# fspath from 3.6 os.py, but modified to raise the same exceptions as the
# fspath from 3.6 os.py, but modified to raise the same exceptions as the
# real native implementation.
# real native implementation.
# Define for testing
# Define for testing
...
@@ -152,6 +170,19 @@ except ImportError:
...
@@ -152,6 +170,19 @@ except ImportError:
# Not sure how to handle this.
# Not sure how to handle this.
raise
UnicodeEncodeError
(
"Can't encode path to filesystem encoding"
)
raise
UnicodeEncodeError
(
"Can't encode path to filesystem encoding"
)
try
:
from
os
import
fsdecode
# pylint:disable=unused-import
except
ImportError
:
def
fsdecode
(
filename
):
"""Decode filename (an os.PathLike, bytes, or str) from the filesystem
encoding with 'surrogateescape' error handler, return str unchanged. On
Windows, use 'strict' error handler if the file system encoding is
'mbcs' (which is the default encoding).
"""
filename
=
fspath
(
filename
)
# Does type-checking of `filename`.
if
PY3
and
isinstance
(
filename
,
bytes
):
return
filename
.
decode
(
encoding
,
errors
)
return
filename
## Clocks
## Clocks
try
:
try
:
...
@@ -162,7 +193,7 @@ except ImportError:
...
@@ -162,7 +193,7 @@ except ImportError:
import
time
import
time
if
sys
.
platform
==
"win32"
:
if
sys
.
platform
==
"win32"
:
perf_counter
=
time
.
clock
perf_counter
=
time
.
clock
# pylint:disable=no-member
else
:
else
:
perf_counter
=
time
.
time
perf_counter
=
time
.
time
...
...
src/gevent/_imap.py
View file @
625c88b0
...
@@ -206,7 +206,6 @@ class IMap(IMapUnordered):
...
@@ -206,7 +206,6 @@ class IMap(IMapUnordered):
index
,
value
=
self
.
queue
.
get
()
index
,
value
=
self
.
queue
.
get
()
if
index
==
self
.
index
:
if
index
==
self
.
index
:
break
break
else
:
self
.
_results
[
index
]
=
value
self
.
_results
[
index
]
=
value
self
.
index
+=
1
self
.
index
+=
1
return
value
return
value
...
...
src/gevent/_socket2.py
View file @
625c88b0
...
@@ -261,7 +261,7 @@ class socket(object):
...
@@ -261,7 +261,7 @@ class socket(object):
result
=
self
.
_sock
.
connect_ex
(
address
)
result
=
self
.
_sock
.
connect_ex
(
address
)
if
not
result
or
result
==
EISCONN
:
if
not
result
or
result
==
EISCONN
:
break
break
el
if
(
result
in
(
EWOULDBLOCK
,
EINPROGRESS
,
EALREADY
))
or
(
result
==
EINVAL
and
is_windows
):
if
(
result
in
(
EWOULDBLOCK
,
EINPROGRESS
,
EALREADY
))
or
(
result
==
EINVAL
and
is_windows
):
self
.
_wait
(
self
.
_write_event
)
self
.
_wait
(
self
.
_write_event
)
else
:
else
:
raise
error
(
result
,
strerror
(
result
))
raise
error
(
result
,
strerror
(
result
))
...
...
src/gevent/_socket3.py
View file @
625c88b0
...
@@ -398,7 +398,7 @@ class socket(object):
...
@@ -398,7 +398,7 @@ class socket(object):
if
not
result
or
result
==
EISCONN
:
if
not
result
or
result
==
EISCONN
:
break
break
el
if
(
result
in
(
EWOULDBLOCK
,
EINPROGRESS
,
EALREADY
))
or
(
result
==
EINVAL
and
is_windows
):
if
(
result
in
(
EWOULDBLOCK
,
EINPROGRESS
,
EALREADY
))
or
(
result
==
EINVAL
and
is_windows
):
self
.
_wait
(
self
.
_write_event
)
self
.
_wait
(
self
.
_write_event
)
else
:
else
:
if
(
isinstance
(
address
,
tuple
)
if
(
isinstance
(
address
,
tuple
)
...
...
src/gevent/_ssl2.py
View file @
625c88b0
...
@@ -235,7 +235,6 @@ class SSLSocket(socket):
...
@@ -235,7 +235,6 @@ class SSLSocket(socket):
sys
.
exc_clear
()
sys
.
exc_clear
()
self
.
_wait
(
self
.
_read_event
)
self
.
_wait
(
self
.
_read_event
)
continue
continue
else
:
raise
raise
else
:
else
:
return
socket
.
recv_into
(
self
,
buffer
,
nbytes
,
flags
)
return
socket
.
recv_into
(
self
,
buffer
,
nbytes
,
flags
)
...
...
src/gevent/_ssl3.py
View file @
625c88b0
...
@@ -44,6 +44,31 @@ if 'namedtuple' in __all__:
...
@@ -44,6 +44,31 @@ if 'namedtuple' in __all__:
orig_SSLContext
=
__ssl__
.
SSLContext
# pylint:disable=no-member
orig_SSLContext
=
__ssl__
.
SSLContext
# pylint:disable=no-member
# We have to pass the raw stdlib socket to SSLContext.wrap_socket.
# That method in turn can pass that object on to things like SNI callbacks.
# It wouldn't have access to any of the attributes on the SSLSocket, like
# context, that it's supposed to (see test_ssl.test_sni_callback). Previously
# we just delegated to the sslsocket with __getattr__, but 3.8
# added some new callbacks and a test that the object they get is an instance
# of the high-level SSLSocket class, so that doesn't work anymore. Instead,
# we wrap the callback and get the real socket to pass on.
class
_contextawaresock
(
socket
.
_gevent_sock_class
):
__slots__
=
(
'_sslsock'
,)
def
__init__
(
self
,
family
,
type
,
proto
,
fileno
,
sslsocket_wref
):
super
().
__init__
(
family
,
type
,
proto
,
fileno
)
self
.
_sslsock
=
sslsocket_wref
class
_Callback
(
object
):
__slots__
=
(
'user_function'
,)
def
__init__
(
self
,
user_function
):
self
.
user_function
=
user_function
def
__call__
(
self
,
conn
,
*
args
):
conn
=
conn
.
_sslsock
()
return
self
.
user_function
(
conn
,
*
args
)
class
SSLContext
(
orig_SSLContext
):
class
SSLContext
(
orig_SSLContext
):
...
@@ -68,10 +93,6 @@ class SSLContext(orig_SSLContext):
...
@@ -68,10 +93,6 @@ class SSLContext(orig_SSLContext):
_context
=
self
,
_context
=
self
,
_session
=
session
)
_session
=
session
)
if
not
hasattr
(
orig_SSLContext
,
'check_hostname'
):
# Python 3.3 lacks this
check_hostname
=
False
if
hasattr
(
orig_SSLContext
.
options
,
'setter'
):
if
hasattr
(
orig_SSLContext
.
options
,
'setter'
):
# In 3.6, these became properties. They want to access the
# In 3.6, these became properties. They want to access the
# property __set__ method in the superclass, and they do so by using
# property __set__ method in the superclass, and they do so by using
...
@@ -108,52 +129,44 @@ class SSLContext(orig_SSLContext):
...
@@ -108,52 +129,44 @@ class SSLContext(orig_SSLContext):
# SSLContext back. This function cannot switch, so it should be safe,
# SSLContext back. This function cannot switch, so it should be safe,
# unless somehow we have multiple threads in a monkey-patched ssl module
# unless somehow we have multiple threads in a monkey-patched ssl module
# at the same time, which doesn't make much sense.
# at the same time, which doesn't make much sense.
@
orig_SSLContext
.
_msg_callback
.
setter
@
property
def
_msg_callback
(
self
):
result
=
super
().
_msg_callback
if
isinstance
(
result
,
_Callback
):
result
=
result
.
user_function
return
result
@
_msg_callback
.
setter
def
_msg_callback
(
self
,
value
):
def
_msg_callback
(
self
,
value
):
if
value
and
callable
(
value
):
value
=
_Callback
(
value
)
__ssl__
.
SSLContext
=
orig_SSLContext
__ssl__
.
SSLContext
=
orig_SSLContext
try
:
try
:
super
(
SSLContext
,
SSLContext
).
_msg_callback
.
__set__
(
self
,
value
)
super
(
SSLContext
,
SSLContext
).
_msg_callback
.
__set__
(
self
,
value
)
finally
:
finally
:
__ssl__
.
SSLContext
=
SSLContext
__ssl__
.
SSLContext
=
SSLContext
class
_contextawaresock
(
socket
.
_gevent_sock_class
):
if
hasattr
(
orig_SSLContext
,
'sni_callback'
):
# We have to pass the raw stdlib socket to SSLContext.wrap_socket.
# Added in 3.7.
# That method in turn can pass that object on to things like SNI callbacks.
# It wouldn't have access to any of the attributes on the SSLSocket, like
# context, that it's supposed to (see test_ssl.test_sni_callback). Our
# solution is to keep a weak reference to the SSLSocket on the raw
# socket and delegate.
# We keep it in a slot to avoid having the ability to set any attributes
# we're not prepared for (because we don't know what to delegate.)
__slots__
=
(
'_sslsock'
,)
@
property
@
property
def
context
(
self
):
def
sni_callback
(
self
):
return
self
.
_sslsock
().
context
result
=
super
().
sni_callback
if
isinstance
(
result
,
_Callback
):
@
context
.
setter
result
=
result
.
user_function
def
context
(
self
,
ctx
):
return
result
self
.
_sslsock
().
context
=
ctx
@
sni_callback
.
setter
def
sni_callback
(
self
,
value
):
@
property
if
value
and
callable
(
value
):
def
session
(
self
):
value
=
_Callback
(
value
)
"""The SSLSession for client socket."""
super
(
orig_SSLContext
,
orig_SSLContext
).
sni_callback
.
__set__
(
self
,
value
)
return
self
.
_sslsock
().
session
else
:
# In newer versions, this just sets sni_callback.
@
session
.
setter
def
set_servername_callback
(
self
,
cb
):
# pylint:disable=arguments-differ
def
session
(
self
,
session
):
if
cb
and
callable
(
cb
):
self
.
_sslsock
().
session
=
session
cb
=
_Callback
(
cb
)
super
().
set_servername_callback
(
cb
)
def
__getattr__
(
self
,
name
):
try
:
return
getattr
(
self
.
_sslsock
(),
name
)
except
RuntimeError
:
# XXX: If the attribute doesn't exist,
# we infinitely recurse
pass
raise
AttributeError
(
name
)
class
SSLSocket
(
socket
):
class
SSLSocket
(
socket
):
"""
"""
...
@@ -164,8 +177,6 @@ class SSLSocket(socket):
...
@@ -164,8 +177,6 @@ class SSLSocket(socket):
# pylint:disable=too-many-instance-attributes,too-many-public-methods
# pylint:disable=too-many-instance-attributes,too-many-public-methods
_gevent_sock_class
=
_contextawaresock
def
__init__
(
self
,
sock
=
None
,
keyfile
=
None
,
certfile
=
None
,
def
__init__
(
self
,
sock
=
None
,
keyfile
=
None
,
certfile
=
None
,
server_side
=
False
,
cert_reqs
=
CERT_NONE
,
server_side
=
False
,
cert_reqs
=
CERT_NONE
,
ssl_version
=
PROTOCOL_SSLv23
,
ca_certs
=
None
,
ssl_version
=
PROTOCOL_SSLv23
,
ca_certs
=
None
,
...
@@ -243,7 +254,6 @@ class SSLSocket(socket):
...
@@ -243,7 +254,6 @@ class SSLSocket(socket):
else
:
else
:
socket
.
__init__
(
self
,
family
=
family
,
type
=
type
,
proto
=
proto
)
socket
.
__init__
(
self
,
family
=
family
,
type
=
type
,
proto
=
proto
)
self
.
_sock
.
_sslsock
=
_wref
(
self
)
self
.
_closed
=
False
self
.
_closed
=
False
self
.
_sslobj
=
None
self
.
_sslobj
=
None
# see if we're connected
# see if we're connected
...
@@ -274,6 +284,9 @@ class SSLSocket(socket):
...
@@ -274,6 +284,9 @@ class SSLSocket(socket):
self
.
close
()
self
.
close
()
raise
x
raise
x
def
_gevent_sock_class
(
self
,
family
,
type
,
proto
,
fileno
):
return
_contextawaresock
(
family
,
type
,
proto
,
fileno
,
_wref
(
self
))
def
_extra_repr
(
self
):
def
_extra_repr
(
self
):
return
' server=%s, cipher=%r'
%
(
return
' server=%s, cipher=%r'
%
(
self
.
server_side
,
self
.
server_side
,
...
...
src/gevent/hub.py
View file @
625c88b0
...
@@ -462,18 +462,29 @@ class Hub(WaitOperationsGreenlet):
...
@@ -462,18 +462,29 @@ class Hub(WaitOperationsGreenlet):
def
handle_error
(
self
,
context
,
type
,
value
,
tb
):
def
handle_error
(
self
,
context
,
type
,
value
,
tb
):
"""
"""
Called by the event loop when an error occurs. The arguments
Called by the event loop when an error occurs. The default
type, value, and tb are the standard tuple returned by :func:`sys.exc_info`.
action is to print the exception to the :attr:`exception
stream <exception_stream>`.
Applications can set a property on the hub with this same signature
The arguments ``type``, ``value``, and ``tb`` are the standard
to override the error handling provided by this class.
tuple as returned by :func:`sys.exc_info`. (Note that when
this is called, it may not be safe to call
:func:`sys.exc_info`.)
Errors that are :attr:`
system errors <SYSTEM_ERROR>` are passed
Errors that are :attr:`
not errors <NOT_ERROR>` are not
to :meth:`handle_system_error`
.
printed
.
:param context: If this is ``None``, indicates a system error that
Errors that are :attr:`system errors <SYSTEM_ERROR>` are
should generally result in exiting the loop and being thrown to the
passed to :meth:`handle_system_error` after being printed.
parent greenlet.
Applications can set a property on the hub instance with this
same signature to override the error handling provided by this
class. This is an advanced usage and requires great care. This
function *must not* raise any exceptions.
:param context: If this is ``None``, indicates a system error
that should generally result in exiting the loop and being
thrown to the parent greenlet.
"""
"""
if
isinstance
(
value
,
str
):
if
isinstance
(
value
,
str
):
# Cython can raise errors where the value is a plain string
# Cython can raise errors where the value is a plain string
...
@@ -513,7 +524,8 @@ class Hub(WaitOperationsGreenlet):
...
@@ -513,7 +524,8 @@ class Hub(WaitOperationsGreenlet):
def
exception_stream
(
self
):
def
exception_stream
(
self
):
"""
"""
The stream to which exceptions will be written.
The stream to which exceptions will be written.
Defaults to ``sys.stderr`` unless assigned to.
Defaults to ``sys.stderr`` unless assigned. Assigning a
false (None) value disables printing exceptions.
.. versionadded:: 1.2a1
.. versionadded:: 1.2a1
"""
"""
...
...
src/gevent/subprocess.py
View file @
625c88b0
...
@@ -49,8 +49,9 @@ from gevent._compat import PY36
...
@@ -49,8 +49,9 @@ from gevent._compat import PY36
from
gevent._compat
import
PY37
from
gevent._compat
import
PY37
from
gevent._compat
import
PY38
from
gevent._compat
import
PY38
from
gevent._compat
import
reraise
from
gevent._compat
import
reraise
from
gevent._compat
import
fs
path
from
gevent._compat
import
fs
decode
from
gevent._compat
import
fsencode
from
gevent._compat
import
fsencode
from
gevent._compat
import
PathLike
from
gevent._util
import
_NONE
from
gevent._util
import
_NONE
from
gevent._util
import
copy_globals
from
gevent._util
import
copy_globals
...
@@ -648,7 +649,7 @@ class Popen(object):
...
@@ -648,7 +649,7 @@ class Popen(object):
# Convert here for the sake of all platforms. os.chdir accepts
# Convert here for the sake of all platforms. os.chdir accepts
# path-like objects natively under 3.6, but CreateProcess
# path-like objects natively under 3.6, but CreateProcess
# doesn't.
# doesn't.
cwd
=
fs
path
(
cwd
)
if
cwd
is
not
None
else
None
cwd
=
fs
decode
(
cwd
)
if
cwd
is
not
None
else
None
try
:
try
:
self
.
_execute_child
(
args
,
executable
,
preexec_fn
,
close_fds
,
self
.
_execute_child
(
args
,
executable
,
preexec_fn
,
close_fds
,
pass_fds
,
cwd
,
env
,
universal_newlines
,
pass_fds
,
cwd
,
env
,
universal_newlines
,
...
@@ -983,6 +984,22 @@ class Popen(object):
...
@@ -983,6 +984,22 @@ class Popen(object):
"""Execute program (MS Windows version)"""
"""Execute program (MS Windows version)"""
# pylint:disable=undefined-variable
# pylint:disable=undefined-variable
assert
not
pass_fds
,
"pass_fds not supported on Windows."
assert
not
pass_fds
,
"pass_fds not supported on Windows."
if
isinstance
(
args
,
str
):
pass
elif
isinstance
(
args
,
bytes
):
if
shell
and
PY3
:
raise
TypeError
(
'bytes args is not allowed on Windows'
)
args
=
list2cmdline
([
args
])
elif
isinstance
(
args
,
PathLike
):
if
shell
:
raise
TypeError
(
'path-like args is not allowed when '
'shell is true'
)
args
=
list2cmdline
([
args
])
else
:
args
=
list2cmdline
(
args
)
if
executable
is
not
None
:
executable
=
fsdecode
(
executable
)
if
not
isinstance
(
args
,
string_types
):
if
not
isinstance
(
args
,
string_types
):
args
=
list2cmdline
(
args
)
args
=
list2cmdline
(
args
)
...
@@ -990,10 +1007,15 @@ class Popen(object):
...
@@ -990,10 +1007,15 @@ class Popen(object):
# Process startup details
# Process startup details
if
startupinfo
is
None
:
if
startupinfo
is
None
:
startupinfo
=
STARTUPINFO
()
startupinfo
=
STARTUPINFO
()
elif
hasattr
(
startupinfo
,
'
_
copy'
):
elif
hasattr
(
startupinfo
,
'copy'
):
# bpo-34044: Copy STARTUPINFO since it is modified below,
# bpo-34044: Copy STARTUPINFO since it is modified below,
# so the caller can reuse it multiple times.
# so the caller can reuse it multiple times.
startupinfo
=
startupinfo
.
copy
()
elif
hasattr
(
startupinfo
,
'_copy'
):
# When the fix was backported to Python 3.7, copy() was
# made private as _copy.
startupinfo
=
startupinfo
.
_copy
()
startupinfo
=
startupinfo
.
_copy
()
use_std_handles
=
-
1
not
in
(
p2cread
,
c2pwrite
,
errwrite
)
use_std_handles
=
-
1
not
in
(
p2cread
,
c2pwrite
,
errwrite
)
if
use_std_handles
:
if
use_std_handles
:
startupinfo
.
dwFlags
|=
STARTF_USESTDHANDLES
startupinfo
.
dwFlags
|=
STARTF_USESTDHANDLES
...
@@ -1060,7 +1082,7 @@ class Popen(object):
...
@@ -1060,7 +1082,7 @@ class Popen(object):
int
(
not
close_fds
),
int
(
not
close_fds
),
creationflags
,
creationflags
,
env
,
env
,
cwd
,
cwd
,
# fsdecode handled earlier
startupinfo
)
startupinfo
)
except
IOError
as
e
:
# From 2.6 on, pywintypes.error was defined as IOError
except
IOError
as
e
:
# From 2.6 on, pywintypes.error was defined as IOError
# Translate pywintypes.error to WindowsError, which is
# Translate pywintypes.error to WindowsError, which is
...
@@ -1345,14 +1367,20 @@ class Popen(object):
...
@@ -1345,14 +1367,20 @@ class Popen(object):
args
=
[
args
]
args
=
[
args
]
elif
not
PY3
and
isinstance
(
args
,
string_types
):
elif
not
PY3
and
isinstance
(
args
,
string_types
):
args
=
[
args
]
args
=
[
args
]
elif
isinstance
(
args
,
PathLike
):
if
shell
:
raise
TypeError
(
'path-like args is not allowed when '
'shell is true'
)
args
=
[
fsencode
(
args
)]
# os.PathLike -> [str]
else
:
else
:
try
:
args
=
list
(
args
)
args
=
list
(
args
)
except
TypeError
:
# os.PathLike instead of a sequence?
args
=
[
fsencode
(
args
)]
# os.PathLike -> [str]
if
shell
:
if
shell
:
args
=
[
"/bin/sh"
,
"-c"
]
+
args
# On Android the default shell is at '/system/bin/sh'.
unix_shell
=
(
'/system/bin/sh'
if
hasattr
(
sys
,
'getandroidapilevel'
)
else
'/bin/sh'
)
args
=
[
unix_shell
,
"-c"
]
+
args
if
executable
:
if
executable
:
args
[
0
]
=
executable
args
[
0
]
=
executable
...
...
src/gevent/testing/monkey_test.py
View file @
625c88b0
...
@@ -24,6 +24,7 @@ from .patched_tests_setup import disable_tests_in_source
...
@@ -24,6 +24,7 @@ from .patched_tests_setup import disable_tests_in_source
from
.
import
support
from
.
import
support
from
.
import
resources
from
.
import
resources
from
.
import
SkipTest
from
.
import
SkipTest
from
.
import
util
if
RUNNING_ON_APPVEYOR
and
PY37
:
if
RUNNING_ON_APPVEYOR
and
PY37
:
# 3.7 added a stricter mode for thread cleanup.
# 3.7 added a stricter mode for thread cleanup.
...
@@ -42,6 +43,15 @@ if RUNNING_ON_APPVEYOR and PY37:
...
@@ -42,6 +43,15 @@ if RUNNING_ON_APPVEYOR and PY37:
# Configure allowed resources
# Configure allowed resources
resources
.
setup_resources
()
resources
.
setup_resources
()
if
not
os
.
path
.
exists
(
test_filename
)
and
os
.
sep
not
in
test_filename
:
# A simple filename, given without a path, that doesn't exist.
# So we change to the appropriate directory, if we can find it.
# This happens when copy-pasting the output of the testrunner
for
d
in
util
.
find_stdlib_tests
():
if
os
.
path
.
exists
(
os
.
path
.
join
(
d
,
test_filename
)):
os
.
chdir
(
d
)
break
__file__
=
os
.
path
.
join
(
os
.
getcwd
(),
test_filename
)
__file__
=
os
.
path
.
join
(
os
.
getcwd
(),
test_filename
)
test_name
=
os
.
path
.
splitext
(
test_filename
)[
0
]
test_name
=
os
.
path
.
splitext
(
test_filename
)[
0
]
...
...
src/gevent/testing/openfiles.py
View file @
625c88b0
...
@@ -108,9 +108,32 @@ else:
...
@@ -108,9 +108,32 @@ else:
(socket.listen(1)). Unlike the lsof implementation, this will only
(socket.listen(1)). Unlike the lsof implementation, this will only
return sockets in a state like that.
return sockets in a state like that.
"""
"""
# We've seen OSError: No such file or directory
# /proc/PID/fd/NUM. This occurs in the loop that checks open
# files. It first does listdir() and then tries readlink() on
# each file. But the file went away. This must be because of
# async GC in PyPy running destructors at arbitrary times.
# This became an issue in PyPy 7.2 but could theoretically be
# an issue with any objects caught in a cycle. Try to clean
# that up before we begin.
import
gc
gc
.
collect
()
gc
.
collect
()
results
=
dict
()
results
=
dict
()
gc
.
disable
()
try
:
for
_
in
range
(
3
):
try
:
process
=
psutil
.
Process
()
process
=
psutil
.
Process
()
results
[
'data'
]
=
process
.
open_files
()
+
process
.
connections
(
'all'
)
results
[
'data'
]
=
process
.
open_files
()
+
process
.
connections
(
'all'
)
break
except
OSError
:
pass
else
:
# No break executed
raise
unittest
.
SkipTest
(
"Unable to read open files"
)
finally
:
gc
.
enable
()
for
x
in
results
[
'data'
]:
for
x
in
results
[
'data'
]:
results
[
x
.
fd
]
=
x
results
[
x
.
fd
]
=
x
results
[
'data'
]
+=
[
'From psutil'
,
process
]
results
[
'data'
]
+=
[
'From psutil'
,
process
]
...
...
src/gevent/testing/sysinfo.py
View file @
625c88b0
...
@@ -137,3 +137,16 @@ RESOLVER_ARES = os.getenv('GEVENT_RESOLVER') == 'ares'
...
@@ -137,3 +137,16 @@ RESOLVER_ARES = os.getenv('GEVENT_RESOLVER') == 'ares'
RESOLVER_DNSPYTHON
=
os
.
getenv
(
'GEVENT_RESOLVER'
)
==
'dnspython'
RESOLVER_DNSPYTHON
=
os
.
getenv
(
'GEVENT_RESOLVER'
)
==
'dnspython'
RESOLVER_NOT_SYSTEM
=
RESOLVER_ARES
or
RESOLVER_DNSPYTHON
RESOLVER_NOT_SYSTEM
=
RESOLVER_ARES
or
RESOLVER_DNSPYTHON
def
get_python_version
():
"""
Return a string of the simple python version,
such as '3.8.0b4'. Handles alpha and beta and final releases.
"""
version
=
'%s.%s.%s'
%
sys
.
version_info
[:
3
]
if
sys
.
version_info
[
3
]
==
'alpha'
:
version
+=
'a%s'
%
sys
.
version_info
[
4
]
elif
sys
.
version_info
[
3
]
==
'beta'
:
version
+=
'b%s'
%
sys
.
version_info
[
4
]
return
version
src/gevent/testing/util.py
View file @
625c88b0
...
@@ -418,6 +418,40 @@ def search_for_setup_py(a_file=None, a_module_name=None, a_class=None, climb_cwd
...
@@ -418,6 +418,40 @@ def search_for_setup_py(a_file=None, a_module_name=None, a_class=None, climb_cwd
raise
NoSetupPyFound
(
"After checking %r"
%
(
locals
(),))
raise
NoSetupPyFound
(
"After checking %r"
%
(
locals
(),))
def
_version_dir_components
():
directory
=
'%s.%s'
%
sys
.
version_info
[:
2
]
full_directory
=
'%s.%s.%s'
%
sys
.
version_info
[:
3
]
if
hasattr
(
sys
,
'pypy_version_info'
):
directory
+=
'pypy'
full_directory
+=
'pypy'
return
directory
,
full_directory
def
find_stdlib_tests
():
"""
Return a sequence of directories that could contain
stdlib tests for the running version of Python.
The most specific tests are at the end of the sequence.
No checks are performed on existence of the directories.
"""
setup_py
=
search_for_setup_py
(
a_file
=
__file__
)
greentest
=
os
.
path
.
join
(
setup_py
,
'src'
,
'greentest'
)
directory
,
full_directory
=
_version_dir_components
()
directory
=
'%s.%s'
%
sys
.
version_info
[:
2
]
full_directory
=
'%s.%s.%s'
%
sys
.
version_info
[:
3
]
if
hasattr
(
sys
,
'pypy_version_info'
):
directory
+=
'pypy'
full_directory
+=
'pypy'
directory
=
os
.
path
.
join
(
greentest
,
directory
)
full_directory
=
os
.
path
.
join
(
greentest
,
full_directory
)
return
directory
,
full_directory
class
ExampleMixin
(
object
):
class
ExampleMixin
(
object
):
"Something that uses the examples/ directory"
"Something that uses the examples/ directory"
...
...
src/gevent/tests/test___monkey_patching.py
View file @
625c88b0
...
@@ -6,35 +6,12 @@ import atexit
...
@@ -6,35 +6,12 @@ import atexit
# subprocess: include in subprocess tests
# subprocess: include in subprocess tests
from
gevent.testing
import
util
from
gevent.testing
import
util
from
gevent.testing
import
sysinfo
TIMEOUT
=
120
TIMEOUT
=
120
# XXX: Generalize this so other packages can use it.
# XXX: Generalize this so other packages can use it.
def
find_stdlib_tests
():
setup_py
=
util
.
search_for_setup_py
(
a_file
=
__file__
)
greentest
=
os
.
path
.
join
(
setup_py
,
'src'
,
'greentest'
)
directory
=
'%s.%s'
%
sys
.
version_info
[:
2
]
full_directory
=
'%s.%s.%s'
%
sys
.
version_info
[:
3
]
if
hasattr
(
sys
,
'pypy_version_info'
):
directory
+=
'pypy'
full_directory
+=
'pypy'
directory
=
os
.
path
.
join
(
greentest
,
directory
)
full_directory
=
os
.
path
.
join
(
greentest
,
full_directory
)
return
directory
,
full_directory
def
get_python_version
():
version
=
'%s.%s.%s'
%
sys
.
version_info
[:
3
]
if
sys
.
version_info
[
3
]
==
'alpha'
:
version
+=
'a%s'
%
sys
.
version_info
[
4
]
elif
sys
.
version_info
[
3
]
==
'beta'
:
version
+=
'b%s'
%
sys
.
version_info
[
4
]
return
version
def
get_absolute_pythonpath
():
def
get_absolute_pythonpath
():
paths
=
[
os
.
path
.
abspath
(
p
)
for
p
in
os
.
environ
.
get
(
'PYTHONPATH'
,
''
).
split
(
os
.
pathsep
)]
paths
=
[
os
.
path
.
abspath
(
p
)
for
p
in
os
.
environ
.
get
(
'PYTHONPATH'
,
''
).
split
(
os
.
pathsep
)]
...
@@ -43,7 +20,7 @@ def get_absolute_pythonpath():
...
@@ -43,7 +20,7 @@ def get_absolute_pythonpath():
def
TESTRUNNER
(
tests
=
None
):
def
TESTRUNNER
(
tests
=
None
):
try
:
try
:
test_dir
,
version_test_dir
=
find_stdlib_tests
()
test_dir
,
version_test_dir
=
util
.
find_stdlib_tests
()
except
util
.
NoSetupPyFound
as
e
:
except
util
.
NoSetupPyFound
as
e
:
util
.
log
(
"WARNING: No setup.py and src/greentest found: %r"
,
e
,
util
.
log
(
"WARNING: No setup.py and src/greentest found: %r"
,
e
,
color
=
"suboptimal-behaviour"
)
color
=
"suboptimal-behaviour"
)
...
@@ -57,7 +34,7 @@ def TESTRUNNER(tests=None):
...
@@ -57,7 +34,7 @@ def TESTRUNNER(tests=None):
with
open
(
os
.
path
.
join
(
test_dir
,
'version'
))
as
f
:
with
open
(
os
.
path
.
join
(
test_dir
,
'version'
))
as
f
:
preferred_version
=
f
.
read
().
strip
()
preferred_version
=
f
.
read
().
strip
()
running_version
=
get_python_version
()
running_version
=
sysinfo
.
get_python_version
()
if
preferred_version
!=
running_version
:
if
preferred_version
!=
running_version
:
util
.
log
(
'WARNING: The tests in %s/ are from version %s and your Python is %s'
,
util
.
log
(
'WARNING: The tests in %s/ are from version %s and your Python is %s'
,
test_dir
,
preferred_version
,
running_version
,
test_dir
,
preferred_version
,
running_version
,
...
...
src/gevent/tests/test__makefile_ref.py
View file @
625c88b0
...
@@ -110,49 +110,40 @@ class Test(greentest.TestCase):
...
@@ -110,49 +110,40 @@ class Test(greentest.TestCase):
def
make_open_socket
(
self
):
def
make_open_socket
(
self
):
s
=
socket
.
socket
()
s
=
socket
.
socket
()
try
:
s
.
bind
(
DEFAULT_BIND_ADDR_TUPLE
)
s
.
bind
(
DEFAULT_BIND_ADDR_TUPLE
)
self
.
_close_on_teardown
(
s
)
if
WIN
or
greentest
.
LINUX
:
if
WIN
or
greentest
.
LINUX
:
# Windows and linux (with psutil) doesn't show as open until
# Windows and linux (with psutil) doesn't show as open until
# we call listen (linux with lsof accepts either)
# we call listen (linux with lsof accepts either)
s
.
listen
(
1
)
s
.
listen
(
1
)
self
.
assert_open
(
s
,
s
.
fileno
())
self
.
assert_open
(
s
,
s
.
fileno
())
except
:
s
.
close
()
s
=
None
raise
return
s
return
s
if
CPYTHON
and
PY2
:
# Keeping raw sockets alive keeps SSL sockets
# from being closed too, at least on CPython2, so we
# need to use weakrefs.
# In contrast, on PyPy, *only* having a weakref lets the
# original socket die and leak
def
_close_on_teardown
(
self
,
resource
):
self
.
close_on_teardown
.
append
(
weakref
.
ref
(
resource
))
return
resource
def
_tearDownCloseOnTearDown
(
self
):
self
.
close_on_teardown
=
[
r
()
for
r
in
self
.
close_on_teardown
if
r
()
is
not
None
]
super
(
Test
,
self
).
_tearDownCloseOnTearDown
()
# Sometimes its this one, sometimes it's test_ssl. No clue why or how.
# Sometimes its this one, sometimes it's test_ssl. No clue why or how.
@
greentest
.
skipOnAppVeyor
(
"This sometimes times out for no apparent reason."
)
@
greentest
.
skipOnAppVeyor
(
"This sometimes times out for no apparent reason."
)
class
TestSocket
(
Test
):
class
TestSocket
(
Test
):
def
test_simple_close
(
self
):
def
test_simple_close
(
self
):
s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
closer
(
self
.
make_open_socket
())
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
s
.
close
()
s
.
close
()
self
.
assert_closed
(
s
,
fileno
)
self
.
assert_closed
(
s
,
fileno
)
def
test_makefile1
(
self
):
def
test_makefile1
(
self
):
s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
closer
(
self
.
make_open_socket
())
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
f
=
s
.
makefile
()
f
=
closer
(
s
.
makefile
())
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
s
.
close
()
# Under python 2, this closes socket wrapper object but not the file descriptor;
# Under python 2, this closes socket wrapper object but not the file descriptor;
# under python 3, both stay open
# under python 3, both stay open
s
.
close
()
if
PY3
:
if
PY3
:
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
else
:
else
:
...
@@ -163,10 +154,11 @@ class TestSocket(Test):
...
@@ -163,10 +154,11 @@ class TestSocket(Test):
self
.
assert_closed
(
fileno
)
self
.
assert_closed
(
fileno
)
def
test_makefile2
(
self
):
def
test_makefile2
(
self
):
s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
closer
(
self
.
make_open_socket
())
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
f
=
s
.
makefile
(
)
f
=
closer
(
s
.
makefile
()
)
self
.
assert_open
(
s
)
self
.
assert_open
(
s
)
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
f
.
close
()
f
.
close
()
...
@@ -176,46 +168,39 @@ class TestSocket(Test):
...
@@ -176,46 +168,39 @@ class TestSocket(Test):
self
.
assert_closed
(
s
,
fileno
)
self
.
assert_closed
(
s
,
fileno
)
def
test_server_simple
(
self
):
def
test_server_simple
(
self
):
listener
=
tcp_listener
(
backlog
=
1
)
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
def
connect
():
def
connect
():
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
t
=
threading
.
Thread
(
target
=
connect
)
closer
.
running_task
(
threading
.
Thread
(
target
=
connect
))
t
.
start
()
try
:
client_socket
=
closer
.
accept
(
listener
)
client_socket
,
_addr
=
listener
.
accept
()
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
self
.
assert_closed
(
client_socket
)
self
.
assert_closed
(
client_socket
)
finally
:
t
.
join
()
listener
.
close
()
connector
.
close
()
def
test_server_makefile1
(
self
):
def
test_server_makefile1
(
self
):
listener
=
tcp_listener
(
backlog
=
1
)
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
def
connect
():
def
connect
():
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
t
=
threading
.
Thread
(
target
=
connect
)
closer
.
running_task
(
threading
.
Thread
(
target
=
connect
))
t
.
start
()
try
:
client_socket
,
_addr
=
listener
.
accept
(
)
client_socket
=
closer
.
accept
(
listener
)
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
f
=
cl
ient_socket
.
makefile
(
)
f
=
cl
oser
(
client_socket
.
makefile
()
)
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
# Under python 2, this closes socket wrapper object but not the file descriptor;
# Under python 2, this closes socket wrapper object but not the file descriptor;
...
@@ -227,38 +212,28 @@ class TestSocket(Test):
...
@@ -227,38 +212,28 @@ class TestSocket(Test):
self
.
assert_open
(
fileno
)
self
.
assert_open
(
fileno
)
f
.
close
()
f
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
t
.
join
()
listener
.
close
()
connector
.
close
()
def
test_server_makefile2
(
self
):
def
test_server_makefile2
(
self
):
listener
=
tcp_listener
(
backlog
=
1
)
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
def
connect
():
def
connect
():
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
connector
.
connect
((
DEFAULT_CONNECT
,
port
))
t
=
threading
.
Thread
(
target
=
connect
)
closer
.
running_task
(
threading
.
Thread
(
target
=
connect
)
)
t
.
start
(
)
client_socket
=
closer
.
accept
(
listener
)
try
:
client_socket
,
_addr
=
listener
.
accept
()
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
f
=
cl
ient_socket
.
makefile
(
)
f
=
cl
oser
(
client_socket
.
makefile
()
)
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
# closing fileobject does not close the socket
# closing fileobject does not close the socket
f
.
close
()
f
.
close
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
t
.
join
()
listener
.
close
()
connector
.
close
()
@
greentest
.
skipOnAppVeyor
(
"This sometimes times out for no apparent reason."
)
@
greentest
.
skipOnAppVeyor
(
"This sometimes times out for no apparent reason."
)
...
@@ -281,7 +256,6 @@ class TestSSL(Test):
...
@@ -281,7 +256,6 @@ class TestSSL(Test):
# our socket first, so this fails.
# our socket first, so this fails.
pass
pass
else
:
else
:
#self._close_on_teardown(x)
x
.
close
()
x
.
close
()
def
_make_ssl_connect_task
(
self
,
connector
,
port
):
def
_make_ssl_connect_task
(
self
,
connector
,
port
):
...
@@ -292,53 +266,24 @@ class TestSSL(Test):
...
@@ -292,53 +266,24 @@ class TestSSL(Test):
t
.
accepted_event
=
accepted_event
t
.
accepted_event
=
accepted_event
return
t
return
t
def
__cleanup
(
self
,
task
,
*
sockets
):
# workaround for test_server_makefile1, test_server_makefile2,
# test_server_simple, test_serverssl_makefile1.
# On PyPy on Linux, it is important to join the SSL Connect
# Task FIRST, before closing the sockets. If we do it after
# (which makes more sense) we hang. It's not clear why, except
# that it has something to do with context switches. Inserting a call to
# gevent.sleep(0.1) instead of joining the task has the same
# effect. If the previous tests hang, then later tests can fail with
# SSLError: unknown alert type.
# XXX: Why do those two things happen?
# On PyPy on macOS, we don't have that problem and can use the
# more logical order.
task
.
join
()
for
s
in
sockets
:
try
:
close
=
s
.
close
except
AttributeError
:
continue
else
:
close
()
del
sockets
del
task
def
test_simple_close
(
self
):
def
test_simple_close
(
self
):
s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
closer
(
self
.
make_open_socket
())
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
s
=
ssl
.
wrap_socket
(
s
)
s
=
closer
(
ssl
.
wrap_socket
(
s
))
self
.
_close_on_teardown
(
s
)
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
s
.
close
()
s
.
close
()
self
.
assert_closed
(
s
,
fileno
)
self
.
assert_closed
(
s
,
fileno
)
def
test_makefile1
(
self
):
def
test_makefile1
(
self
):
raw_s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
ssl
.
wrap_socket
(
raw_s
)
raw_s
=
closer
(
self
.
make_open_socket
())
s
=
closer
(
ssl
.
wrap_socket
(
raw_s
))
self
.
_close_on_teardown
(
s
)
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
f
=
s
.
makefile
(
)
f
=
closer
(
s
.
makefile
()
)
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
s
.
close
()
s
.
close
()
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
...
@@ -346,16 +291,15 @@ class TestSSL(Test):
...
@@ -346,16 +291,15 @@ class TestSSL(Test):
raw_s
.
close
()
raw_s
.
close
()
self
.
assert_closed
(
s
,
fileno
)
self
.
assert_closed
(
s
,
fileno
)
def
test_makefile2
(
self
):
def
test_makefile2
(
self
):
s
=
self
.
make_open_socket
()
with
Closing
()
as
closer
:
s
=
closer
(
self
.
make_open_socket
())
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
s
=
ssl
.
wrap_socket
(
s
)
s
=
closer
(
ssl
.
wrap_socket
(
s
))
self
.
_close_on_teardown
(
s
)
fileno
=
s
.
fileno
()
fileno
=
s
.
fileno
()
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
f
=
s
.
makefile
(
)
f
=
closer
(
s
.
makefile
()
)
self
.
assert_open
(
s
,
fileno
)
self
.
assert_open
(
s
,
fileno
)
f
.
close
()
f
.
close
()
# closing fileobject does not close the socket
# closing fileobject does not close the socket
...
@@ -364,44 +308,40 @@ class TestSSL(Test):
...
@@ -364,44 +308,40 @@ class TestSSL(Test):
self
.
assert_closed
(
s
,
fileno
)
self
.
assert_closed
(
s
,
fileno
)
def
test_server_simple
(
self
):
def
test_server_simple
(
self
):
listener
=
tcp_listener
(
backlog
=
1
)
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
.
start
(
)
closer
.
running_task
(
t
)
try
:
client_socket
=
closer
.
accept
(
listener
)
client_socket
,
_addr
=
listener
.
accept
()
t
.
accepted_event
.
set
()
t
.
accepted_event
.
set
()
self
.
_close_on_teardown
(
client_socket
.
close
)
client_socket
=
closer
(
client_socket
=
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
server_side
=
True
)
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
self
.
_close_on_teardown
(
client_socket
)
server_side
=
True
)
)
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
self
.
__cleanup
(
t
,
listener
,
connector
)
def
test_server_makefile1
(
self
):
def
test_server_makefile1
(
self
):
listener
=
self
.
_close_on_teardown
(
tcp_listener
(
backlog
=
1
))
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
.
start
(
)
closer
.
running_task
(
t
)
try
:
client_socket
=
closer
.
accept
(
listener
)
client_socket
,
_addr
=
listener
.
accept
()
t
.
accepted_event
.
set
()
t
.
accepted_event
.
set
()
self
.
_close_on_teardown
(
client_socket
.
close
)
# hard ref
client_socket
=
closer
(
client_socket
=
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
server_side
=
True
)
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
self
.
_close_on_teardown
(
client_socket
)
server_side
=
True
)
)
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
f
=
client_socket
.
makefile
()
f
=
client_socket
.
makefile
()
...
@@ -410,26 +350,22 @@ class TestSSL(Test):
...
@@ -410,26 +350,22 @@ class TestSSL(Test):
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
f
.
close
()
f
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
self
.
__cleanup
(
t
,
listener
,
connector
)
def
test_server_makefile2
(
self
):
def
test_server_makefile2
(
self
):
listener
=
tcp_listener
(
backlog
=
1
)
with
Closing
()
as
closer
:
listener
=
closer
(
tcp_listener
(
backlog
=
1
))
port
=
listener
.
getsockname
()[
1
]
port
=
listener
.
getsockname
()[
1
]
connector
=
socket
.
socket
()
connector
=
closer
(
socket
.
socket
())
self
.
_close_on_teardown
(
connector
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
.
start
(
)
closer
.
running_task
(
t
)
try
:
client_socket
,
_addr
=
listener
.
accept
()
t
.
accepted_event
.
set
()
t
.
accepted_event
.
set
()
self
.
_close_on_teardown
(
client_socket
)
client_socket
=
closer
.
accept
(
listener
)
client_socket
=
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
server_side
=
True
)
client_socket
=
closer
(
self
.
_close_on_teardown
(
client_socket
)
ssl
.
wrap_socket
(
client_socket
,
keyfile
=
certfile
,
certfile
=
certfile
,
server_side
=
True
))
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
f
=
client_socket
.
makefile
()
f
=
client_socket
.
makefile
()
...
@@ -439,23 +375,18 @@ class TestSSL(Test):
...
@@ -439,23 +375,18 @@ class TestSSL(Test):
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
self
.
__cleanup
(
t
,
connector
,
listener
,
client_socket
)
def
test_serverssl_makefile1
(
self
):
def
test_serverssl_makefile1
(
self
):
listener
=
self
.
_close_on_teardown
(
tcp_listener
(
backlog
=
1
)
)
raw_listener
=
tcp_listener
(
backlog
=
1
)
fileno
=
listener
.
fileno
()
fileno
=
raw_
listener
.
fileno
()
port
=
listener
.
getsockname
()[
1
]
port
=
raw_
listener
.
getsockname
()[
1
]
listener
=
ssl
.
wrap_socket
(
listener
,
keyfile
=
certfile
,
certfile
=
certfile
)
listener
=
ssl
.
wrap_socket
(
raw_
listener
,
keyfile
=
certfile
,
certfile
=
certfile
)
connector
=
socket
.
socket
()
connector
=
socket
.
socket
()
self
.
_close_on_teardown
(
connector
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
=
self
.
_make_ssl_connect_task
(
connector
,
port
)
t
.
start
()
t
.
start
()
try
:
with
CleaningUp
(
t
,
listener
,
raw_listener
,
connector
)
as
client_socket
:
client_socket
,
_addr
=
listener
.
accept
()
t
.
accepted_event
.
set
()
t
.
accepted_event
.
set
()
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
...
@@ -465,13 +396,11 @@ class TestSSL(Test):
...
@@ -465,13 +396,11 @@ class TestSSL(Test):
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
f
.
close
()
f
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
finally
:
self
.
__cleanup
(
t
,
listener
,
connector
)
def
test_serverssl_makefile2
(
self
):
def
test_serverssl_makefile2
(
self
):
listener
=
self
.
_close_on_teardown
(
tcp_listener
(
backlog
=
1
)
)
raw_listener
=
tcp_listener
(
backlog
=
1
)
port
=
listener
.
getsockname
()[
1
]
port
=
raw_
listener
.
getsockname
()[
1
]
listener
=
ssl
.
wrap_socket
(
listener
,
keyfile
=
certfile
,
certfile
=
certfile
)
listener
=
ssl
.
wrap_socket
(
raw_
listener
,
keyfile
=
certfile
,
certfile
=
certfile
)
accepted_event
=
threading
.
Event
()
accepted_event
=
threading
.
Event
()
def
connect
(
connector
=
socket
.
socket
()):
def
connect
(
connector
=
socket
.
socket
()):
...
@@ -489,8 +418,7 @@ class TestSSL(Test):
...
@@ -489,8 +418,7 @@ class TestSSL(Test):
t
.
daemon
=
True
t
.
daemon
=
True
t
.
start
()
t
.
start
()
client_socket
=
None
client_socket
=
None
try
:
with
CleaningUp
(
t
,
listener
,
raw_listener
)
as
client_socket
:
client_socket
,
_addr
=
listener
.
accept
()
accepted_event
.
set
()
accepted_event
.
set
()
fileno
=
client_socket
.
fileno
()
fileno
=
client_socket
.
fileno
()
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
...
@@ -505,8 +433,98 @@ class TestSSL(Test):
...
@@ -505,8 +433,98 @@ class TestSSL(Test):
self
.
assert_open
(
client_socket
,
fileno
)
self
.
assert_open
(
client_socket
,
fileno
)
client_socket
.
close
()
client_socket
.
close
()
self
.
assert_closed
(
client_socket
,
fileno
)
self
.
assert_closed
(
client_socket
,
fileno
)
class
Closing
(
object
):
def
__init__
(
self
,
*
init
):
self
.
_objects
=
[]
for
i
in
init
:
self
.
closing
(
i
)
self
.
task
=
None
def
accept
(
self
,
listener
):
client_socket
,
_addr
=
listener
.
accept
()
return
self
.
closing
(
client_socket
)
def
__enter__
(
self
):
o
=
self
.
objects
()
if
len
(
o
)
==
1
:
return
o
[
0
]
return
self
if
PY2
and
CPYTHON
:
# This implementation depends or refcounting
# for things to close. Eww.
def
closing
(
self
,
o
):
self
.
_objects
.
append
(
weakref
.
ref
(
o
))
return
o
def
objects
(
self
):
return
[
r
()
for
r
in
self
.
_objects
if
r
()
is
not
None
]
else
:
def
objects
(
self
):
# PyPy returns an object without __len__...
return
list
(
reversed
(
self
.
_objects
))
def
closing
(
self
,
o
):
self
.
_objects
.
append
(
o
)
return
o
__call__
=
closing
def
running_task
(
self
,
thread
):
assert
self
.
task
is
None
self
.
task
=
thread
self
.
task
.
start
()
return
self
.
task
def
__exit__
(
self
,
t
,
v
,
tb
):
# workaround for test_server_makefile1, test_server_makefile2,
# test_server_simple, test_serverssl_makefile1.
# On PyPy on Linux, it is important to join the SSL Connect
# Task FIRST, before closing the sockets. If we do it after
# (which makes more sense) we hang. It's not clear why, except
# that it has something to do with context switches. Inserting a call to
# gevent.sleep(0.1) instead of joining the task has the same
# effect. If the previous tests hang, then later tests can fail with
# SSLError: unknown alert type.
# XXX: Why do those two things happen?
# On PyPy on macOS, we don't have that problem and can use the
# more logical order.
try
:
if
self
.
task
is
not
None
:
self
.
task
.
join
()
finally
:
self
.
task
=
None
for
o
in
self
.
objects
():
try
:
o
.
close
()
except
Exception
:
# pylint:disable=broad-except
pass
self
.
_objects
=
()
class
CleaningUp
(
Closing
):
def
__init__
(
self
,
task
,
listener
,
*
other_sockets
):
super
(
CleaningUp
,
self
).
__init__
(
listener
,
*
other_sockets
)
self
.
task
=
task
self
.
listener
=
listener
def
__enter__
(
self
):
return
self
.
accept
(
self
.
listener
)
def
__exit__
(
self
,
t
,
v
,
tb
):
try
:
Closing
.
__exit__
(
self
,
t
,
v
,
tb
)
finally
:
finally
:
self
.
__cleanup
(
t
,
listener
,
client_socket
)
self
.
listener
=
None
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
...
...
src/gevent/tests/test__monkey_sigchld.py
View file @
625c88b0
import
errno
import
errno
import
os
import
os
import
sys
import
sys
#os.environ['GEVENT_NOWAITPID'] = 'True'
import
gevent
import
gevent
import
gevent.monkey
import
gevent.monkey
...
@@ -19,8 +18,27 @@ def handle_sigchld(*_args):
...
@@ -19,8 +18,27 @@ def handle_sigchld(*_args):
# Raise an ignored error
# Raise an ignored error
raise
TypeError
(
"This should be ignored but printed"
)
raise
TypeError
(
"This should be ignored but printed"
)
# Try to produce output compatible with unittest output so
# our status parsing functions work.
import
signal
import
signal
if
hasattr
(
signal
,
'SIGCHLD'
):
if
hasattr
(
signal
,
'SIGCHLD'
):
# In Python 3.8.0 final, on both Travis CI/Linux and locally
# on macOS, the *child* process started crashing on exit with a memory
# error:
#
# Debug memory block at address p=0x7fcf5d6b5000: API ''
# 6508921152173528397 bytes originally requested
# The 7 pad bytes at p-7 are not all FORBIDDENBYTE (0xfd):
#
# When PYTHONDEVMODE is set. This happens even if we just simply fork
# the child process and don't have gevent even /imported/ in the most
# minimal test case. It's not clear what caused that.
if
sys
.
version_info
[:
2
]
>=
(
3
,
8
)
and
os
.
environ
.
get
(
"PYTHONDEVMODE"
):
print
(
"Ran 1 tests in 0.0s (skipped=1)"
)
sys
.
exit
(
0
)
assert
signal
.
getsignal
(
signal
.
SIGCHLD
)
==
signal
.
SIG_DFL
assert
signal
.
getsignal
(
signal
.
SIGCHLD
)
==
signal
.
SIG_DFL
signal
.
signal
(
signal
.
SIGCHLD
,
handle_sigchld
)
signal
.
signal
(
signal
.
SIGCHLD
,
handle_sigchld
)
handler
=
signal
.
getsignal
(
signal
.
SIGCHLD
)
handler
=
signal
.
getsignal
(
signal
.
SIGCHLD
)
...
@@ -64,6 +82,8 @@ if hasattr(signal, 'SIGCHLD'):
...
@@ -64,6 +82,8 @@ if hasattr(signal, 'SIGCHLD'):
raise
AssertionError
(
"Failed to wait using"
,
func
)
raise
AssertionError
(
"Failed to wait using"
,
func
)
finally
:
finally
:
timeout
.
close
()
timeout
.
close
()
print
(
"Ran 1 tests in 0.0s"
)
sys
.
exit
(
0
)
sys
.
exit
(
0
)
else
:
else
:
print
(
"No SIGCHLD, not testing"
)
print
(
"No SIGCHLD, not testing"
)
print
(
"Ran 1 tests in 0.0s (skipped=1)"
)
src/gevent/tests/test__monkey_sigchld_2.py
View file @
625c88b0
...
@@ -16,6 +16,11 @@ def handle(*_args):
...
@@ -16,6 +16,11 @@ def handle(*_args):
os
.
waitpid
(
-
1
,
os
.
WNOHANG
)
os
.
waitpid
(
-
1
,
os
.
WNOHANG
)
# The signal watcher must be installed *before* monkey patching
# The signal watcher must be installed *before* monkey patching
if
hasattr
(
signal
,
'SIGCHLD'
):
if
hasattr
(
signal
,
'SIGCHLD'
):
if
sys
.
version_info
[:
2
]
>=
(
3
,
8
)
and
os
.
environ
.
get
(
"PYTHONDEVMODE"
):
# See test__monkey_sigchld.py
print
(
"Ran 1 tests in 0.0s (skipped=1)"
)
sys
.
exit
(
0
)
# On Python 2, the signal handler breaks the platform
# On Python 2, the signal handler breaks the platform
# module, because it uses os.popen. pkg_resources uses the platform
# module, because it uses os.popen. pkg_resources uses the platform
# module.
# module.
...
...
src/gevent/tests/test__monkey_sigchld_3.py
View file @
625c88b0
...
@@ -25,6 +25,11 @@ def _waitpid(p):
...
@@ -25,6 +25,11 @@ def _waitpid(p):
assert
stat
==
0
,
stat
assert
stat
==
0
,
stat
if
hasattr
(
signal
,
'SIGCHLD'
):
if
hasattr
(
signal
,
'SIGCHLD'
):
if
sys
.
version_info
[:
2
]
>=
(
3
,
8
)
and
os
.
environ
.
get
(
"PYTHONDEVMODE"
):
# See test__monkey_sigchld.py
print
(
"Ran 1 tests in 0.0s (skipped=1)"
)
sys
.
exit
(
0
)
# Do what subprocess does and make sure we have the watcher
# Do what subprocess does and make sure we have the watcher
# in the parent
# in the parent
get_hub
().
loop
.
install_sigchld
()
get_hub
().
loop
.
install_sigchld
()
...
@@ -50,3 +55,4 @@ if hasattr(signal, 'SIGCHLD'):
...
@@ -50,3 +55,4 @@ if hasattr(signal, 'SIGCHLD'):
sys
.
exit
(
0
)
sys
.
exit
(
0
)
else
:
else
:
print
(
"No SIGCHLD, not testing"
)
print
(
"No SIGCHLD, not testing"
)
print
(
"Ran 1 tests in 0.0s (skipped=1)"
)
src/gevent/tests/test__pywsgi.py
View file @
625c88b0
...
@@ -636,11 +636,11 @@ class TestChunkedPost(TestCase):
...
@@ -636,11 +636,11 @@ class TestChunkedPost(TestCase):
return
[
data
]
return
[
data
]
if
env
[
'PATH_INFO'
]
==
'/b'
:
if
env
[
'PATH_INFO'
]
==
'/b'
:
lines
=
[
x
for
x
in
iter
(
lambda
:
env
[
'wsgi.input'
].
read
(
6
),
b''
)]
lines
=
list
(
iter
(
lambda
:
env
[
'wsgi.input'
].
read
(
6
),
b''
))
return
lines
return
lines
if
env
[
'PATH_INFO'
]
==
'/c'
:
if
env
[
'PATH_INFO'
]
==
'/c'
:
return
[
x
for
x
in
iter
(
lambda
:
env
[
'wsgi.input'
].
read
(
1
),
b''
)]
return
list
(
iter
(
lambda
:
env
[
'wsgi.input'
].
read
(
1
),
b''
))
def
test_014_chunked_post
(
self
):
def
test_014_chunked_post
(
self
):
data
=
(
b'POST /a HTTP/1.1
\
r
\
n
Host: localhost
\
r
\
n
Connection: close
\
r
\
n
'
data
=
(
b'POST /a HTTP/1.1
\
r
\
n
Host: localhost
\
r
\
n
Connection: close
\
r
\
n
'
...
...
src/gevent/tests/test__ssl.py
View file @
625c88b0
...
@@ -9,6 +9,8 @@ import gevent.testing as greentest
...
@@ -9,6 +9,8 @@ import gevent.testing as greentest
from
gevent.tests
import
test__socket
from
gevent.tests
import
test__socket
import
ssl
import
ssl
from
gevent.testing
import
PY2
def
ssl_listener
(
private_key
,
certificate
):
def
ssl_listener
(
private_key
,
certificate
):
raw_listener
=
socket
.
socket
()
raw_listener
=
socket
.
socket
()
greentest
.
bind_and_listen
(
raw_listener
)
greentest
.
bind_and_listen
(
raw_listener
)
...
@@ -24,8 +26,11 @@ class TestSSL(test__socket.TestTCP):
...
@@ -24,8 +26,11 @@ class TestSSL(test__socket.TestTCP):
# ssl.SSLError); That's gone in Py3 though. In Python 2, most timeouts are raised
# ssl.SSLError); That's gone in Py3 though. In Python 2, most timeouts are raised
# as SSLError, but Python 3 raises the normal socket.timeout instead. So this has
# as SSLError, but Python 3 raises the normal socket.timeout instead. So this has
# the effect of making TIMEOUT_ERROR be SSLError on Py2 and socket.timeout on Py3
# the effect of making TIMEOUT_ERROR be SSLError on Py2 and socket.timeout on Py3
# See https://bugs.python.org/issue10272
# See https://bugs.python.org/issue10272.
TIMEOUT_ERROR
=
getattr
(
socket
,
'sslerror'
,
socket
.
timeout
)
# PyPy3 7.2 has a bug, though: it shares much of the SSL implementation with Python 2,
# and it unconditionally does `socket.sslerror = SSLError` when ssl is imported.
# So we can't rely on getattr/hasattr tests, we must be explicit.
TIMEOUT_ERROR
=
socket
.
sslerror
if
PY2
else
socket
.
timeout
# pylint:disable=no-member
def
_setup_listener
(
self
):
def
_setup_listener
(
self
):
listener
,
raw_listener
=
ssl_listener
(
self
.
privfile
,
self
.
certfile
)
listener
,
raw_listener
=
ssl_listener
(
self
.
privfile
,
self
.
certfile
)
...
...
src/greentest/3.7/keycert.passwd.pem
View file @
625c88b0
-----BEGIN
RSA
PRIVATE KEY-----
-----BEGIN
ENCRYPTED
PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
MIIHbTBXBgkqhkiG9w0BBQ0wSjApBgkqhkiG9w0BBQwwHAQIhD+rJdxqb6ECAggA
DEK-Info: DES-EDE3-CBC,D134E931C96D9DEC
MAwGCCqGSIb3DQIJBQAwHQYJYIZIAWUDBAEqBBDTdyjCP3riOSUfxix4aXEvBIIH
ECGkbsFabrcFMZcplw5jHMaOlG7rYjUzwDJ80JM8uzbv2Jb8SvNlns2+xmnEvH/M
nuGFEej7vIjkYWSMz5OJeVTNntDRQi6ZM4DBm3g8T7i/0odr3WFqGMMKZcIhLYQf
mNvRmnXmplbVjH3XBMK8o2Psnr2V/a0j7/pgqpRxHykG+koOY4gzdt3MAg8JPbS2
rgRq7RSKtrJ1y5taVucMV+EuCjyfzDo0TsYt+ZrXv/D08eZhjRmkhoHnGVF0TqQm
hymSl+Y5EpciO3xLfz4aFL1ZNqspQbO/TD13Ij7DUIy7xIRBMp4taoZCrP0cEBAZ
nQEXM/ERT4J2RM78dnG+homMkI76qOqxgGbRqQqJo6AiVRcAZ45y8s96bru2TAB8
+wgu9m23I4dh3E8RUBzWyFFNic2MVVHrui6JbHc4dIHfyKLtXJDhUcS0vIC9PvcV
+pWjO/v0Je7AFVdwSU52N8OOY6uoSAygW+0UY1WVxbVGJF2XfRsNpPX+YQHYl6e+
jhorh3UZC4lM+/jjXV5AhzQ0VrJ2tXAUX2dA144XHzkSH2QmwfnajPsci7BL2CGC
3xM5XBVCgr6kmdAyub5qUJ38X3TpdVGoR0i+CVS9GTr2pSRib1zURAeeHnlqiUZM
rjyTy4NfB/lDwU+55dqJZQSKXMxAapJMrtgw7LD5CKQcN6zmfhXGssJ7HQUXKkaX
4m0Gn9s72nJevU1wxED8pwOhR8fnHEmMKGD2HPhKoOCbzDhwwBZO27TNa1uWeM3f
I1YOFzuUD7oo56BVCnVswv0jX9RxrE5QYNreMlOP9cS+kIYH65N+PAhlURuQC14K
M5oixKDi2PqMn3y2cDx1NjJtP661688EcJ5a2Ih9BgO9xpnhSyzBWEKcAn0tJB0H
PgDkHn5knSa2UQA5tc5f7zdHOZhGRUfcjLP+KAWA3nh+/2OKw/X3zuPx75YT/FKe
/56M0FW6cdOOIzMveGGL7sHW5E+iOdI1n5e7C6KJUzew78Y9qJnhS53EdI6qTz9R
tACPw5hjEpl62m9Xa0eWepZXwqkIOkzHMmCyNCsbC0mmRoEjmvfnslfsmnh4Dg/c
wsIsj1i070Fk6RbPo6zpLlF6w7Zj8GlZaZA7OZZv9wo5VEV/0ST8gmiiBOBc4C6Y
4YsTYMOLLIeCa+WIc38aA5W2lNO9lW0LwLhX1rP+GRVPv+TVHXlfoyaI+jp0iXrJ
u9hyLIIu4dFEBKyQHRvBnQSLNpKx6or1OGFDVBay2In9Yh2BHh1+vOj/OIz/wq48
t3xxT0gaiIR/VznyS7Py68QV/zB7VdqbsNzS7LdquHK1k8+7OYiWjY3gqyU40Iu2
EHOIV27fRJxLu4jeK5LIGDhuPnMJ8AJYQ0bQOUP6fd7p+TxWkAQZPB/Dx/cs3hx
r
d1eSnIoDvQJwyYp7XYXbOlXNLY+s1Qb7yxcW3vXm0Bg3gKT8r1XHWJ9rj+CxAn5
r
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
-----END
RSA
PRIVATE KEY-----
-----END
ENCRYPTED
PRIVATE KEY-----
-----BEGIN CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIIEWTCCAsGgAwIBAgIJAJinz4jHSjLtMA0GCSqGSIb3DQEBCwUAMF8xCzAJBgNV
MIIEWTCCAsGgAwIBAgIJAJinz4jHSjLtMA0GCSqGSIb3DQEBCwUAMF8xCzAJBgNV
BAYTAlhZMRcwFQYDVQQHDA5DYXN0bGUgQW50aHJheDEjMCEGA1UECgwaUHl0aG9u
BAYTAlhZMRcwFQYDVQQHDA5DYXN0bGUgQW50aHJheDEjMCEGA1UECgwaUHl0aG9u
...
@@ -66,3 +66,4 @@ jMqTFlmO7kpf/jpCSmamp3/JSEE1BJKHwQ6Ql4nzRA2N1mnvWH7Zxcv043gkHeAu
...
@@ -66,3 +66,4 @@ jMqTFlmO7kpf/jpCSmamp3/JSEE1BJKHwQ6Ql4nzRA2N1mnvWH7Zxcv043gkHeAu
9Wc2uXpw9xF8itV4Uvcdr3dwqByvIqn7iI/gB+4l41e0u8OmH2MKOx4Nxlly5TNW
9Wc2uXpw9xF8itV4Uvcdr3dwqByvIqn7iI/gB+4l41e0u8OmH2MKOx4Nxlly5TNW
HcVKQHyOeyvnINuBAQ==
HcVKQHyOeyvnINuBAQ==
-----END CERTIFICATE-----
-----END CERTIFICATE-----
src/greentest/3.7/ssl_key.passwd.pem
View file @
625c88b0
-----BEGIN
RSA
PRIVATE KEY-----
-----BEGIN
ENCRYPTED
PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
MIIHbTBXBgkqhkiG9w0BBQ0wSjApBgkqhkiG9w0BBQwwHAQI072N7W+PDDMCAggA
DEK-Info: DES-EDE3-CBC,8064BE1494B24B13
MAwGCCqGSIb3DQIJBQAwHQYJYIZIAWUDBAEqBBA/AuaRNi4vE4KGqI4In+70BIIH
ENGS5Vex5NID873frmd1UZEHZ+O/Bd0wDb+NUpIqesHkRYf7kKi6Gnr+nKQ/oVVn
KJrffOMbo8M0I3PzcYxRZGMpKD1yB3Ii4+bT5XoanxjIJ+4fdx6LfZ0Rsx+riyzs
Lm3JjE7c8ECP0OkOOXmiXuWL1SkzBBWqCI4stSGUPvBiHsGwNnvJAaGjUffgMlcC
tymsQu/iYY9j+4rCvN9+eetsL1X6iZpiimKsLexcid9M3fb0vxED5Sgw0dvunCUA
aJOA2+dnejLkzblq4CB2LQdm06N3Xoe9tyqtQaUHxfzJAf5Ydd8uj7vpKN2MMhY7
xhqjLIKR92MKbODHf6KrDKCpsiPbjq4gZ7P+uCGXAMHL3MXIJSC0hW9rK7Ce6oyO
icIPJwSyh0N7S6XWVtHEokr9Kp4y2hS5a+BgCWV1/1z0aF7agnSVndmT1VR+nWmc
CjpIcgB8x+GUWZZZhAFdlzIHMZrteNP2P5HK6QcaT71P034Dz1hhqoj4Q0t+Fta2
lM14k+lethmHMB+fsNSjnqeJ7XOPlOTHqhiZ9bBSTgF/xr5Bck/NiKRzHjdovBox
4tfsM/bnTR/l6hwlhPa1e3Uj322tDTDWBScgWANn5+sEWldLmozMaWhZsn22pfk2
TKg+xchaBhpRh7wBPBIlNJeHmIjv+8obOKjKU98Ig/7R9+IryZaNcKAH0PuOT+Sw
KjRMGXG024JVheV882nbdOBvG7oq+lxkZ/ZP+vvqJqnvYtf7WtM8UivzYpe5Hz5b
QHXiCGQbOiYHB9UyhDTWiB7YVjd8KHefOFxfHzOQb/iBhbv1x3bTl3DgepvRN6VO
kVvWzPjBLUSZ9whM9rDLqSSqMPyPvDTuEmLkuq+xm7pYJmsLqIMP2klZLqRxLX6K
dIsPLoIZe42sdf9GeMsk8mGJyZUQ6AzsfhWk3grb/XscizPSvrNsJ2VL1R7YTyT3
uqwplb8UG440qauxgnQ905PId1l2fJEnRtV+7vXprA0L0QotgXLVHBhLmTFM+3PH
3WA4ZXR1EqvXnWL7N/raemQjy62iOG6t7fcF5IdP9CMbWP+Plpsz4cQW7FtesCTq
9H3onf31dionUAPrn3nfVE36HhvVgRyvDBnBzJSIMighgq21Qx/d1dk0DRYi1hUI
a5ZXraochQz361ODFNIeBEGU+0qqXUtZDlmos/EySkZykSeU/L0bImS62VGE3afo
nCHl0YJPXheVcXR7JiSF2XQCAaFuS1Mr7NCXfWZOZQC/0dkvmHnl9DUAhuqq9BNZ
YXBmznTTT9kkFkqv7H0MerfJsrE/wF8puP3GM01DW2JRgXRpSWlvbPV/2LnMtRuD
1cKhZXcKHadg2/r0Zup/oDzmHPUEfTAXT0xbqoWlhkdwbF2veWQ96A/ncx3ISTb4
II7iH4rWDtTjCN6BWKAgDOnPkc9sZ4XulqT32lcUeV6LTdMBfq8kMEc8eDij1vUT
PkXBlX9rdia8nmtyQDQRn4NuvchbaGkj4WKFC8pF8Hn7naHqwjpHaDUimBc0CoQW
maVCRpuwaq8EIT3lVgNLufHiG96ojlyYtj3orzw22IjkgC/9ee8UDik9CqbMVmFf
edNJqruKWwtSVLuwKHCC2gZFX9AXSKJXJz/QRSUlhFGOhuF/J6yKaXj6n5lxWNiQ
fVHhsw8LNSg8Q4bmwm5Eg2w2it2gtI68+mwr75oCxuJ/8OMjW21Prj8XDh5reie2
54J+OP/hz2aS95CD2+Zf1SKpxdWiLZSIQqESpmmUrXROixNJZ/Z7gI74Dd9dSJOH
c0lDKQOFZ9UnLU1bXR/6qUM+JFKR4DMq+fOCuoQSVoyVUEOsJpvBOYnYZN9cxsZm
W+3AU03vrrFZVrJVZhjcINHoH1Skh6JKscH18L6x4U868nSr4SrRLX8BhHllOQyD
vh9dKafMEcKZ8flsbr+gOmOw7+Py2ifSlf25E/Frb1W4gtbTb0LQVHb6+drutrZj
bmU+PZAjF8ZBIaCtTGulDXD29F73MeAZeTSsgQjFu0iKLj1wPiphbx8i/SUtR4YP
8HEu4CnHYFCD4ZnOJb26XlZCb8GFBddW86yJYyUqMMV6Q1aJfAOAglsTo1LjIMOZ
X6PVA04g66r1NBw+3RQASVorZ3g1MSFvITHXcbKkBDeJH2z1+c6t/VVyTONnQhM5
byo0BTAmwUevU/iuOXQ4qRBXXcoidDcTCrxfUSPG9wdt9l+m5SdQpWqfQ+fx5O7m
lLgRSk6HCbetvT9PKxWrWutA12pdBYEHdZhMHVf2+xclky7l09w8hg2/qqcdGRGe
SLlrHyZCiPSFMtC9DxqjIklHjf5W3wslGLgaD30YXa4VDYkRihf3CNsxGQ+tVvef
oAOZ72t0l5ObNyaruDKUS6f4AjOyWq/Xj5xuFtf1n3tQHyslSyCTPcAbQhDfTHUx
l0ZjoAitF7Gaua06IESmKnpHe23dkr1cjYq+u2IV+xGH8LeExdwsQ9kpuTeXPnQs
vixb/V9qvYPt7OCn8py7v1M69NH42QVFAvwveDIFjZdqfIKBoJK2V4qPoevJI6uj
JOA99SsFx1ct32RrwjxnDDsiNkaViTKo9GDkV3jQTfoFgAVqfSgg9wGXpqUqhNG7
Q5ByMt8OXOjSXNpHXpYQWUiWeCwOEBXJX8rzCHdMtg37jJ0zCmeErR1NTdg+Euj
M
TiSIHCowllLny2zn4XrXCy2niD3VDt0skb3l/PaegHE2z7S5YY85nQtYwpLiwB9
M
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
-----END
RSA
PRIVATE KEY-----
-----END
ENCRYPTED
PRIVATE KEY-----
src/greentest/3.7/test_httplib.py
View file @
625c88b0
...
@@ -1157,6 +1157,34 @@ class BasicTest(TestCase):
...
@@ -1157,6 +1157,34 @@ class BasicTest(TestCase):
thread
.
join
()
thread
.
join
()
self
.
assertEqual
(
result
,
b"proxied data
\
n
"
)
self
.
assertEqual
(
result
,
b"proxied data
\
n
"
)
def
test_putrequest_override_validation
(
self
):
"""
It should be possible to override the default validation
behavior in putrequest (bpo-38216).
"""
class
UnsafeHTTPConnection
(
client
.
HTTPConnection
):
def
_validate_path
(
self
,
url
):
pass
conn
=
UnsafeHTTPConnection
(
'example.com'
)
conn
.
sock
=
FakeSocket
(
''
)
conn
.
putrequest
(
'GET'
,
'/
\
x00
'
)
def
test_putrequest_override_encoding
(
self
):
"""
It should be possible to override the default encoding
to transmit bytes in another encoding even if invalid
(bpo-36274).
"""
class
UnsafeHTTPConnection
(
client
.
HTTPConnection
):
def
_encode_request
(
self
,
str_url
):
return
str_url
.
encode
(
'utf-8'
)
conn
=
UnsafeHTTPConnection
(
'example.com'
)
conn
.
sock
=
FakeSocket
(
''
)
conn
.
putrequest
(
'GET'
,
'/☃'
)
class
ExtendedReadTest
(
TestCase
):
class
ExtendedReadTest
(
TestCase
):
"""
"""
Test peek(), read1(), readline()
Test peek(), read1(), readline()
...
@@ -1281,6 +1309,7 @@ class ExtendedReadTest(TestCase):
...
@@ -1281,6 +1309,7 @@ class ExtendedReadTest(TestCase):
p
=
self
.
resp
.
peek
(
0
)
p
=
self
.
resp
.
peek
(
0
)
self
.
assertLessEqual
(
0
,
len
(
p
))
self
.
assertLessEqual
(
0
,
len
(
p
))
class
ExtendedReadTestChunked
(
ExtendedReadTest
):
class
ExtendedReadTestChunked
(
ExtendedReadTest
):
"""
"""
Test peek(), read1(), readline() in chunked mode
Test peek(), read1(), readline() in chunked mode
...
...
src/greentest/3.7/test_ssl.py
View file @
625c88b0
...
@@ -19,6 +19,7 @@ import weakref
...
@@ -19,6 +19,7 @@ import weakref
import
platform
import
platform
import
functools
import
functools
import
sysconfig
import
sysconfig
import
functools
try
:
try
:
import
ctypes
import
ctypes
except
ImportError
:
except
ImportError
:
...
@@ -142,6 +143,87 @@ OP_CIPHER_SERVER_PREFERENCE = getattr(ssl, "OP_CIPHER_SERVER_PREFERENCE", 0)
...
@@ -142,6 +143,87 @@ OP_CIPHER_SERVER_PREFERENCE = getattr(ssl, "OP_CIPHER_SERVER_PREFERENCE", 0)
OP_ENABLE_MIDDLEBOX_COMPAT
=
getattr
(
ssl
,
"OP_ENABLE_MIDDLEBOX_COMPAT"
,
0
)
OP_ENABLE_MIDDLEBOX_COMPAT
=
getattr
(
ssl
,
"OP_ENABLE_MIDDLEBOX_COMPAT"
,
0
)
def
has_tls_protocol
(
protocol
):
"""Check if a TLS protocol is available and enabled
:param protocol: enum ssl._SSLMethod member or name
:return: bool
"""
if
isinstance
(
protocol
,
str
):
assert
protocol
.
startswith
(
'PROTOCOL_'
)
protocol
=
getattr
(
ssl
,
protocol
,
None
)
if
protocol
is
None
:
return
False
if
protocol
in
{
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS_SERVER
,
ssl
.
PROTOCOL_TLS_CLIENT
}:
# auto-negotiate protocols are always available
return
True
name
=
protocol
.
name
return
has_tls_version
(
name
[
len
(
'PROTOCOL_'
):])
@
functools
.
lru_cache
()
def
has_tls_version
(
version
):
"""Check if a TLS/SSL version is enabled
:param version: TLS version name or ssl.TLSVersion member
:return: bool
"""
if
version
==
"SSLv2"
:
# never supported and not even in TLSVersion enum
return
False
if
isinstance
(
version
,
str
):
version
=
ssl
.
TLSVersion
.
__members__
[
version
]
# check compile time flags like ssl.HAS_TLSv1_2
if
not
getattr
(
ssl
,
f'HAS_
{
version
.
name
}
'
):
return
False
# check runtime and dynamic crypto policy settings. A TLS version may
# be compiled in but disabled by a policy or config option.
ctx
=
ssl
.
SSLContext
()
if
(
hasattr
(
ctx
,
'minimum_version'
)
and
ctx
.
minimum_version
!=
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
and
version
<
ctx
.
minimum_version
):
return
False
if
(
hasattr
(
ctx
,
'maximum_version'
)
and
ctx
.
maximum_version
!=
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
and
version
>
ctx
.
maximum_version
):
return
False
return
True
def
requires_tls_version
(
version
):
"""Decorator to skip tests when a required TLS version is not available
:param version: TLS version name or ssl.TLSVersion member
:return:
"""
def
decorator
(
func
):
@
functools
.
wraps
(
func
)
def
wrapper
(
*
args
,
**
kw
):
if
not
has_tls_version
(
version
):
raise
unittest
.
SkipTest
(
f"
{
version
}
is not available."
)
else
:
return
func
(
*
args
,
**
kw
)
return
wrapper
return
decorator
requires_minimum_version
=
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
"required OpenSSL >= 1.1.0g"
)
def
handle_error
(
prefix
):
def
handle_error
(
prefix
):
exc_format
=
' '
.
join
(
traceback
.
format_exception
(
*
sys
.
exc_info
()))
exc_format
=
' '
.
join
(
traceback
.
format_exception
(
*
sys
.
exc_info
()))
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -849,8 +931,8 @@ class BasicSocketTests(unittest.TestCase):
...
@@ -849,8 +931,8 @@ class BasicSocketTests(unittest.TestCase):
cert
,
enc
,
trust
=
element
cert
,
enc
,
trust
=
element
self
.
assertIsInstance
(
cert
,
bytes
)
self
.
assertIsInstance
(
cert
,
bytes
)
self
.
assertIn
(
enc
,
{
"x509_asn"
,
"pkcs_7_asn"
})
self
.
assertIn
(
enc
,
{
"x509_asn"
,
"pkcs_7_asn"
})
self
.
assertIsInstance
(
trust
,
(
set
,
bool
))
self
.
assertIsInstance
(
trust
,
(
frozenset
,
set
,
bool
))
if
isinstance
(
trust
,
set
):
if
isinstance
(
trust
,
(
frozenset
,
set
)
):
trust_oids
.
update
(
trust
)
trust_oids
.
update
(
trust
)
serverAuth
=
"1.3.6.1.5.5.7.3.1"
serverAuth
=
"1.3.6.1.5.5.7.3.1"
...
@@ -1124,19 +1206,23 @@ class ContextTests(unittest.TestCase):
...
@@ -1124,19 +1206,23 @@ class ContextTests(unittest.TestCase):
with
self
.
assertRaises
(
AttributeError
):
with
self
.
assertRaises
(
AttributeError
):
ctx
.
hostname_checks_common_name
=
True
ctx
.
hostname_checks_common_name
=
True
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_minimum_version
"required OpenSSL 1.1.0g
"
)
@
unittest
.
skipIf
(
IS_LIBRESSL
,
"see bpo-34001
"
)
def
test_min_max_version
(
self
):
def
test_min_max_version
(
self
):
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS_SERVER
)
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS_SERVER
)
# OpenSSL default is MINIMUM_SUPPORTED, however some vendors like
# OpenSSL default is MINIMUM_SUPPORTED, however some vendors like
# Fedora override the setting to TLS 1.0.
# Fedora override the setting to TLS 1.0.
self
.
assertIn
(
minimum_range
=
{
ctx
.
minimum_version
,
# stock OpenSSL
{
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
ssl
.
TLSVersion
.
TLSv1_2
}
self
.
assertIn
(
ctx
.
minimum_version
,
minimum_range
)
)
self
.
assertEqual
(
self
.
assertEqual
(
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
...
@@ -1182,8 +1268,8 @@ class ContextTests(unittest.TestCase):
...
@@ -1182,8 +1268,8 @@ class ContextTests(unittest.TestCase):
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLSv1_1
)
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLSv1_1
)
self
.
assert
Equal
(
self
.
assert
In
(
ctx
.
minimum_version
,
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
ctx
.
minimum_version
,
minimum_range
)
)
self
.
assertEqual
(
self
.
assertEqual
(
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
...
@@ -2723,6 +2809,8 @@ class ThreadedTests(unittest.TestCase):
...
@@ -2723,6 +2809,8 @@ class ThreadedTests(unittest.TestCase):
for
protocol
in
PROTOCOLS
:
for
protocol
in
PROTOCOLS
:
if
protocol
in
{
ssl
.
PROTOCOL_TLS_CLIENT
,
ssl
.
PROTOCOL_TLS_SERVER
}:
if
protocol
in
{
ssl
.
PROTOCOL_TLS_CLIENT
,
ssl
.
PROTOCOL_TLS_SERVER
}:
continue
continue
if
not
has_tls_protocol
(
protocol
):
continue
with
self
.
subTest
(
protocol
=
ssl
.
_PROTOCOL_NAMES
[
protocol
]):
with
self
.
subTest
(
protocol
=
ssl
.
_PROTOCOL_NAMES
[
protocol
]):
context
=
ssl
.
SSLContext
(
protocol
)
context
=
ssl
.
SSLContext
(
protocol
)
context
.
load_cert_chain
(
CERTFILE
)
context
.
load_cert_chain
(
CERTFILE
)
...
@@ -3014,7 +3102,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3014,7 +3102,7 @@ class ThreadedTests(unittest.TestCase):
else
:
else
:
self
.
fail
(
"Use of invalid cert should have failed!"
)
self
.
fail
(
"Use of invalid cert should have failed!"
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
"Test needs TLS 1.3"
)
@
requires_tls_version
(
'TLSv1_3'
)
def
test_wrong_cert_tls13
(
self
):
def
test_wrong_cert_tls13
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
# load client cert that is not signed by trusted CA
# load client cert that is not signed by trusted CA
...
@@ -3109,9 +3197,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3109,9 +3197,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIn
(
msg
,
repr
(
e
))
self
.
assertIn
(
msg
,
repr
(
e
))
self
.
assertIn
(
'certificate verify failed'
,
repr
(
e
))
self
.
assertIn
(
'certificate verify failed'
,
repr
(
e
))
@
skip_if_broken_ubuntu_ssl
@
requires_tls_version
(
'SSLv2'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
'PROTOCOL_SSLv2'
),
"OpenSSL is compiled without SSLv2 support"
)
def
test_protocol_sslv2
(
self
):
def
test_protocol_sslv2
(
self
):
"""Connecting to an SSLv2 server with various client options"""
"""Connecting to an SSLv2 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3120,7 +3206,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3120,7 +3206,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLS
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLS
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLSv1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLSv1
,
False
)
# SSLv23 client with specific SSL options
# SSLv23 client with specific SSL options
...
@@ -3138,7 +3224,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3138,7 +3224,7 @@ class ThreadedTests(unittest.TestCase):
"""Connecting to an SSLv23 server with various client options"""
"""Connecting to an SSLv23 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
sys
.
stdout
.
write
(
"
\
n
"
)
sys
.
stdout
.
write
(
"
\
n
"
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try
:
try
:
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv2
,
True
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv2
,
True
)
except
OSError
as
x
:
except
OSError
as
x
:
...
@@ -3147,35 +3233,36 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3147,35 +3233,36 @@ class ThreadedTests(unittest.TestCase):
sys
.
stdout
.
write
(
sys
.
stdout
.
write
(
" SSL2 client to SSL23 server test unexpectedly failed:
\
n
%s
\
n
"
" SSL2 client to SSL23 server test unexpectedly failed:
\
n
%s
\
n
"
%
str
(
x
))
%
str
(
x
))
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_OPTIONAL
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_REQUIRED
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
# Server with specific SSL options
# Server with specific SSL options
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
server_options
=
ssl
.
OP_NO_SSLv3
)
server_options
=
ssl
.
OP_NO_SSLv3
)
# Will choose TLSv1
# Will choose TLSv1
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
server_options
=
ssl
.
OP_NO_SSLv2
|
ssl
.
OP_NO_SSLv3
)
server_options
=
ssl
.
OP_NO_SSLv2
|
ssl
.
OP_NO_SSLv3
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
server_options
=
ssl
.
OP_NO_TLSv1
)
server_options
=
ssl
.
OP_NO_TLSv1
)
@
requires_tls_version
(
'SSLv3'
)
@
skip_if_broken_ubuntu_ssl
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
'PROTOCOL_SSLv3'
),
"OpenSSL is compiled without SSLv3 support"
)
def
test_protocol_sslv3
(
self
):
def
test_protocol_sslv3
(
self
):
"""Connecting to an SSLv3 server with various client options"""
"""Connecting to an SSLv3 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3183,7 +3270,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3183,7 +3270,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_REQUIRED
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_SSLv3
)
client_options
=
ssl
.
OP_NO_SSLv3
)
...
@@ -3193,7 +3280,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3193,7 +3280,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_SSLv2
)
False
,
client_options
=
ssl
.
OP_NO_SSLv2
)
@
skip_if_broken_ubuntu_ssl
@
requires_tls_version
(
'TLSv1'
)
def
test_protocol_tlsv1
(
self
):
def
test_protocol_tlsv1
(
self
):
"""Connecting to a TLSv1 server with various client options"""
"""Connecting to a TLSv1 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3201,36 +3288,32 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3201,36 +3288,32 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1
)
client_options
=
ssl
.
OP_NO_TLSv1
)
@
skip_if_broken_ubuntu_ssl
@
requires_tls_version
(
'TLSv1_1'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
"PROTOCOL_TLSv1_1"
),
"TLS version 1.1 not supported."
)
def
test_protocol_tlsv1_1
(
self
):
def
test_protocol_tlsv1_1
(
self
):
"""Connecting to a TLSv1.1 server with various client options.
"""Connecting to a TLSv1.1 server with various client options.
Testing against older TLS versions."""
Testing against older TLS versions."""
if
support
.
verbose
:
if
support
.
verbose
:
sys
.
stdout
.
write
(
"
\
n
"
)
sys
.
stdout
.
write
(
"
\
n
"
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1_1
)
client_options
=
ssl
.
OP_NO_TLSv1_1
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1
_2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1_1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
_2
,
ssl
.
PROTOCOL_TLSv1_1
,
False
)
@
skip_if_broken_ubuntu_ssl
@
requires_tls_version
(
'TLSv1_2'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
"PROTOCOL_TLSv1_2"
),
"TLS version 1.2 not supported."
)
def
test_protocol_tlsv1_2
(
self
):
def
test_protocol_tlsv1_2
(
self
):
"""Connecting to a TLSv1.2 server with various client options.
"""Connecting to a TLSv1.2 server with various client options.
Testing against older TLS versions."""
Testing against older TLS versions."""
...
@@ -3239,9 +3322,9 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3239,9 +3322,9 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLSv1_2
,
'TLSv1.2'
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLSv1_2
,
'TLSv1.2'
,
server_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,
server_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,
client_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,)
client_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1_2
)
client_options
=
ssl
.
OP_NO_TLSv1_2
)
...
@@ -3684,7 +3767,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3684,7 +3767,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
if
IS_OPENSSL_1_1_1
and
ssl
.
HAS_TLSv1_3
:
if
IS_OPENSSL_1_1_1
and
has_tls_version
(
'TLSv1_3'
)
:
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
elif
ssl
.
OPENSSL_VERSION_INFO
>=
(
1
,
0
,
2
):
elif
ssl
.
OPENSSL_VERSION_INFO
>=
(
1
,
0
,
2
):
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
...
@@ -3693,8 +3776,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3693,8 +3776,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
version
(),
None
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
@
requires_tls_version
(
'TLSv1_3'
)
"test requires TLSv1.3 enabled OpenSSL"
)
def
test_tls1_3
(
self
):
def
test_tls1_3
(
self
):
context
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS
)
context
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS
)
context
.
load_cert_chain
(
CERTFILE
)
context
.
load_cert_chain
(
CERTFILE
)
...
@@ -3711,9 +3793,9 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3711,9 +3793,9 @@ class ThreadedTests(unittest.TestCase):
})
})
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_minimum_version
"required OpenSSL 1.1.0g"
)
@
requires_tls_version
(
'TLSv1_2'
)
def
test_min_max_version
(
self
):
def
test_min_max_version
_tlsv1_2
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
# client TLSv1.0 to 1.2
# client TLSv1.0 to 1.2
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
...
@@ -3728,7 +3810,13 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3728,7 +3810,13 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
@
requires_minimum_version
@
requires_tls_version
(
'TLSv1_1'
)
def
test_min_max_version_tlsv1_1
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
# client 1.0 to 1.2, server 1.0 to 1.1
# client 1.0 to 1.2, server 1.0 to 1.1
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_1
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_1
...
@@ -3738,6 +3826,10 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3738,6 +3826,10 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertEqual
(
s
.
version
(),
'TLSv1.1'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.1'
)
@
requires_minimum_version
@
requires_tls_version
(
'TLSv1_2'
)
def
test_min_max_version_mismatch
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
# client 1.0, server 1.2 (mismatch)
# client 1.0, server 1.2 (mismatch)
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
...
@@ -3750,10 +3842,8 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3750,10 +3842,8 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertIn
(
"alert"
,
str
(
e
.
exception
))
self
.
assertIn
(
"alert"
,
str
(
e
.
exception
))
@
requires_minimum_version
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_tls_version
(
'SSLv3'
)
"required OpenSSL 1.1.0g"
)
@
unittest
.
skipUnless
(
ssl
.
HAS_SSLv3
,
"requires SSLv3 support"
)
def
test_min_max_version_sslv3
(
self
):
def
test_min_max_version_sslv3
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
SSLv3
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
SSLv3
...
@@ -4272,7 +4362,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -4272,7 +4362,7 @@ class ThreadedTests(unittest.TestCase):
'Session refers to a different SSLContext.'
)
'Session refers to a different SSLContext.'
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
"Test needs TLS 1.3"
)
@
unittest
.
skipUnless
(
has_tls_version
(
'TLSv1_3'
)
,
"Test needs TLS 1.3"
)
class
TestPostHandshakeAuth
(
unittest
.
TestCase
):
class
TestPostHandshakeAuth
(
unittest
.
TestCase
):
def
test_pha_setter
(
self
):
def
test_pha_setter
(
self
):
protocols
=
[
protocols
=
[
...
...
src/greentest/3.7/test_subprocess.py
View file @
625c88b0
...
@@ -11,6 +11,7 @@ import os
...
@@ -11,6 +11,7 @@ import os
import
errno
import
errno
import
tempfile
import
tempfile
import
time
import
time
import
traceback
import
selectors
import
selectors
import
sysconfig
import
sysconfig
import
select
import
select
...
@@ -59,10 +60,14 @@ class BaseTestCase(unittest.TestCase):
...
@@ -59,10 +60,14 @@ class BaseTestCase(unittest.TestCase):
support
.
reap_children
()
support
.
reap_children
()
def
tearDown
(
self
):
def
tearDown
(
self
):
if
not
mswindows
:
# subprocess._active is not used on Windows and is set to None.
for
inst
in
subprocess
.
_active
:
for
inst
in
subprocess
.
_active
:
inst
.
wait
()
inst
.
wait
()
subprocess
.
_cleanup
()
subprocess
.
_cleanup
()
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
self
.
doCleanups
()
self
.
doCleanups
()
support
.
reap_children
()
support
.
reap_children
()
...
@@ -1504,6 +1509,26 @@ class RunFuncTestCase(BaseTestCase):
...
@@ -1504,6 +1509,26 @@ class RunFuncTestCase(BaseTestCase):
self
.
assertIn
(
'stderr'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'stderr'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'capture_output'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'capture_output'
,
c
.
exception
.
args
[
0
])
# This test _might_ wind up a bit fragile on loaded build+test machines
# as it depends on the timing with wide enough margins for normal situations
# but does assert that it happened "soon enough" to believe the right thing
# happened.
@
unittest
.
skipIf
(
mswindows
,
"requires posix like 'sleep' shell command"
)
def
test_run_with_shell_timeout_and_capture_output
(
self
):
"""Output capturing after a timeout mustn't hang forever on open filehandles."""
before_secs
=
time
.
monotonic
()
try
:
subprocess
.
run
(
'sleep 3'
,
shell
=
True
,
timeout
=
0.1
,
capture_output
=
True
)
# New session unspecified.
except
subprocess
.
TimeoutExpired
as
exc
:
after_secs
=
time
.
monotonic
()
stacks
=
traceback
.
format_exc
()
# assertRaises doesn't give this.
else
:
self
.
fail
(
"TimeoutExpired not raised."
)
self
.
assertLess
(
after_secs
-
before_secs
,
1.5
,
msg
=
"TimeoutExpired was delayed! Bad traceback:
\
n
```
\
n
"
f"
{
stacks
}
```"
)
@
unittest
.
skipIf
(
mswindows
,
"POSIX specific tests"
)
@
unittest
.
skipIf
(
mswindows
,
"POSIX specific tests"
)
class
POSIXProcessTestCase
(
BaseTestCase
):
class
POSIXProcessTestCase
(
BaseTestCase
):
...
@@ -2622,6 +2647,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2622,6 +2647,10 @@ class POSIXProcessTestCase(BaseTestCase):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
p
=
None
p
=
None
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
# check that p is in the active processes list
# check that p is in the active processes list
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
...
@@ -2644,6 +2673,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2644,6 +2673,10 @@ class POSIXProcessTestCase(BaseTestCase):
p
=
None
p
=
None
os
.
kill
(
pid
,
signal
.
SIGKILL
)
os
.
kill
(
pid
,
signal
.
SIGKILL
)
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
# check that p is in the active processes list
# check that p is in the active processes list
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
...
@@ -2657,6 +2690,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2657,6 +2690,10 @@ class POSIXProcessTestCase(BaseTestCase):
pass
pass
# p should have been wait()ed on, and removed from the _active list
# p should have been wait()ed on, and removed from the _active list
self
.
assertRaises
(
OSError
,
os
.
waitpid
,
pid
,
0
)
self
.
assertRaises
(
OSError
,
os
.
waitpid
,
pid
,
0
)
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
def
test_close_fds_after_preexec
(
self
):
def
test_close_fds_after_preexec
(
self
):
...
...
src/greentest/3.7/test_wsgiref.py
View file @
625c88b0
...
@@ -540,32 +540,62 @@ class TestHandler(ErrorHandler):
...
@@ -540,32 +540,62 @@ class TestHandler(ErrorHandler):
class
HandlerTests
(
TestCase
):
class
HandlerTests
(
TestCase
):
# testEnviron() can produce long error message
def
checkEnvironAttrs
(
self
,
handler
):
maxDiff
=
80
*
50
env
=
handler
.
environ
for
attr
in
[
'version'
,
'multithread'
,
'multiprocess'
,
'run_once'
,
'file_wrapper'
]:
if
attr
==
'file_wrapper'
and
handler
.
wsgi_file_wrapper
is
None
:
continue
self
.
assertEqual
(
getattr
(
handler
,
'wsgi_'
+
attr
),
env
[
'wsgi.'
+
attr
])
def
checkOSEnviron
(
self
,
handler
):
empty
=
{};
setup_testing_defaults
(
empty
)
env
=
handler
.
environ
from
os
import
environ
for
k
,
v
in
environ
.
items
():
if
k
not
in
empty
:
self
.
assertEqual
(
env
[
k
],
v
)
for
k
,
v
in
empty
.
items
():
self
.
assertIn
(
k
,
env
)
def
testEnviron
(
self
):
def
testEnviron
(
self
):
h
=
TestHandler
(
X
=
"Y"
)
os_environ
=
{
h
.
setup_environ
()
# very basic environment
self
.
checkEnvironAttrs
(
h
)
'HOME'
:
'/my/home'
,
self
.
checkOSEnviron
(
h
)
'PATH'
:
'/my/path'
,
self
.
assertEqual
(
h
.
environ
[
"X"
],
"Y"
)
'LANG'
:
'fr_FR.UTF-8'
,
# set some WSGI variables
'SCRIPT_NAME'
:
'test_script_name'
,
'SERVER_NAME'
:
'test_server_name'
,
}
with
support
.
swap_attr
(
TestHandler
,
'os_environ'
,
os_environ
):
# override X and HOME variables
handler
=
TestHandler
(
X
=
"Y"
,
HOME
=
"/override/home"
)
handler
.
setup_environ
()
# Check that wsgi_xxx attributes are copied to wsgi.xxx variables
# of handler.environ
for
attr
in
(
'version'
,
'multithread'
,
'multiprocess'
,
'run_once'
,
'file_wrapper'
):
self
.
assertEqual
(
getattr
(
handler
,
'wsgi_'
+
attr
),
handler
.
environ
[
'wsgi.'
+
attr
])
# Test handler.environ as a dict
expected
=
{}
setup_testing_defaults
(
expected
)
# Handler inherits os_environ variables which are not overriden
# by SimpleHandler.add_cgi_vars() (SimpleHandler.base_env)
for
key
,
value
in
os_environ
.
items
():
if
key
not
in
expected
:
expected
[
key
]
=
value
expected
.
update
({
# X doesn't exist in os_environ
"X"
:
"Y"
,
# HOME is overriden by TestHandler
'HOME'
:
"/override/home"
,
# overriden by setup_testing_defaults()
"SCRIPT_NAME"
:
""
,
"SERVER_NAME"
:
"127.0.0.1"
,
# set by BaseHandler.setup_environ()
'wsgi.input'
:
handler
.
get_stdin
(),
'wsgi.errors'
:
handler
.
get_stderr
(),
'wsgi.version'
:
(
1
,
0
),
'wsgi.run_once'
:
False
,
'wsgi.url_scheme'
:
'http'
,
'wsgi.multithread'
:
True
,
'wsgi.multiprocess'
:
True
,
'wsgi.file_wrapper'
:
util
.
FileWrapper
,
})
self
.
assertDictEqual
(
handler
.
environ
,
expected
)
def
testCGIEnviron
(
self
):
def
testCGIEnviron
(
self
):
h
=
BaseCGIHandler
(
None
,
None
,
None
,{})
h
=
BaseCGIHandler
(
None
,
None
,
None
,{})
...
...
src/greentest/3.7/version
View file @
625c88b0
3.7.
2
3.7.
5
src/greentest/3.8/keycert.passwd.pem
View file @
625c88b0
-----BEGIN
RSA
PRIVATE KEY-----
-----BEGIN
ENCRYPTED
PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
MIIHbTBXBgkqhkiG9w0BBQ0wSjApBgkqhkiG9w0BBQwwHAQIhD+rJdxqb6ECAggA
DEK-Info: DES-EDE3-CBC,D134E931C96D9DEC
MAwGCCqGSIb3DQIJBQAwHQYJYIZIAWUDBAEqBBDTdyjCP3riOSUfxix4aXEvBIIH
ECGkbsFabrcFMZcplw5jHMaOlG7rYjUzwDJ80JM8uzbv2Jb8SvNlns2+xmnEvH/M
nuGFEej7vIjkYWSMz5OJeVTNntDRQi6ZM4DBm3g8T7i/0odr3WFqGMMKZcIhLYQf
mNvRmnXmplbVjH3XBMK8o2Psnr2V/a0j7/pgqpRxHykG+koOY4gzdt3MAg8JPbS2
rgRq7RSKtrJ1y5taVucMV+EuCjyfzDo0TsYt+ZrXv/D08eZhjRmkhoHnGVF0TqQm
hymSl+Y5EpciO3xLfz4aFL1ZNqspQbO/TD13Ij7DUIy7xIRBMp4taoZCrP0cEBAZ
nQEXM/ERT4J2RM78dnG+homMkI76qOqxgGbRqQqJo6AiVRcAZ45y8s96bru2TAB8
+wgu9m23I4dh3E8RUBzWyFFNic2MVVHrui6JbHc4dIHfyKLtXJDhUcS0vIC9PvcV
+pWjO/v0Je7AFVdwSU52N8OOY6uoSAygW+0UY1WVxbVGJF2XfRsNpPX+YQHYl6e+
jhorh3UZC4lM+/jjXV5AhzQ0VrJ2tXAUX2dA144XHzkSH2QmwfnajPsci7BL2CGC
3xM5XBVCgr6kmdAyub5qUJ38X3TpdVGoR0i+CVS9GTr2pSRib1zURAeeHnlqiUZM
rjyTy4NfB/lDwU+55dqJZQSKXMxAapJMrtgw7LD5CKQcN6zmfhXGssJ7HQUXKkaX
4m0Gn9s72nJevU1wxED8pwOhR8fnHEmMKGD2HPhKoOCbzDhwwBZO27TNa1uWeM3f
I1YOFzuUD7oo56BVCnVswv0jX9RxrE5QYNreMlOP9cS+kIYH65N+PAhlURuQC14K
M5oixKDi2PqMn3y2cDx1NjJtP661688EcJ5a2Ih9BgO9xpnhSyzBWEKcAn0tJB0H
PgDkHn5knSa2UQA5tc5f7zdHOZhGRUfcjLP+KAWA3nh+/2OKw/X3zuPx75YT/FKe
/56M0FW6cdOOIzMveGGL7sHW5E+iOdI1n5e7C6KJUzew78Y9qJnhS53EdI6qTz9R
tACPw5hjEpl62m9Xa0eWepZXwqkIOkzHMmCyNCsbC0mmRoEjmvfnslfsmnh4Dg/c
wsIsj1i070Fk6RbPo6zpLlF6w7Zj8GlZaZA7OZZv9wo5VEV/0ST8gmiiBOBc4C6Y
4YsTYMOLLIeCa+WIc38aA5W2lNO9lW0LwLhX1rP+GRVPv+TVHXlfoyaI+jp0iXrJ
u9hyLIIu4dFEBKyQHRvBnQSLNpKx6or1OGFDVBay2In9Yh2BHh1+vOj/OIz/wq48
t3xxT0gaiIR/VznyS7Py68QV/zB7VdqbsNzS7LdquHK1k8+7OYiWjY3gqyU40Iu2
EHOIV27fRJxLu4jeK5LIGDhuPnMJ8AJYQ0bQOUP6fd7p+TxWkAQZPB/Dx/cs3hx
r
d1eSnIoDvQJwyYp7XYXbOlXNLY+s1Qb7yxcW3vXm0Bg3gKT8r1XHWJ9rj+CxAn5
r
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
-----END
RSA
PRIVATE KEY-----
-----END
ENCRYPTED
PRIVATE KEY-----
-----BEGIN CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIIEWTCCAsGgAwIBAgIJAJinz4jHSjLtMA0GCSqGSIb3DQEBCwUAMF8xCzAJBgNV
MIIEWTCCAsGgAwIBAgIJAJinz4jHSjLtMA0GCSqGSIb3DQEBCwUAMF8xCzAJBgNV
BAYTAlhZMRcwFQYDVQQHDA5DYXN0bGUgQW50aHJheDEjMCEGA1UECgwaUHl0aG9u
BAYTAlhZMRcwFQYDVQQHDA5DYXN0bGUgQW50aHJheDEjMCEGA1UECgwaUHl0aG9u
...
@@ -66,3 +66,4 @@ jMqTFlmO7kpf/jpCSmamp3/JSEE1BJKHwQ6Ql4nzRA2N1mnvWH7Zxcv043gkHeAu
...
@@ -66,3 +66,4 @@ jMqTFlmO7kpf/jpCSmamp3/JSEE1BJKHwQ6Ql4nzRA2N1mnvWH7Zxcv043gkHeAu
9Wc2uXpw9xF8itV4Uvcdr3dwqByvIqn7iI/gB+4l41e0u8OmH2MKOx4Nxlly5TNW
9Wc2uXpw9xF8itV4Uvcdr3dwqByvIqn7iI/gB+4l41e0u8OmH2MKOx4Nxlly5TNW
HcVKQHyOeyvnINuBAQ==
HcVKQHyOeyvnINuBAQ==
-----END CERTIFICATE-----
-----END CERTIFICATE-----
src/greentest/3.8/ssl_key.passwd.pem
View file @
625c88b0
-----BEGIN
RSA
PRIVATE KEY-----
-----BEGIN
ENCRYPTED
PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
MIIHbTBXBgkqhkiG9w0BBQ0wSjApBgkqhkiG9w0BBQwwHAQI072N7W+PDDMCAggA
DEK-Info: DES-EDE3-CBC,8064BE1494B24B13
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
M
TiSIHCowllLny2zn4XrXCy2niD3VDt0skb3l/PaegHE2z7S5YY85nQtYwpLiwB9
M
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
-----END
RSA
PRIVATE KEY-----
-----END
ENCRYPTED
PRIVATE KEY-----
src/greentest/3.8/test_httplib.py
View file @
625c88b0
...
@@ -1155,6 +1155,34 @@ class BasicTest(TestCase):
...
@@ -1155,6 +1155,34 @@ class BasicTest(TestCase):
thread
.
join
()
thread
.
join
()
self
.
assertEqual
(
result
,
b"proxied data
\
n
"
)
self
.
assertEqual
(
result
,
b"proxied data
\
n
"
)
def
test_putrequest_override_validation
(
self
):
"""
It should be possible to override the default validation
behavior in putrequest (bpo-38216).
"""
class
UnsafeHTTPConnection
(
client
.
HTTPConnection
):
def
_validate_path
(
self
,
url
):
pass
conn
=
UnsafeHTTPConnection
(
'example.com'
)
conn
.
sock
=
FakeSocket
(
''
)
conn
.
putrequest
(
'GET'
,
'/
\
x00
'
)
def
test_putrequest_override_encoding
(
self
):
"""
It should be possible to override the default encoding
to transmit bytes in another encoding even if invalid
(bpo-36274).
"""
class
UnsafeHTTPConnection
(
client
.
HTTPConnection
):
def
_encode_request
(
self
,
str_url
):
return
str_url
.
encode
(
'utf-8'
)
conn
=
UnsafeHTTPConnection
(
'example.com'
)
conn
.
sock
=
FakeSocket
(
''
)
conn
.
putrequest
(
'GET'
,
'/☃'
)
class
ExtendedReadTest
(
TestCase
):
class
ExtendedReadTest
(
TestCase
):
"""
"""
Test peek(), read1(), readline()
Test peek(), read1(), readline()
...
@@ -1279,6 +1307,7 @@ class ExtendedReadTest(TestCase):
...
@@ -1279,6 +1307,7 @@ class ExtendedReadTest(TestCase):
p
=
self
.
resp
.
peek
(
0
)
p
=
self
.
resp
.
peek
(
0
)
self
.
assertLessEqual
(
0
,
len
(
p
))
self
.
assertLessEqual
(
0
,
len
(
p
))
class
ExtendedReadTestChunked
(
ExtendedReadTest
):
class
ExtendedReadTestChunked
(
ExtendedReadTest
):
"""
"""
Test peek(), read1(), readline() in chunked mode
Test peek(), read1(), readline() in chunked mode
...
...
src/greentest/3.8/test_socket.py
View file @
625c88b0
...
@@ -1897,7 +1897,9 @@ class BasicCANTest(unittest.TestCase):
...
@@ -1897,7 +1897,9 @@ class BasicCANTest(unittest.TestCase):
def
testBindAny
(
self
):
def
testBindAny
(
self
):
with
socket
.
socket
(
socket
.
PF_CAN
,
socket
.
SOCK_RAW
,
socket
.
CAN_RAW
)
as
s
:
with
socket
.
socket
(
socket
.
PF_CAN
,
socket
.
SOCK_RAW
,
socket
.
CAN_RAW
)
as
s
:
s
.
bind
((
''
,
))
address
=
(
''
,
)
s
.
bind
(
address
)
self
.
assertEqual
(
s
.
getsockname
(),
address
)
def
testTooLongInterfaceName
(
self
):
def
testTooLongInterfaceName
(
self
):
# most systems limit IFNAMSIZ to 16, take 1024 to be sure
# most systems limit IFNAMSIZ to 16, take 1024 to be sure
...
...
src/greentest/3.8/test_ssl.py
View file @
625c88b0
...
@@ -19,6 +19,7 @@ import asyncore
...
@@ -19,6 +19,7 @@ import asyncore
import
weakref
import
weakref
import
platform
import
platform
import
sysconfig
import
sysconfig
import
functools
try
:
try
:
import
ctypes
import
ctypes
except
ImportError
:
except
ImportError
:
...
@@ -143,6 +144,87 @@ OP_CIPHER_SERVER_PREFERENCE = getattr(ssl, "OP_CIPHER_SERVER_PREFERENCE", 0)
...
@@ -143,6 +144,87 @@ OP_CIPHER_SERVER_PREFERENCE = getattr(ssl, "OP_CIPHER_SERVER_PREFERENCE", 0)
OP_ENABLE_MIDDLEBOX_COMPAT
=
getattr
(
ssl
,
"OP_ENABLE_MIDDLEBOX_COMPAT"
,
0
)
OP_ENABLE_MIDDLEBOX_COMPAT
=
getattr
(
ssl
,
"OP_ENABLE_MIDDLEBOX_COMPAT"
,
0
)
def
has_tls_protocol
(
protocol
):
"""Check if a TLS protocol is available and enabled
:param protocol: enum ssl._SSLMethod member or name
:return: bool
"""
if
isinstance
(
protocol
,
str
):
assert
protocol
.
startswith
(
'PROTOCOL_'
)
protocol
=
getattr
(
ssl
,
protocol
,
None
)
if
protocol
is
None
:
return
False
if
protocol
in
{
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS_SERVER
,
ssl
.
PROTOCOL_TLS_CLIENT
}:
# auto-negotiate protocols are always available
return
True
name
=
protocol
.
name
return
has_tls_version
(
name
[
len
(
'PROTOCOL_'
):])
@
functools
.
lru_cache
def
has_tls_version
(
version
):
"""Check if a TLS/SSL version is enabled
:param version: TLS version name or ssl.TLSVersion member
:return: bool
"""
if
version
==
"SSLv2"
:
# never supported and not even in TLSVersion enum
return
False
if
isinstance
(
version
,
str
):
version
=
ssl
.
TLSVersion
.
__members__
[
version
]
# check compile time flags like ssl.HAS_TLSv1_2
if
not
getattr
(
ssl
,
f'HAS_
{
version
.
name
}
'
):
return
False
# check runtime and dynamic crypto policy settings. A TLS version may
# be compiled in but disabled by a policy or config option.
ctx
=
ssl
.
SSLContext
()
if
(
hasattr
(
ctx
,
'minimum_version'
)
and
ctx
.
minimum_version
!=
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
and
version
<
ctx
.
minimum_version
):
return
False
if
(
hasattr
(
ctx
,
'maximum_version'
)
and
ctx
.
maximum_version
!=
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
and
version
>
ctx
.
maximum_version
):
return
False
return
True
def
requires_tls_version
(
version
):
"""Decorator to skip tests when a required TLS version is not available
:param version: TLS version name or ssl.TLSVersion member
:return:
"""
def
decorator
(
func
):
@
functools
.
wraps
(
func
)
def
wrapper
(
*
args
,
**
kw
):
if
not
has_tls_version
(
version
):
raise
unittest
.
SkipTest
(
f"
{
version
}
is not available."
)
else
:
return
func
(
*
args
,
**
kw
)
return
wrapper
return
decorator
requires_minimum_version
=
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
"required OpenSSL >= 1.1.0g"
)
def
handle_error
(
prefix
):
def
handle_error
(
prefix
):
exc_format
=
' '
.
join
(
traceback
.
format_exception
(
*
sys
.
exc_info
()))
exc_format
=
' '
.
join
(
traceback
.
format_exception
(
*
sys
.
exc_info
()))
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -832,8 +914,8 @@ class BasicSocketTests(unittest.TestCase):
...
@@ -832,8 +914,8 @@ class BasicSocketTests(unittest.TestCase):
cert
,
enc
,
trust
=
element
cert
,
enc
,
trust
=
element
self
.
assertIsInstance
(
cert
,
bytes
)
self
.
assertIsInstance
(
cert
,
bytes
)
self
.
assertIn
(
enc
,
{
"x509_asn"
,
"pkcs_7_asn"
})
self
.
assertIn
(
enc
,
{
"x509_asn"
,
"pkcs_7_asn"
})
self
.
assertIsInstance
(
trust
,
(
set
,
bool
))
self
.
assertIsInstance
(
trust
,
(
frozenset
,
set
,
bool
))
if
isinstance
(
trust
,
set
):
if
isinstance
(
trust
,
(
frozenset
,
set
)
):
trust_oids
.
update
(
trust
)
trust_oids
.
update
(
trust
)
serverAuth
=
"1.3.6.1.5.5.7.3.1"
serverAuth
=
"1.3.6.1.5.5.7.3.1"
...
@@ -1104,19 +1186,23 @@ class ContextTests(unittest.TestCase):
...
@@ -1104,19 +1186,23 @@ class ContextTests(unittest.TestCase):
with
self
.
assertRaises
(
AttributeError
):
with
self
.
assertRaises
(
AttributeError
):
ctx
.
hostname_checks_common_name
=
True
ctx
.
hostname_checks_common_name
=
True
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_minimum_version
"required OpenSSL 1.1.0g
"
)
@
unittest
.
skipIf
(
IS_LIBRESSL
,
"see bpo-34001
"
)
def
test_min_max_version
(
self
):
def
test_min_max_version
(
self
):
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS_SERVER
)
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS_SERVER
)
# OpenSSL default is MINIMUM_SUPPORTED, however some vendors like
# OpenSSL default is MINIMUM_SUPPORTED, however some vendors like
# Fedora override the setting to TLS 1.0.
# Fedora override the setting to TLS 1.0.
self
.
assertIn
(
minimum_range
=
{
ctx
.
minimum_version
,
# stock OpenSSL
{
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
ssl
.
TLSVersion
.
TLSv1_2
}
self
.
assertIn
(
ctx
.
minimum_version
,
minimum_range
)
)
self
.
assertEqual
(
self
.
assertEqual
(
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
...
@@ -1162,8 +1248,8 @@ class ContextTests(unittest.TestCase):
...
@@ -1162,8 +1248,8 @@ class ContextTests(unittest.TestCase):
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLSv1_1
)
ctx
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLSv1_1
)
self
.
assert
Equal
(
self
.
assert
In
(
ctx
.
minimum_version
,
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
ctx
.
minimum_version
,
minimum_range
)
)
self
.
assertEqual
(
self
.
assertEqual
(
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
ctx
.
maximum_version
,
ssl
.
TLSVersion
.
MAXIMUM_SUPPORTED
...
@@ -2716,6 +2802,8 @@ class ThreadedTests(unittest.TestCase):
...
@@ -2716,6 +2802,8 @@ class ThreadedTests(unittest.TestCase):
for
protocol
in
PROTOCOLS
:
for
protocol
in
PROTOCOLS
:
if
protocol
in
{
ssl
.
PROTOCOL_TLS_CLIENT
,
ssl
.
PROTOCOL_TLS_SERVER
}:
if
protocol
in
{
ssl
.
PROTOCOL_TLS_CLIENT
,
ssl
.
PROTOCOL_TLS_SERVER
}:
continue
continue
if
not
has_tls_protocol
(
protocol
):
continue
with
self
.
subTest
(
protocol
=
ssl
.
_PROTOCOL_NAMES
[
protocol
]):
with
self
.
subTest
(
protocol
=
ssl
.
_PROTOCOL_NAMES
[
protocol
]):
context
=
ssl
.
SSLContext
(
protocol
)
context
=
ssl
.
SSLContext
(
protocol
)
context
.
load_cert_chain
(
CERTFILE
)
context
.
load_cert_chain
(
CERTFILE
)
...
@@ -3007,7 +3095,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3007,7 +3095,7 @@ class ThreadedTests(unittest.TestCase):
else
:
else
:
self
.
fail
(
"Use of invalid cert should have failed!"
)
self
.
fail
(
"Use of invalid cert should have failed!"
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
"Test needs TLS 1.3"
)
@
requires_tls_version
(
'TLSv1_3'
)
def
test_wrong_cert_tls13
(
self
):
def
test_wrong_cert_tls13
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
# load client cert that is not signed by trusted CA
# load client cert that is not signed by trusted CA
...
@@ -3102,8 +3190,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3102,8 +3190,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIn
(
msg
,
repr
(
e
))
self
.
assertIn
(
msg
,
repr
(
e
))
self
.
assertIn
(
'certificate verify failed'
,
repr
(
e
))
self
.
assertIn
(
'certificate verify failed'
,
repr
(
e
))
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
'PROTOCOL_SSLv2'
),
@
requires_tls_version
(
'SSLv2'
)
"OpenSSL is compiled without SSLv2 support"
)
def
test_protocol_sslv2
(
self
):
def
test_protocol_sslv2
(
self
):
"""Connecting to an SSLv2 server with various client options"""
"""Connecting to an SSLv2 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3112,7 +3199,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3112,7 +3199,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv2
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLS
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLS
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLSv1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv2
,
ssl
.
PROTOCOL_TLSv1
,
False
)
# SSLv23 client with specific SSL options
# SSLv23 client with specific SSL options
...
@@ -3129,7 +3216,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3129,7 +3216,7 @@ class ThreadedTests(unittest.TestCase):
"""Connecting to an SSLv23 server with various client options"""
"""Connecting to an SSLv23 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
sys
.
stdout
.
write
(
"
\
n
"
)
sys
.
stdout
.
write
(
"
\
n
"
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try
:
try
:
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv2
,
True
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv2
,
True
)
except
OSError
as
x
:
except
OSError
as
x
:
...
@@ -3138,34 +3225,36 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3138,34 +3225,36 @@ class ThreadedTests(unittest.TestCase):
sys
.
stdout
.
write
(
sys
.
stdout
.
write
(
" SSL2 client to SSL23 server test unexpectedly failed:
\
n
%s
\
n
"
" SSL2 client to SSL23 server test unexpectedly failed:
\
n
%s
\
n
"
%
str
(
x
))
%
str
(
x
))
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_OPTIONAL
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
ssl
.
CERT_REQUIRED
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
# Server with specific SSL options
# Server with specific SSL options
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_SSLv3
,
False
,
server_options
=
ssl
.
OP_NO_SSLv3
)
server_options
=
ssl
.
OP_NO_SSLv3
)
# Will choose TLSv1
# Will choose TLSv1
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLS
,
True
,
server_options
=
ssl
.
OP_NO_SSLv2
|
ssl
.
OP_NO_SSLv3
)
server_options
=
ssl
.
OP_NO_SSLv2
|
ssl
.
OP_NO_SSLv3
)
if
has_tls_version
(
'TLSv1'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
server_options
=
ssl
.
OP_NO_TLSv1
)
server_options
=
ssl
.
OP_NO_TLSv1
)
@
requires_tls_version
(
'SSLv3'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
'PROTOCOL_SSLv3'
),
"OpenSSL is compiled without SSLv3 support"
)
def
test_protocol_sslv3
(
self
):
def
test_protocol_sslv3
(
self
):
"""Connecting to an SSLv3 server with various client options"""
"""Connecting to an SSLv3 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3173,7 +3262,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3173,7 +3262,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv3
,
'SSLv3'
,
ssl
.
CERT_REQUIRED
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_SSLv3
)
client_options
=
ssl
.
OP_NO_SSLv3
)
...
@@ -3183,6 +3272,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3183,6 +3272,7 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
try_protocol_combo
(
ssl
.
PROTOCOL_SSLv3
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_SSLv2
)
False
,
client_options
=
ssl
.
OP_NO_SSLv2
)
@
requires_tls_version
(
'TLSv1'
)
def
test_protocol_tlsv1
(
self
):
def
test_protocol_tlsv1
(
self
):
"""Connecting to a TLSv1 server with various client options"""
"""Connecting to a TLSv1 server with various client options"""
if
support
.
verbose
:
if
support
.
verbose
:
...
@@ -3190,34 +3280,32 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3190,34 +3280,32 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1
)
client_options
=
ssl
.
OP_NO_TLSv1
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
"PROTOCOL_TLSv1_1"
),
@
requires_tls_version
(
'TLSv1_1'
)
"TLS version 1.1 not supported."
)
def
test_protocol_tlsv1_1
(
self
):
def
test_protocol_tlsv1_1
(
self
):
"""Connecting to a TLSv1.1 server with various client options.
"""Connecting to a TLSv1.1 server with various client options.
Testing against older TLS versions."""
Testing against older TLS versions."""
if
support
.
verbose
:
if
support
.
verbose
:
sys
.
stdout
.
write
(
"
\
n
"
)
sys
.
stdout
.
write
(
"
\
n
"
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1_1
)
client_options
=
ssl
.
OP_NO_TLSv1_1
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1_1
,
'TLSv1.1'
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_1
,
ssl
.
PROTOCOL_TLSv1
_2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
,
ssl
.
PROTOCOL_TLSv1_1
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1
_2
,
ssl
.
PROTOCOL_TLSv1_1
,
False
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
,
"PROTOCOL_TLSv1_2"
),
@
requires_tls_version
(
'TLSv1_2'
)
"TLS version 1.2 not supported."
)
def
test_protocol_tlsv1_2
(
self
):
def
test_protocol_tlsv1_2
(
self
):
"""Connecting to a TLSv1.2 server with various client options.
"""Connecting to a TLSv1.2 server with various client options.
Testing against older TLS versions."""
Testing against older TLS versions."""
...
@@ -3226,9 +3314,9 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3226,9 +3314,9 @@ class ThreadedTests(unittest.TestCase):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLSv1_2
,
'TLSv1.2'
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLSv1_2
,
'TLSv1.2'
,
server_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,
server_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,
client_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,)
client_options
=
ssl
.
OP_NO_SSLv3
|
ssl
.
OP_NO_SSLv2
,)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv2'
):
if
has
_tls_version
(
'
SSLv2'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv2
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv2
,
False
)
if
has
attr
(
ssl
,
'PROTOCOL_
SSLv3'
):
if
has
_tls_version
(
'
SSLv3'
):
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_SSLv3
,
False
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLS
,
False
,
try_protocol_combo
(
ssl
.
PROTOCOL_TLSv1_2
,
ssl
.
PROTOCOL_TLS
,
False
,
client_options
=
ssl
.
OP_NO_TLSv1_2
)
client_options
=
ssl
.
OP_NO_TLSv1_2
)
...
@@ -3671,7 +3759,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3671,7 +3759,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
if
IS_OPENSSL_1_1_1
and
ssl
.
HAS_TLSv1_3
:
if
IS_OPENSSL_1_1_1
and
has_tls_version
(
'TLSv1_3'
)
:
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
elif
ssl
.
OPENSSL_VERSION_INFO
>=
(
1
,
0
,
2
):
elif
ssl
.
OPENSSL_VERSION_INFO
>=
(
1
,
0
,
2
):
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
...
@@ -3680,8 +3768,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3680,8 +3768,7 @@ class ThreadedTests(unittest.TestCase):
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
_sslobj
,
None
)
self
.
assertIs
(
s
.
version
(),
None
)
self
.
assertIs
(
s
.
version
(),
None
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
@
requires_tls_version
(
'TLSv1_3'
)
"test requires TLSv1.3 enabled OpenSSL"
)
def
test_tls1_3
(
self
):
def
test_tls1_3
(
self
):
context
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS
)
context
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLS
)
context
.
load_cert_chain
(
CERTFILE
)
context
.
load_cert_chain
(
CERTFILE
)
...
@@ -3698,9 +3785,9 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3698,9 +3785,9 @@ class ThreadedTests(unittest.TestCase):
})
})
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.3'
)
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_minimum_version
"required OpenSSL 1.1.0g"
)
@
requires_tls_version
(
'TLSv1_2'
)
def
test_min_max_version
(
self
):
def
test_min_max_version
_tlsv1_2
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
# client TLSv1.0 to 1.2
# client TLSv1.0 to 1.2
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
...
@@ -3715,7 +3802,13 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3715,7 +3802,13 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.2'
)
@
requires_minimum_version
@
requires_tls_version
(
'TLSv1_1'
)
def
test_min_max_version_tlsv1_1
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
# client 1.0 to 1.2, server 1.0 to 1.1
# client 1.0 to 1.2, server 1.0 to 1.1
client_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_1
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_1
...
@@ -3725,11 +3818,15 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3725,11 +3818,15 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertEqual
(
s
.
version
(),
'TLSv1.1'
)
self
.
assertEqual
(
s
.
version
(),
'TLSv1.1'
)
@
requires_minimum_version
@
requires_tls_version
(
'TLSv1_2'
)
def
test_min_max_version_mismatch
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
# client 1.0, server 1.2 (mismatch)
# client 1.0, server 1.2 (mismatch)
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1_2
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
TLSv1_2
client_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
maximum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
m
ax
imum_version
=
ssl
.
TLSVersion
.
TLSv1
client_context
.
m
in
imum_version
=
ssl
.
TLSVersion
.
TLSv1
with
ThreadedEchoServer
(
context
=
server_context
)
as
server
:
with
ThreadedEchoServer
(
context
=
server_context
)
as
server
:
with
client_context
.
wrap_socket
(
socket
.
socket
(),
with
client_context
.
wrap_socket
(
socket
.
socket
(),
server_hostname
=
hostname
)
as
s
:
server_hostname
=
hostname
)
as
s
:
...
@@ -3737,10 +3834,8 @@ class ThreadedTests(unittest.TestCase):
...
@@ -3737,10 +3834,8 @@ class ThreadedTests(unittest.TestCase):
s
.
connect
((
HOST
,
server
.
port
))
s
.
connect
((
HOST
,
server
.
port
))
self
.
assertIn
(
"alert"
,
str
(
e
.
exception
))
self
.
assertIn
(
"alert"
,
str
(
e
.
exception
))
@
requires_minimum_version
@
unittest
.
skipUnless
(
hasattr
(
ssl
.
SSLContext
,
'minimum_version'
),
@
requires_tls_version
(
'SSLv3'
)
"required OpenSSL 1.1.0g"
)
@
unittest
.
skipUnless
(
ssl
.
HAS_SSLv3
,
"requires SSLv3 support"
)
def
test_min_max_version_sslv3
(
self
):
def
test_min_max_version_sslv3
(
self
):
client_context
,
server_context
,
hostname
=
testing_context
()
client_context
,
server_context
,
hostname
=
testing_context
()
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
SSLv3
server_context
.
minimum_version
=
ssl
.
TLSVersion
.
SSLv3
...
@@ -4263,7 +4358,7 @@ class ThreadedTests(unittest.TestCase):
...
@@ -4263,7 +4358,7 @@ class ThreadedTests(unittest.TestCase):
'Session refers to a different SSLContext.'
)
'Session refers to a different SSLContext.'
)
@
unittest
.
skipUnless
(
ssl
.
HAS_TLSv1_3
,
"Test needs TLS 1.3"
)
@
unittest
.
skipUnless
(
has_tls_version
(
'TLSv1_3'
)
,
"Test needs TLS 1.3"
)
class
TestPostHandshakeAuth
(
unittest
.
TestCase
):
class
TestPostHandshakeAuth
(
unittest
.
TestCase
):
def
test_pha_setter
(
self
):
def
test_pha_setter
(
self
):
protocols
=
[
protocols
=
[
...
@@ -4575,9 +4670,7 @@ class TestSSLDebug(unittest.TestCase):
...
@@ -4575,9 +4670,7 @@ class TestSSLDebug(unittest.TestCase):
msg
=
[]
msg
=
[]
def
msg_cb
(
conn
,
direction
,
version
,
content_type
,
msg_type
,
data
):
def
msg_cb
(
conn
,
direction
,
version
,
content_type
,
msg_type
,
data
):
# gevent: disabled . We want this test to run, but the socket is passed from
self
.
assertIsInstance
(
conn
,
ssl
.
SSLSocket
)
# the low-level C code, and it's not the gevent wrapper.
# self.assertIsInstance(conn, ssl.SSLSocket)
self
.
assertIsInstance
(
data
,
bytes
)
self
.
assertIsInstance
(
data
,
bytes
)
self
.
assertIn
(
direction
,
{
'read'
,
'write'
})
self
.
assertIn
(
direction
,
{
'read'
,
'write'
})
msg
.
append
((
direction
,
version
,
content_type
,
msg_type
))
msg
.
append
((
direction
,
version
,
content_type
,
msg_type
))
...
...
src/greentest/3.8/test_subprocess.py
View file @
625c88b0
...
@@ -10,6 +10,7 @@ import os
...
@@ -10,6 +10,7 @@ import os
import
errno
import
errno
import
tempfile
import
tempfile
import
time
import
time
import
traceback
import
selectors
import
selectors
import
sysconfig
import
sysconfig
import
select
import
select
...
@@ -52,10 +53,14 @@ class BaseTestCase(unittest.TestCase):
...
@@ -52,10 +53,14 @@ class BaseTestCase(unittest.TestCase):
support
.
reap_children
()
support
.
reap_children
()
def
tearDown
(
self
):
def
tearDown
(
self
):
if
not
mswindows
:
# subprocess._active is not used on Windows and is set to None.
for
inst
in
subprocess
.
_active
:
for
inst
in
subprocess
.
_active
:
inst
.
wait
()
inst
.
wait
()
subprocess
.
_cleanup
()
subprocess
.
_cleanup
()
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
self
.
doCleanups
()
self
.
doCleanups
()
support
.
reap_children
()
support
.
reap_children
()
...
@@ -1553,6 +1558,26 @@ class RunFuncTestCase(BaseTestCase):
...
@@ -1553,6 +1558,26 @@ class RunFuncTestCase(BaseTestCase):
self
.
assertIn
(
'stderr'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'stderr'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'capture_output'
,
c
.
exception
.
args
[
0
])
self
.
assertIn
(
'capture_output'
,
c
.
exception
.
args
[
0
])
# This test _might_ wind up a bit fragile on loaded build+test machines
# as it depends on the timing with wide enough margins for normal situations
# but does assert that it happened "soon enough" to believe the right thing
# happened.
@
unittest
.
skipIf
(
mswindows
,
"requires posix like 'sleep' shell command"
)
def
test_run_with_shell_timeout_and_capture_output
(
self
):
"""Output capturing after a timeout mustn't hang forever on open filehandles."""
before_secs
=
time
.
monotonic
()
try
:
subprocess
.
run
(
'sleep 3'
,
shell
=
True
,
timeout
=
0.1
,
capture_output
=
True
)
# New session unspecified.
except
subprocess
.
TimeoutExpired
as
exc
:
after_secs
=
time
.
monotonic
()
stacks
=
traceback
.
format_exc
()
# assertRaises doesn't give this.
else
:
self
.
fail
(
"TimeoutExpired not raised."
)
self
.
assertLess
(
after_secs
-
before_secs
,
1.5
,
msg
=
"TimeoutExpired was delayed! Bad traceback:
\
n
```
\
n
"
f"
{
stacks
}
```"
)
@
unittest
.
skipIf
(
mswindows
,
"POSIX specific tests"
)
@
unittest
.
skipIf
(
mswindows
,
"POSIX specific tests"
)
class
POSIXProcessTestCase
(
BaseTestCase
):
class
POSIXProcessTestCase
(
BaseTestCase
):
...
@@ -2672,6 +2697,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2672,6 +2697,10 @@ class POSIXProcessTestCase(BaseTestCase):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
p
=
None
p
=
None
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
# check that p is in the active processes list
# check that p is in the active processes list
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
...
@@ -2694,6 +2723,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2694,6 +2723,10 @@ class POSIXProcessTestCase(BaseTestCase):
p
=
None
p
=
None
os
.
kill
(
pid
,
signal
.
SIGKILL
)
os
.
kill
(
pid
,
signal
.
SIGKILL
)
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
# check that p is in the active processes list
# check that p is in the active processes list
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
...
@@ -2707,6 +2740,10 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2707,6 +2740,10 @@ class POSIXProcessTestCase(BaseTestCase):
pass
pass
# p should have been wait()ed on, and removed from the _active list
# p should have been wait()ed on, and removed from the _active list
self
.
assertRaises
(
OSError
,
os
.
waitpid
,
pid
,
0
)
self
.
assertRaises
(
OSError
,
os
.
waitpid
,
pid
,
0
)
if
mswindows
:
# subprocess._active is not used on Windows and is set to None.
self
.
assertIsNone
(
subprocess
.
_active
)
else
:
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
def
test_close_fds_after_preexec
(
self
):
def
test_close_fds_after_preexec
(
self
):
...
...
src/greentest/3.8/test_threading.py
View file @
625c88b0
...
@@ -18,7 +18,6 @@ import os
...
@@ -18,7 +18,6 @@ import os
import
subprocess
import
subprocess
import
signal
import
signal
# from test import lock_tests
from
gevent.tests
import
lock_tests
# gevent: use our local copy
from
gevent.tests
import
lock_tests
# gevent: use our local copy
from
test
import
support
from
test
import
support
...
...
src/greentest/3.8/test_wsgiref.py
View file @
625c88b0
...
@@ -293,10 +293,9 @@ class IntegrationTests(TestCase):
...
@@ -293,10 +293,9 @@ class IntegrationTests(TestCase):
received
=
len
(
response
.
read
())
received
=
len
(
response
.
read
())
http
.
close
()
http
.
close
()
background
=
threading
.
Thread
(
target
=
run_client
,
name
=
'gevent'
)
background
=
threading
.
Thread
(
target
=
run_client
)
background
.
start
()
background
.
start
()
server
.
handle_request
()
server
.
handle_request
()
print
(
dir
(
background
))
background
.
join
()
background
.
join
()
self
.
assertEqual
(
received
,
support
.
SOCK_MAX_SIZE
-
100
)
self
.
assertEqual
(
received
,
support
.
SOCK_MAX_SIZE
-
100
)
...
@@ -587,10 +586,10 @@ class HandlerTests(TestCase):
...
@@ -587,10 +586,10 @@ class HandlerTests(TestCase):
expected
.
update
({
expected
.
update
({
# X doesn't exist in os_environ
# X doesn't exist in os_environ
"X"
:
"Y"
,
"X"
:
"Y"
,
# HOME is overriden by TestHandler
# HOME is overrid
d
en by TestHandler
'HOME'
:
"/override/home"
,
'HOME'
:
"/override/home"
,
# overriden by setup_testing_defaults()
# overrid
d
en by setup_testing_defaults()
"SCRIPT_NAME"
:
""
,
"SCRIPT_NAME"
:
""
,
"SERVER_NAME"
:
"127.0.0.1"
,
"SERVER_NAME"
:
"127.0.0.1"
,
...
...
src/greentest/3.8/version
View file @
625c88b0
3.8.0
b4
3.8.0
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