Merge branch 'acogneau-autoupdate_tests'

This commit is contained in:
Florian Bruhin 2015-09-01 08:49:53 +02:00
commit 44f594662a
4 changed files with 110 additions and 3 deletions

View File

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

View File

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

View File

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

View 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