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:
Florian Bruhin 2015-08-09 18:47:36 +02:00
parent 0bf651d1fa
commit fe3eb30892
6 changed files with 62 additions and 63 deletions

View File

@ -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'))

View File

@ -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)

View File

@ -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

View File

@ -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):

View File

@ -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

View File

@ -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):