Issue #11500: Fixed a bug in the os x proxy bypass code for fully qualified IP addresses in the proxy exception list.
This commit is contained in:
commit
f2db4de4d8
@ -7,7 +7,9 @@ import socket
|
|||||||
import array
|
import array
|
||||||
|
|
||||||
import urllib.request
|
import urllib.request
|
||||||
from urllib.request import Request, OpenerDirector
|
# The proxy bypass method imported below has logic specific to the OSX
|
||||||
|
# proxy config data structure but is testable on all platforms.
|
||||||
|
from urllib.request import Request, OpenerDirector, _proxy_bypass_macosx_sysconf
|
||||||
|
|
||||||
# XXX
|
# XXX
|
||||||
# Request
|
# Request
|
||||||
@ -1076,6 +1078,17 @@ class HandlerTests(unittest.TestCase):
|
|||||||
self.assertEqual(req.get_host(), "www.python.org")
|
self.assertEqual(req.get_host(), "www.python.org")
|
||||||
del os.environ['no_proxy']
|
del os.environ['no_proxy']
|
||||||
|
|
||||||
|
def test_proxy_no_proxy_all(self):
|
||||||
|
os.environ['no_proxy'] = '*'
|
||||||
|
o = OpenerDirector()
|
||||||
|
ph = urllib.request.ProxyHandler(dict(http="proxy.example.com"))
|
||||||
|
o.add_handler(ph)
|
||||||
|
req = Request("http://www.python.org")
|
||||||
|
self.assertEqual(req.get_host(), "www.python.org")
|
||||||
|
r = o.open(req)
|
||||||
|
self.assertEqual(req.get_host(), "www.python.org")
|
||||||
|
del os.environ['no_proxy']
|
||||||
|
|
||||||
|
|
||||||
def test_proxy_https(self):
|
def test_proxy_https(self):
|
||||||
o = OpenerDirector()
|
o = OpenerDirector()
|
||||||
@ -1116,6 +1129,26 @@ class HandlerTests(unittest.TestCase):
|
|||||||
self.assertEqual(req.get_host(), "proxy.example.com:3128")
|
self.assertEqual(req.get_host(), "proxy.example.com:3128")
|
||||||
self.assertEqual(req.get_header("Proxy-authorization"),"FooBar")
|
self.assertEqual(req.get_header("Proxy-authorization"),"FooBar")
|
||||||
|
|
||||||
|
def test_osx_proxy_bypass(self):
|
||||||
|
bypass = {
|
||||||
|
'exclude_simple': False,
|
||||||
|
'exceptions': ['foo.bar', '*.bar.com', '127.0.0.1', '10.10',
|
||||||
|
'10.0/16']
|
||||||
|
}
|
||||||
|
# Check hosts that should trigger the proxy bypass
|
||||||
|
for host in ('foo.bar', 'www.bar.com', '127.0.0.1', '10.10.0.1',
|
||||||
|
'10.0.0.1'):
|
||||||
|
self.assertTrue(_proxy_bypass_macosx_sysconf(host, bypass),
|
||||||
|
'expected bypass of %s to be True' % host)
|
||||||
|
# Check hosts that should not trigger the proxy bypass
|
||||||
|
for host in ('abc.foo.bar', 'bar.com', '127.0.0.2', '10.11.0.1', 'test'):
|
||||||
|
self.assertFalse(_proxy_bypass_macosx_sysconf(host, bypass),
|
||||||
|
'expected bypass of %s to be False' % host)
|
||||||
|
|
||||||
|
# Check the exclude_simple flag
|
||||||
|
bypass = {'exclude_simple': True, 'exceptions': []}
|
||||||
|
self.assertTrue(_proxy_bypass_macosx_sysconf('test', bypass))
|
||||||
|
|
||||||
def test_basic_auth(self, quote_char='"'):
|
def test_basic_auth(self, quote_char='"'):
|
||||||
opener = OpenerDirector()
|
opener = OpenerDirector()
|
||||||
password_manager = MockPasswordManager()
|
password_manager = MockPasswordManager()
|
||||||
|
@ -2208,15 +2208,19 @@ def proxy_bypass_environment(host):
|
|||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
if sys.platform == 'darwin':
|
# This code tests an OSX specific data structure but is testable on all
|
||||||
from _scproxy import _get_proxy_settings, _get_proxies
|
# platforms
|
||||||
|
def _proxy_bypass_macosx_sysconf(host, proxy_settings):
|
||||||
def proxy_bypass_macosx_sysconf(host):
|
|
||||||
"""
|
"""
|
||||||
Return True iff this host shouldn't be accessed using a proxy
|
Return True iff this host shouldn't be accessed using a proxy
|
||||||
|
|
||||||
This function uses the MacOSX framework SystemConfiguration
|
This function uses the MacOSX framework SystemConfiguration
|
||||||
to fetch the proxy information.
|
to fetch the proxy information.
|
||||||
|
|
||||||
|
proxy_settings come from _scproxy._get_proxy_settings or get mocked ie:
|
||||||
|
{ 'exclude_simple': bool,
|
||||||
|
'exceptions': ['foo.bar', '*.bar.com', '127.0.0.1', '10.1', '10.0/16']
|
||||||
|
}
|
||||||
"""
|
"""
|
||||||
import re
|
import re
|
||||||
import socket
|
import socket
|
||||||
@ -2231,8 +2235,6 @@ if sys.platform == 'darwin':
|
|||||||
parts = (parts + [0, 0, 0, 0])[:4]
|
parts = (parts + [0, 0, 0, 0])[:4]
|
||||||
return (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8) | parts[3]
|
return (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8) | parts[3]
|
||||||
|
|
||||||
proxy_settings = _get_proxy_settings()
|
|
||||||
|
|
||||||
# Check for simple host names:
|
# Check for simple host names:
|
||||||
if '.' not in host:
|
if '.' not in host:
|
||||||
if proxy_settings['exclude_simple']:
|
if proxy_settings['exclude_simple']:
|
||||||
@ -2257,7 +2259,6 @@ if sys.platform == 'darwin':
|
|||||||
mask = m.group(2)
|
mask = m.group(2)
|
||||||
if mask is None:
|
if mask is None:
|
||||||
mask = 8 * (m.group(1).count('.') + 1)
|
mask = 8 * (m.group(1).count('.') + 1)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
mask = int(mask[1:])
|
mask = int(mask[1:])
|
||||||
mask = 32 - mask
|
mask = 32 - mask
|
||||||
@ -2271,6 +2272,13 @@ if sys.platform == 'darwin':
|
|||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
if sys.platform == 'darwin':
|
||||||
|
from _scproxy import _get_proxy_settings, _get_proxies
|
||||||
|
|
||||||
|
def proxy_bypass_macosx_sysconf(host):
|
||||||
|
proxy_settings = _get_proxy_settings()
|
||||||
|
return _proxy_bypass_macosx_sysconf(host, proxy_settings)
|
||||||
|
|
||||||
def getproxies_macosx_sysconf():
|
def getproxies_macosx_sysconf():
|
||||||
"""Return a dictionary of scheme -> proxy server URL mappings.
|
"""Return a dictionary of scheme -> proxy server URL mappings.
|
||||||
|
|
||||||
|
@ -34,6 +34,9 @@ Core and Builtins
|
|||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #11500: Fixed a bug in the os x proxy bypass code for fully qualified
|
||||||
|
IP addresses in the proxy exception list.
|
||||||
|
|
||||||
- Issue #11491: dbm.error is no longer raised when dbm.open is called with
|
- Issue #11491: dbm.error is no longer raised when dbm.open is called with
|
||||||
the "n" as the flag argument and the file exists. The behavior matches
|
the "n" as the flag argument and the file exists. The behavior matches
|
||||||
the documentation and general logic.
|
the documentation and general logic.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user