SQL code review.

- Fix flake8
- history.clear should also clear completion table
- call _resize_columns in set_model, not set_pattern
- add more unit-testing for the history completion table
This commit is contained in:
Ryan Roden-Corrent 2017-07-12 22:14:27 -04:00
parent ea459a1eca
commit 1aed2470e5
4 changed files with 19 additions and 5 deletions

View File

@ -28,7 +28,7 @@ exclude = .*,__pycache__,resources.py
ignore = ignore =
E128,E226,E265,E501,E402,E266,E722,E731, E128,E226,E265,E501,E402,E266,E722,E731,
F401, F401,
N802,N806 N802,
P101,P102,P103, P101,P102,P103,
D102,D103,D104,D105,D209,D211,D402,D403 D102,D103,D104,D105,D209,D211,D402,D403
min-version = 3.4.0 min-version = 3.4.0
@ -39,7 +39,7 @@ putty-ignore =
/# pragma: no mccabe/ : +C901 /# pragma: no mccabe/ : +C901
tests/*/test_*.py : +D100,D101,D401 tests/*/test_*.py : +D100,D101,D401
tests/conftest.py : +F403 tests/conftest.py : +F403
tests/unit/browser/webkit/test_history.py : +N806 tests/unit/browser/test_history.py : +N806
tests/helpers/fixtures.py : +N806 tests/helpers/fixtures.py : +N806
tests/unit/browser/webkit/http/test_content_disposition.py : +D400 tests/unit/browser/webkit/http/test_content_disposition.py : +D400
scripts/dev/ci/appveyor_install.py : +FI53 scripts/dev/ci/appveyor_install.py : +FI53

View File

@ -115,6 +115,7 @@ class WebHistory(sql.SqlTable):
def _do_clear(self): def _do_clear(self):
self.delete_all() self.delete_all()
self.completion.delete_all()
def delete_url(self, url): def delete_url(self, url):
"""Remove all history entries with the given url. """Remove all history entries with the given url.

View File

@ -286,16 +286,17 @@ class CompletionView(QTreeView):
self._active = True self._active = True
self._maybe_show() self._maybe_show()
self._resize_columns()
for i in range(model.rowCount()): for i in range(model.rowCount()):
self.expand(model.index(i, 0)) self.expand(model.index(i, 0))
def set_pattern(self, pattern): def set_pattern(self, pattern):
"""Set the pattern on the underlying model."""
if not self.model(): if not self.model():
return return
self.pattern = pattern self.pattern = pattern
with debug.log_time(log.completion, 'Set pattern {}'.format(pattern)): with debug.log_time(log.completion, 'Set pattern {}'.format(pattern)):
self.model().set_pattern(pattern) self.model().set_pattern(pattern)
self._resize_columns()
self._maybe_update_geometry() self._maybe_update_geometry()
self._maybe_show() self._maybe_show()

View File

@ -123,6 +123,7 @@ def test_clear_force(qtbot, tmpdir, hist):
hist.add_url(QUrl('http://www.qutebrowser.org/')) hist.add_url(QUrl('http://www.qutebrowser.org/'))
hist.clear(force=True) hist.clear(force=True)
assert not len(hist) assert not len(hist)
assert not len(hist.completion)
def test_delete_url(hist): def test_delete_url(hist):
@ -131,10 +132,16 @@ def test_delete_url(hist):
hist.add_url(QUrl('http://example.com/2'), atime=0) hist.add_url(QUrl('http://example.com/2'), atime=0)
before = set(hist) before = set(hist)
completion_before = set(hist.completion)
hist.delete_url(QUrl('http://example.com/1')) hist.delete_url(QUrl('http://example.com/1'))
diff = before.difference(set(hist)) diff = before.difference(set(hist))
assert diff == {('http://example.com/1', '', 0, False)} assert diff == {('http://example.com/1', '', 0, False)}
completion_diff = completion_before.difference(set(hist.completion))
assert completion_diff == {('http://example.com/1', '', 0)}
@pytest.mark.parametrize('url, atime, title, redirect, expected_url', [ @pytest.mark.parametrize('url, atime, title, redirect, expected_url', [
('http://www.example.com', 12346, 'the title', False, ('http://www.example.com', 12346, 'the title', False,
@ -146,15 +153,20 @@ def test_delete_url(hist):
('https://user:pass@example.com', 12346, 'the title', False, ('https://user:pass@example.com', 12346, 'the title', False,
'https://user@example.com'), 'https://user@example.com'),
]) ])
def test_add_item(qtbot, hist, url, atime, title, redirect, expected_url): def test_add_url(qtbot, hist, url, atime, title, redirect, expected_url):
hist.add_url(QUrl(url), atime=atime, title=title, redirect=redirect) hist.add_url(QUrl(url), atime=atime, title=title, redirect=redirect)
assert list(hist) == [(expected_url, title, atime, redirect)] assert list(hist) == [(expected_url, title, atime, redirect)]
if redirect:
assert not len(hist.completion)
else:
assert list(hist.completion) == [(expected_url, title, atime)]
def test_add_item_invalid(qtbot, hist, caplog): def test_add_url_invalid(qtbot, hist, caplog):
with caplog.at_level(logging.WARNING): with caplog.at_level(logging.WARNING):
hist.add_url(QUrl()) hist.add_url(QUrl())
assert not list(hist) assert not list(hist)
assert not list(hist.completion)
@pytest.mark.parametrize('level, url, req_url, expected', [ @pytest.mark.parametrize('level, url, req_url, expected', [