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
9796e85a
Commit
9796e85a
authored
Nov 18, 2019
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
A change in subprocess._active broke Windows tests, so update test versions.
parent
85a42dd8
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
683 additions
and
336 deletions
+683
-336
scripts/install.sh
scripts/install.sh
+2
-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.
scripts/install.sh
View file @
9796e85a
...
@@ -29,8 +29,8 @@ else
...
@@ -29,8 +29,8 @@ else
# and it's pretty large.
# and it's pretty large.
# So if we need to incorporate changes from pyenv, either temporarily
# So if we need to incorporate changes from pyenv, either temporarily
# turn this back on, or remove the Travis caches.
# turn this back on, or remove the Travis caches.
#
git fetch || echo "Fetch failed to complete. Ignoring"
git fetch
||
echo
"Fetch failed to complete. Ignoring"
#
git reset --hard origin/master
git reset
--hard
origin/master
cd
$back
cd
$back
fi
fi
...
...
src/greentest/3.7/keycert.passwd.pem
View file @
9796e85a
-----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 @
9796e85a
-----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.7/test_httplib.py
View file @
9796e85a
...
@@ -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 @
9796e85a
...
@@ -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.
minimum_range
=
{
# stock OpenSSL
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
self
.
assertIn
(
self
.
assertIn
(
ctx
.
minimum_version
,
ctx
.
minimum_version
,
minimum_range
{
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
)
)
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
if
has_tls_version
(
'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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
if
has_tls_version
(
'TLSv1'
):
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
if
has_tls_version
(
'TLSv1'
):
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
if
has_tls_version
(
'TLSv1'
):
server_options
=
ssl
.
OP_NO_TLSv1
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
server_options
=
ssl
.
OP_NO_TLSv1
)
@
skip_if_broken_ubuntu_ssl
@
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
:
...
@@ -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 @
9796e85a
...
@@ -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
):
for
inst
in
subprocess
.
_active
:
if
not
mswindows
:
inst
.
wait
()
# subprocess._active is not used on Windows and is set to None.
subprocess
.
_cleanup
()
for
inst
in
subprocess
.
_active
:
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
inst
.
wait
()
subprocess
.
_cleanup
()
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,8 +2647,12 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2622,8 +2647,12 @@ class POSIXProcessTestCase(BaseTestCase):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
p
=
None
p
=
None
# check that p is in the active processes list
if
mswindows
:
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# 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
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
def
test_leak_fast_process_del_killed
(
self
):
def
test_leak_fast_process_del_killed
(
self
):
# Issue #12650: on Unix, if Popen.__del__() was called before the
# Issue #12650: on Unix, if Popen.__del__() was called before the
...
@@ -2644,8 +2673,12 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2644,8 +2673,12 @@ class POSIXProcessTestCase(BaseTestCase):
p
=
None
p
=
None
os
.
kill
(
pid
,
signal
.
SIGKILL
)
os
.
kill
(
pid
,
signal
.
SIGKILL
)
# check that p is in the active processes list
if
mswindows
:
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# 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
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# let some time for the process to exit, and create a new Popen: this
# let some time for the process to exit, and create a new Popen: this
# should trigger the wait() of p
# should trigger the wait() of p
...
@@ -2657,7 +2690,11 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2657,7 +2690,11 @@ 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
)
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
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
])
def
test_close_fds_after_preexec
(
self
):
def
test_close_fds_after_preexec
(
self
):
fd_status
=
support
.
findfile
(
"fd_status.py"
,
subdir
=
"subprocessdata"
)
fd_status
=
support
.
findfile
(
"fd_status.py"
,
subdir
=
"subprocessdata"
)
...
...
src/greentest/3.7/test_wsgiref.py
View file @
9796e85a
...
@@ -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 @
9796e85a
3.7.
2
3.7.
5
src/greentest/3.8/keycert.passwd.pem
View file @
9796e85a
-----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 @
9796e85a
-----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 @
9796e85a
...
@@ -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 @
9796e85a
...
@@ -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 @
9796e85a
...
@@ -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.
minimum_range
=
{
# stock OpenSSL
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
self
.
assertIn
(
self
.
assertIn
(
ctx
.
minimum_version
,
ctx
.
minimum_version
,
minimum_range
{
ssl
.
TLSVersion
.
MINIMUM_SUPPORTED
,
# Fedora 29 uses TLS 1.0 by default
ssl
.
TLSVersion
.
TLSv1
,
# RHEL 8 uses TLS 1.2 by default
ssl
.
TLSVersion
.
TLSv1_2
}
)
)
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
)
if
has_tls_version
(
'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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_OPTIONAL
)
if
has_tls_version
(
'TLSv1'
):
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
'TLSv1'
,
ssl
.
CERT_REQUIRED
)
if
has_tls_version
(
'TLSv1'
):
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
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
if
has_tls_version
(
'TLSv1'
):
server_options
=
ssl
.
OP_NO_TLSv1
)
try_protocol_combo
(
ssl
.
PROTOCOL_TLS
,
ssl
.
PROTOCOL_TLSv1
,
False
,
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 @
9796e85a
...
@@ -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
):
for
inst
in
subprocess
.
_active
:
if
not
mswindows
:
inst
.
wait
()
# subprocess._active is not used on Windows and is set to None.
subprocess
.
_cleanup
()
for
inst
in
subprocess
.
_active
:
self
.
assertFalse
(
subprocess
.
_active
,
"subprocess._active not empty"
)
inst
.
wait
()
subprocess
.
_cleanup
()
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,8 +2697,12 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2672,8 +2697,12 @@ class POSIXProcessTestCase(BaseTestCase):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
with
support
.
check_warnings
((
''
,
ResourceWarning
)):
p
=
None
p
=
None
# check that p is in the active processes list
if
mswindows
:
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# 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
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
def
test_leak_fast_process_del_killed
(
self
):
def
test_leak_fast_process_del_killed
(
self
):
# Issue #12650: on Unix, if Popen.__del__() was called before the
# Issue #12650: on Unix, if Popen.__del__() was called before the
...
@@ -2694,8 +2723,12 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2694,8 +2723,12 @@ class POSIXProcessTestCase(BaseTestCase):
p
=
None
p
=
None
os
.
kill
(
pid
,
signal
.
SIGKILL
)
os
.
kill
(
pid
,
signal
.
SIGKILL
)
# check that p is in the active processes list
if
mswindows
:
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# 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
self
.
assertIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
# let some time for the process to exit, and create a new Popen: this
# let some time for the process to exit, and create a new Popen: this
# should trigger the wait() of p
# should trigger the wait() of p
...
@@ -2707,7 +2740,11 @@ class POSIXProcessTestCase(BaseTestCase):
...
@@ -2707,7 +2740,11 @@ 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
)
self
.
assertNotIn
(
ident
,
[
id
(
o
)
for
o
in
subprocess
.
_active
])
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
])
def
test_close_fds_after_preexec
(
self
):
def
test_close_fds_after_preexec
(
self
):
fd_status
=
support
.
findfile
(
"fd_status.py"
,
subdir
=
"subprocessdata"
)
fd_status
=
support
.
findfile
(
"fd_status.py"
,
subdir
=
"subprocessdata"
)
...
...
src/greentest/3.8/test_threading.py
View file @
9796e85a
...
@@ -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 @
9796e85a
...
@@ -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 @
9796e85a
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