Reorganize exceptions in urlutils.
- Instead of ValueError, a new InvalidUrlError is raised with invalid URLs. - FuzzyUrlError got removed as it's basically the same as InvalidUrlError.
This commit is contained in:
parent
0bf651d1fa
commit
fe3eb30892
@ -272,7 +272,7 @@ def process_pos_args(args, via_ipc=False, cwd=None):
|
|||||||
log.init.debug("Startup URL {}".format(cmd))
|
log.init.debug("Startup URL {}".format(cmd))
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(cmd, cwd, relative=True)
|
url = urlutils.fuzzy_url(cmd, cwd, relative=True)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
message.error('current', "Error in startup argument '{}': "
|
message.error('current', "Error in startup argument '{}': "
|
||||||
"{}".format(cmd, e))
|
"{}".format(cmd, e))
|
||||||
else:
|
else:
|
||||||
@ -302,7 +302,7 @@ def _open_startpage(win_id=None):
|
|||||||
for urlstr in config.get('general', 'startpage'):
|
for urlstr in config.get('general', 'startpage'):
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(urlstr, do_search=False)
|
url = urlutils.fuzzy_url(urlstr, do_search=False)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
message.error('current', "Error when opening startpage: "
|
message.error('current', "Error when opening startpage: "
|
||||||
"{}".format(e))
|
"{}".format(e))
|
||||||
tabbed_browser.tabopen(QUrl('about:blank'))
|
tabbed_browser.tabopen(QUrl('about:blank'))
|
||||||
|
@ -303,7 +303,7 @@ class CommandDispatcher:
|
|||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(url)
|
url = urlutils.fuzzy_url(url)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
raise cmdexc.CommandError(e)
|
raise cmdexc.CommandError(e)
|
||||||
if tab or bg or window:
|
if tab or bg or window:
|
||||||
self._open(url, tab, bg, window)
|
self._open(url, tab, bg, window)
|
||||||
@ -869,7 +869,7 @@ class CommandDispatcher:
|
|||||||
log.misc.debug("{} contained: '{}'".format(target, text))
|
log.misc.debug("{} contained: '{}'".format(target, text))
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(text)
|
url = urlutils.fuzzy_url(text)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
raise cmdexc.CommandError(e)
|
raise cmdexc.CommandError(e)
|
||||||
self._open(url, tab, bg, window)
|
self._open(url, tab, bg, window)
|
||||||
|
|
||||||
@ -1063,7 +1063,7 @@ class CommandDispatcher:
|
|||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(url)
|
url = urlutils.fuzzy_url(url)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
raise cmdexc.CommandError(e)
|
raise cmdexc.CommandError(e)
|
||||||
self._open(url, tab, bg, window)
|
self._open(url, tab, bg, window)
|
||||||
|
|
||||||
|
@ -225,7 +225,7 @@ class QuickmarkManager(UrlMarkManager):
|
|||||||
urlstr = self.marks[name]
|
urlstr = self.marks[name]
|
||||||
try:
|
try:
|
||||||
url = urlutils.fuzzy_url(urlstr, do_search=False)
|
url = urlutils.fuzzy_url(urlstr, do_search=False)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
raise InvalidUrlError(
|
raise InvalidUrlError(
|
||||||
"Invalid URL for quickmark {}: {}".format(name, str(e)))
|
"Invalid URL for quickmark {}: {}".format(name, str(e)))
|
||||||
return url
|
return url
|
||||||
|
@ -1113,7 +1113,7 @@ class FuzzyUrl(BaseType):
|
|||||||
from qutebrowser.utils import urlutils
|
from qutebrowser.utils import urlutils
|
||||||
try:
|
try:
|
||||||
self.transform(value)
|
self.transform(value)
|
||||||
except urlutils.FuzzyUrlError as e:
|
except urlutils.InvalidUrlError as e:
|
||||||
raise configexc.ValidationError(value, str(e))
|
raise configexc.ValidationError(value, str(e))
|
||||||
|
|
||||||
def transform(self, value):
|
def transform(self, value):
|
||||||
|
@ -37,6 +37,22 @@ from qutebrowser.commands import cmdexc
|
|||||||
# https://github.com/The-Compiler/qutebrowser/issues/108
|
# https://github.com/The-Compiler/qutebrowser/issues/108
|
||||||
|
|
||||||
|
|
||||||
|
class InvalidUrlError(ValueError):
|
||||||
|
|
||||||
|
"""Error raised if a function got an invalid URL.
|
||||||
|
|
||||||
|
Inherits ValueError because that was the exception originally used for
|
||||||
|
that, so there still might be some code around which checks for that.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, url):
|
||||||
|
if url.isValid():
|
||||||
|
raise ValueError("Got valid URL {}!".format(url.toDisplayString()))
|
||||||
|
self.url = url
|
||||||
|
self.msg = get_errstring(url)
|
||||||
|
super().__init__(self.msg)
|
||||||
|
|
||||||
|
|
||||||
def _parse_search_term(s):
|
def _parse_search_term(s):
|
||||||
"""Get a search engine name and search term from a string.
|
"""Get a search engine name and search term from a string.
|
||||||
|
|
||||||
@ -185,7 +201,7 @@ def fuzzy_url(urlstr, cwd=None, relative=False, do_search=True):
|
|||||||
qtutils.ensure_valid(url)
|
qtutils.ensure_valid(url)
|
||||||
else:
|
else:
|
||||||
if not url.isValid():
|
if not url.isValid():
|
||||||
raise FuzzyUrlError("Invalid URL '{}'!".format(urlstr), url)
|
raise InvalidUrlError(url)
|
||||||
return url
|
return url
|
||||||
|
|
||||||
|
|
||||||
@ -355,7 +371,7 @@ def host_tuple(url):
|
|||||||
This is suitable to identify a connection, e.g. for SSL errors.
|
This is suitable to identify a connection, e.g. for SSL errors.
|
||||||
"""
|
"""
|
||||||
if not url.isValid():
|
if not url.isValid():
|
||||||
raise ValueError(get_errstring(url))
|
raise InvalidUrlError(url)
|
||||||
scheme, host, port = url.scheme(), url.host(), url.port()
|
scheme, host, port = url.scheme(), url.host(), url.port()
|
||||||
assert scheme
|
assert scheme
|
||||||
if not host:
|
if not host:
|
||||||
@ -405,9 +421,9 @@ def same_domain(url1, url2):
|
|||||||
True if the domains are the same, False otherwise.
|
True if the domains are the same, False otherwise.
|
||||||
"""
|
"""
|
||||||
if not url1.isValid():
|
if not url1.isValid():
|
||||||
raise ValueError(get_errstring(url1))
|
raise InvalidUrlError(url1)
|
||||||
if not url2.isValid():
|
if not url2.isValid():
|
||||||
raise ValueError(get_errstring(url2))
|
raise InvalidUrlError(url2)
|
||||||
|
|
||||||
suffix1 = url1.topLevelDomain()
|
suffix1 = url1.topLevelDomain()
|
||||||
suffix2 = url2.topLevelDomain()
|
suffix2 = url2.topLevelDomain()
|
||||||
@ -422,29 +438,6 @@ def same_domain(url1, url2):
|
|||||||
return domain1 == domain2
|
return domain1 == domain2
|
||||||
|
|
||||||
|
|
||||||
class FuzzyUrlError(Exception):
|
|
||||||
|
|
||||||
"""Exception raised by fuzzy_url on problems.
|
|
||||||
|
|
||||||
Attributes:
|
|
||||||
msg: The error message to use.
|
|
||||||
url: The QUrl which caused the error.
|
|
||||||
"""
|
|
||||||
|
|
||||||
def __init__(self, msg, url=None):
|
|
||||||
super().__init__(msg)
|
|
||||||
if url is not None and url.isValid():
|
|
||||||
raise ValueError("Got valid URL {}!".format(url.toDisplayString()))
|
|
||||||
self.url = url
|
|
||||||
self.msg = msg
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
if self.url is None or not self.url.errorString():
|
|
||||||
return self.msg
|
|
||||||
else:
|
|
||||||
return '{}: {}'.format(self.msg, self.url.errorString())
|
|
||||||
|
|
||||||
|
|
||||||
class IncDecError(Exception):
|
class IncDecError(Exception):
|
||||||
|
|
||||||
"""Exception raised by incdec_number on problems.
|
"""Exception raised by incdec_number on problems.
|
||||||
@ -476,7 +469,7 @@ def incdec_number(url, incdec):
|
|||||||
Raises IncDecError if the url contains no number.
|
Raises IncDecError if the url contains no number.
|
||||||
"""
|
"""
|
||||||
if not url.isValid():
|
if not url.isValid():
|
||||||
raise ValueError(get_errstring(url))
|
raise InvalidUrlError(url)
|
||||||
|
|
||||||
path = url.path()
|
path = url.path()
|
||||||
# Get the last number in a string
|
# Get the last number in a string
|
||||||
|
@ -219,7 +219,7 @@ class TestFuzzyUrl:
|
|||||||
|
|
||||||
@pytest.mark.parametrize('do_search, exception', [
|
@pytest.mark.parametrize('do_search, exception', [
|
||||||
(True, qtutils.QtValueError),
|
(True, qtutils.QtValueError),
|
||||||
(False, urlutils.FuzzyUrlError),
|
(False, urlutils.InvalidUrlError),
|
||||||
])
|
])
|
||||||
def test_invalid_url(self, do_search, exception, is_url_mock, monkeypatch):
|
def test_invalid_url(self, do_search, exception, is_url_mock, monkeypatch):
|
||||||
"""Test with an invalid URL."""
|
"""Test with an invalid URL."""
|
||||||
@ -469,34 +469,40 @@ def test_host_tuple(qurl, tpl):
|
|||||||
assert urlutils.host_tuple(qurl) == tpl
|
assert urlutils.host_tuple(qurl) == tpl
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('url, raising, has_err_string', [
|
class TestInvalidUrlError:
|
||||||
(None, False, False),
|
|
||||||
(QUrl(), False, False),
|
|
||||||
(QUrl('http://www.example.com/'), True, False),
|
|
||||||
(QUrl('://'), False, True),
|
|
||||||
])
|
|
||||||
def test_fuzzy_url_error(url, raising, has_err_string):
|
|
||||||
"""Test FuzzyUrlError.
|
|
||||||
|
|
||||||
Args:
|
@pytest.mark.parametrize('url, raising, has_err_string', [
|
||||||
url: The URL to pass to FuzzyUrlError.
|
(QUrl(), False, False),
|
||||||
raising; True if the FuzzyUrlError should raise itself.
|
(QUrl('http://www.example.com/'), True, False),
|
||||||
has_err_string: Whether the QUrl is expected to have errorString set.
|
(QUrl('://'), False, True),
|
||||||
"""
|
])
|
||||||
if raising:
|
def test_invalid_url_error(self, url, raising, has_err_string):
|
||||||
expected_exc = ValueError
|
"""Test InvalidUrlError.
|
||||||
else:
|
|
||||||
expected_exc = urlutils.FuzzyUrlError
|
|
||||||
|
|
||||||
with pytest.raises(expected_exc) as excinfo:
|
Args:
|
||||||
raise urlutils.FuzzyUrlError("Error message", url)
|
url: The URL to pass to InvalidUrlError.
|
||||||
|
raising; True if the InvalidUrlError should raise itself.
|
||||||
if not raising:
|
has_err_string: Whether the QUrl is expected to have errorString
|
||||||
if has_err_string:
|
set.
|
||||||
expected_text = "Error message: " + url.errorString()
|
"""
|
||||||
|
if raising:
|
||||||
|
expected_exc = ValueError
|
||||||
else:
|
else:
|
||||||
expected_text = "Error message"
|
expected_exc = urlutils.InvalidUrlError
|
||||||
assert str(excinfo.value) == expected_text
|
|
||||||
|
with pytest.raises(expected_exc) as excinfo:
|
||||||
|
raise urlutils.InvalidUrlError(url)
|
||||||
|
|
||||||
|
if not raising:
|
||||||
|
expected_text = "Invalid URL"
|
||||||
|
if has_err_string:
|
||||||
|
expected_text += " - " + url.errorString()
|
||||||
|
assert str(excinfo.value) == expected_text
|
||||||
|
|
||||||
|
def test_value_error_subclass(self):
|
||||||
|
"""Make sure InvalidUrlError is a ValueError subclass."""
|
||||||
|
with pytest.raises(ValueError):
|
||||||
|
raise urlutils.InvalidUrlError(QUrl())
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('are_same, url1, url2', [
|
@pytest.mark.parametrize('are_same, url1, url2', [
|
||||||
@ -522,7 +528,7 @@ def test_same_domain(are_same, url1, url2):
|
|||||||
])
|
])
|
||||||
def test_same_domain_invalid_url(url1, url2):
|
def test_same_domain_invalid_url(url1, url2):
|
||||||
"""Test same_domain with invalid URLs."""
|
"""Test same_domain with invalid URLs."""
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(urlutils.InvalidUrlError):
|
||||||
urlutils.same_domain(QUrl(url1), QUrl(url2))
|
urlutils.same_domain(QUrl(url1), QUrl(url2))
|
||||||
|
|
||||||
class TestIncDecNumber:
|
class TestIncDecNumber:
|
||||||
@ -570,7 +576,7 @@ class TestIncDecNumber:
|
|||||||
|
|
||||||
def test_invalid_url(self):
|
def test_invalid_url(self):
|
||||||
"""Test if incdec_number rejects an invalid URL."""
|
"""Test if incdec_number rejects an invalid URL."""
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(urlutils.InvalidUrlError):
|
||||||
urlutils.incdec_number(QUrl(""), "increment")
|
urlutils.incdec_number(QUrl(""), "increment")
|
||||||
|
|
||||||
def test_wrong_mode(self):
|
def test_wrong_mode(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user