Merge branch 'abbradar-more-pac'

This commit is contained in:
Florian Bruhin 2017-02-04 18:12:29 +01:00
commit 21d2d04f45
6 changed files with 42 additions and 4 deletions

View File

@ -38,6 +38,7 @@ Fixed
- Fixed hints sometimes not working with Qt 5.8 - Fixed hints sometimes not working with Qt 5.8
- `:enter-mode` now refuses to enter modes which can't be entered manually (which caused crashes). - `:enter-mode` now refuses to enter modes which can't be entered manually (which caused crashes).
- `:record-macro` (`q`) now doesn't try to record macros for special keys without a text. - `:record-macro` (`q`) now doesn't try to record macros for special keys without a text.
- Fixed PAC (proxy autoconfig) not working with QtWebKit
v0.9.1 v0.9.1
------ ------

View File

@ -187,6 +187,7 @@ Contributors, sorted by the number of commits in descending order:
* Oliver Caldwell * Oliver Caldwell
* Julian Weigt * Julian Weigt
* Sebastian Frysztak * Sebastian Frysztak
* Nikolay Amiantov
* Jonas Schürmann * Jonas Schürmann
* error800 * error800
* Michael Hoang * Michael Hoang
@ -197,7 +198,6 @@ Contributors, sorted by the number of commits in descending order:
* Tomasz Kramkowski * Tomasz Kramkowski
* Samuel Walladge * Samuel Walladge
* Peter Rice * Peter Rice
* Nikolay Amiantov
* Ismail S * Ismail S
* Halfwit * Halfwit
* David Vogt * David Vogt

View File

@ -126,7 +126,7 @@ class _PACContext(QObject):
return QHostAddress(QHostAddress.LocalHost).toString() return QHostAddress(QHostAddress.LocalHost).toString()
class PACResolver(object): class PACResolver:
"""Evaluate PAC script files and resolve proxies.""" """Evaluate PAC script files and resolve proxies."""

View File

@ -614,7 +614,7 @@ def proxy_from_url(url):
scheme = url.scheme() scheme = url.scheme()
if scheme in ['pac+http', 'pac+https']: if scheme in ['pac+http', 'pac+https']:
return pac.PACFetcher return pac.PACFetcher(url)
types = { types = {
'http': QNetworkProxy.HttpProxy, 'http': QNetworkProxy.HttpProxy,

View File

@ -125,6 +125,43 @@ def test_invalid_port():
res.resolve(QNetworkProxyQuery(QUrl("https://example.com/test"))) res.resolve(QNetworkProxyQuery(QUrl("https://example.com/test")))
@pytest.mark.parametrize(string, ["", "{"])
def test_wrong_pac_string(string):
with pytest.raises(pac.EvalProxyError):
pac.PACResolver(string)
@pytest.mark.parametrize("value", [
"",
"DIRECT FOO",
"PROXY",
"SOCKS",
"FOOBAR",
])
def test_fail_parse(value):
test_str_f = """
function FindProxyForURL(domain, host) {{
return "{}";
}}
"""
res = pac.PACResolver(test_str_f.format(value))
with pytest.raises(pac.ParseProxyError):
res.resolve(QNetworkProxyQuery(QUrl("https://example.com/test")))
def test_fail_return():
test_str = """
function FindProxyForURL(domain, host) {
return null;
}
"""
res = pac.PACResolver(test_str)
with pytest.raises(pac.EvalProxyError):
res.resolve(QNetworkProxyQuery(QUrl("https://example.com/test")))
# See https://github.com/The-Compiler/qutebrowser/pull/1891#issuecomment-259222615 # See https://github.com/The-Compiler/qutebrowser/pull/1891#issuecomment-259222615
try: try:

View File

@ -765,7 +765,7 @@ class TestProxyFromUrl:
@pytest.mark.parametrize('scheme', ['pac+http', 'pac+https']) @pytest.mark.parametrize('scheme', ['pac+http', 'pac+https'])
def test_proxy_from_url_pac(self, scheme): def test_proxy_from_url_pac(self, scheme):
fetcher = urlutils.proxy_from_url(QUrl('{}://foo'.format(scheme))) fetcher = urlutils.proxy_from_url(QUrl('{}://foo'.format(scheme)))
assert fetcher is pac.PACFetcher assert isinstance(fetcher, pac.PACFetcher)
@pytest.mark.parametrize('url, exception', [ @pytest.mark.parametrize('url, exception', [
('blah', urlutils.InvalidProxyTypeError), ('blah', urlutils.InvalidProxyTypeError),