Merge branch 'acogneau-autoupdate_tests'
This commit is contained in:
commit
44f594662a
@ -137,8 +137,8 @@ Contributors, sorted by the number of commits in descending order:
|
||||
* Antoni Boucher
|
||||
* Bruno Oliveira
|
||||
* Martin Tournoij
|
||||
* Raphael Pierzina
|
||||
* Alexander Cogneau
|
||||
* Raphael Pierzina
|
||||
* Joel Torstensson
|
||||
* Claude
|
||||
* Lamar Pavel
|
||||
|
@ -49,9 +49,12 @@ class PyPIVersionClient(QObject):
|
||||
success = pyqtSignal(str)
|
||||
error = pyqtSignal(str)
|
||||
|
||||
def __init__(self, parent=None):
|
||||
def __init__(self, parent=None, client=None):
|
||||
super().__init__(parent)
|
||||
self._client = httpclient.HTTPClient(self)
|
||||
if client is None:
|
||||
self._client = httpclient.HTTPClient(self)
|
||||
else:
|
||||
self._client = client
|
||||
self._client.error.connect(self.error)
|
||||
self._client.success.connect(self.on_client_success)
|
||||
|
||||
|
@ -48,6 +48,7 @@ PERFECT_FILES = [
|
||||
|
||||
'qutebrowser/keyinput/basekeyparser.py',
|
||||
|
||||
'qutebrowser/misc/autoupdate.py',
|
||||
'qutebrowser/misc/readline.py',
|
||||
'qutebrowser/misc/split.py',
|
||||
'qutebrowser/misc/msgbox.py',
|
||||
|
103
tests/unit/misc/test_autoupdate.py
Normal file
103
tests/unit/misc/test_autoupdate.py
Normal file
@ -0,0 +1,103 @@
|
||||
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
||||
|
||||
# Copyright 2015 Alexander Cogneau (acogneau) <alexander.cogneau@gmail.com>:
|
||||
#
|
||||
# This file is part of qutebrowser.
|
||||
#
|
||||
# qutebrowser is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# qutebrowser is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
"""Tests for qutebrowser.misc.autoupdate"""
|
||||
|
||||
import pytest
|
||||
from PyQt5.QtTest import QSignalSpy
|
||||
from PyQt5.QtCore import QUrl
|
||||
|
||||
from qutebrowser.misc import autoupdate, httpclient
|
||||
|
||||
INVALID_JSON = ['{"invalid": { "json"}', '{"wrong": "keys"}']
|
||||
|
||||
|
||||
class HTTPGetStub(httpclient.HTTPClient):
|
||||
"""A stub class for HTTPClient.
|
||||
|
||||
Attributes:
|
||||
url: the last url used by get()
|
||||
_success: Wether get() will emit a success signal.
|
||||
"""
|
||||
|
||||
def __init__(self, success=True, json=None):
|
||||
super().__init__()
|
||||
self._success = success
|
||||
if json:
|
||||
self._json = json
|
||||
else:
|
||||
self._json = '{"info": {"version": "test"}}'
|
||||
|
||||
def get(self, url):
|
||||
self.url = url
|
||||
if self._success:
|
||||
self.success.emit(self._json)
|
||||
else:
|
||||
self.error.emit("error")
|
||||
|
||||
|
||||
def test_constructor():
|
||||
client = autoupdate.PyPIVersionClient()
|
||||
assert isinstance(client._client, httpclient.HTTPClient)
|
||||
|
||||
|
||||
def test_get_version_success(qtbot):
|
||||
"""Test get_version() when success is emitted."""
|
||||
http_stub = HTTPGetStub(success=True)
|
||||
client = autoupdate.PyPIVersionClient(client=http_stub)
|
||||
|
||||
# Use a spy to inspect the signal
|
||||
error_spy = QSignalSpy(client.error)
|
||||
|
||||
with qtbot.waitSignal(client.success, raising=True):
|
||||
client.get_version('test')
|
||||
|
||||
assert len(error_spy) == 0
|
||||
|
||||
assert http_stub.url == QUrl('https://pypi.python.org/pypi/test/json')
|
||||
|
||||
|
||||
def test_get_version_error(qtbot):
|
||||
"""Test get_version() when error is emitted."""
|
||||
http_stub = HTTPGetStub(success=False)
|
||||
client = autoupdate.PyPIVersionClient(client=http_stub)
|
||||
|
||||
# Use a spy to inspect the signal
|
||||
success_spy = QSignalSpy(client.success)
|
||||
|
||||
with qtbot.waitSignal(client.error, raising=True):
|
||||
client.get_version('test')
|
||||
|
||||
assert len(success_spy) == 0
|
||||
|
||||
|
||||
@pytest.mark.parametrize('json', INVALID_JSON)
|
||||
def test_invalid_json(qtbot, json):
|
||||
"""Test on_client_success() with invalid JSON."""
|
||||
http_stub = HTTPGetStub(json=json)
|
||||
client = autoupdate.PyPIVersionClient(client=http_stub)
|
||||
client.get_version('test')
|
||||
|
||||
# Use a spy to inspect the signal
|
||||
success_spy = QSignalSpy(client.success)
|
||||
|
||||
with qtbot.waitSignal(client.error, raising=True):
|
||||
client.get_version('test')
|
||||
|
||||
assert len(success_spy) == 0
|
Loading…
Reference in New Issue
Block a user