2014-06-23 19:44:21 +02:00
|
|
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
|
|
|
|
2015-01-03 15:51:31 +01:00
|
|
|
# Copyright 2014-2015 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
|
2014-06-23 19:44:21 +02:00
|
|
|
#
|
|
|
|
# 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/>.
|
|
|
|
|
|
|
|
# pylint: disable=invalid-name
|
|
|
|
|
|
|
|
"""Fake objects/stubs."""
|
2015-04-05 20:30:31 +02:00
|
|
|
|
2015-04-04 18:24:26 +02:00
|
|
|
import logging
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2014-08-26 19:10:14 +02:00
|
|
|
from unittest import mock
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
from PyQt5.QtCore import pyqtSignal, QPoint, QProcess, QObject
|
2014-08-12 09:03:38 +02:00
|
|
|
from PyQt5.QtNetwork import QNetworkRequest
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2014-12-17 11:17:18 +01:00
|
|
|
from qutebrowser.config import configexc
|
|
|
|
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
class ConfigStub:
|
|
|
|
|
|
|
|
"""Stub for basekeyparser.config.
|
|
|
|
|
|
|
|
Attributes:
|
|
|
|
data: The config data to return.
|
|
|
|
"""
|
|
|
|
|
2015-04-04 18:24:26 +02:00
|
|
|
def __init__(self, data=None):
|
|
|
|
self.data = data or {}
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
def section(self, name):
|
|
|
|
"""Get a section from the config.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
name: The section name to get.
|
|
|
|
|
|
|
|
Return:
|
|
|
|
The section as dict.
|
|
|
|
"""
|
|
|
|
return self.data[name]
|
|
|
|
|
|
|
|
def get(self, sect, opt):
|
|
|
|
"""Get a value from the config."""
|
2014-08-20 20:57:10 +02:00
|
|
|
data = self.data[sect]
|
2014-06-23 19:44:21 +02:00
|
|
|
try:
|
2014-08-20 20:57:10 +02:00
|
|
|
return data[opt]
|
2014-06-23 19:44:21 +02:00
|
|
|
except KeyError:
|
2014-12-17 11:17:18 +01:00
|
|
|
raise configexc.NoOptionError(opt, sect)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeKeyEvent:
|
|
|
|
|
|
|
|
"""Fake QKeyPressEvent stub."""
|
|
|
|
|
|
|
|
def __init__(self, key, modifiers=0, text=''):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.key = mock.Mock(return_value=key)
|
|
|
|
self.text = mock.Mock(return_value=text)
|
|
|
|
self.modifiers = mock.Mock(return_value=modifiers)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeWebFrame:
|
|
|
|
|
|
|
|
"""A stub for QWebFrame."""
|
|
|
|
|
|
|
|
def __init__(self, geometry, scroll=None, parent=None):
|
|
|
|
"""Constructor.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
geometry: The geometry of the frame as QRect.
|
|
|
|
scroll: The scroll position as QPoint.
|
|
|
|
parent: The parent frame.
|
|
|
|
"""
|
|
|
|
if scroll is None:
|
|
|
|
scroll = QPoint(0, 0)
|
2014-08-26 19:10:14 +02:00
|
|
|
self.geometry = mock.Mock(return_value=geometry)
|
|
|
|
self.scrollPosition = mock.Mock(return_value=scroll)
|
|
|
|
self.parentFrame = mock.Mock(return_value=parent)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeChildrenFrame:
|
|
|
|
|
|
|
|
"""A stub for QWebFrame to test get_child_frames."""
|
|
|
|
|
|
|
|
def __init__(self, children=None):
|
|
|
|
if children is None:
|
|
|
|
children = []
|
2014-08-26 19:10:14 +02:00
|
|
|
self.childFrames = mock.Mock(return_value=children)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeQApplication:
|
|
|
|
|
|
|
|
"""Stub to insert as QApplication module."""
|
|
|
|
|
2014-09-09 21:40:16 +02:00
|
|
|
def __init__(self):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.instance = mock.Mock(return_value=self)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeUrl:
|
|
|
|
|
|
|
|
"""QUrl stub which provides .path()."""
|
|
|
|
|
|
|
|
def __init__(self, path=None):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.path = mock.Mock(return_value=path)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeNetworkReply:
|
|
|
|
|
|
|
|
"""QNetworkReply stub which provides a Content-Disposition header."""
|
|
|
|
|
2014-08-12 09:03:38 +02:00
|
|
|
KNOWN_HEADERS = {
|
|
|
|
QNetworkRequest.ContentTypeHeader: 'Content-Type',
|
|
|
|
}
|
|
|
|
|
|
|
|
def __init__(self, headers=None, url=None):
|
2014-06-23 19:44:21 +02:00
|
|
|
if url is None:
|
|
|
|
url = FakeUrl()
|
2014-08-12 09:03:38 +02:00
|
|
|
if headers is None:
|
|
|
|
self.headers = {}
|
|
|
|
else:
|
|
|
|
self.headers = headers
|
2014-08-26 19:10:14 +02:00
|
|
|
self.url = mock.Mock(return_value=url)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
def hasRawHeader(self, name):
|
|
|
|
"""Check if the reply has a certain header.
|
|
|
|
|
|
|
|
Args:
|
2015-02-05 07:12:36 +01:00
|
|
|
name: The name of the header as ISO-8859-1 encoded bytes object.
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
Return:
|
|
|
|
True if the header is present, False if not.
|
|
|
|
"""
|
2015-02-05 07:12:36 +01:00
|
|
|
return name.decode('iso-8859-1') in self.headers
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
def rawHeader(self, name):
|
|
|
|
"""Get the raw header data of a header.
|
|
|
|
|
|
|
|
Args:
|
2015-02-05 07:12:36 +01:00
|
|
|
name: The name of the header as ISO-8859-1 encoded bytes object.
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
Return:
|
|
|
|
The header data, as ISO-8859-1 encoded bytes() object.
|
2014-08-12 09:03:38 +02:00
|
|
|
"""
|
2015-02-05 07:12:36 +01:00
|
|
|
name = name.decode('iso-8859-1')
|
2014-08-12 09:03:38 +02:00
|
|
|
return self.headers[name].encode('iso-8859-1')
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2014-08-12 09:03:38 +02:00
|
|
|
def header(self, known_header):
|
|
|
|
"""Get a known header.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
known_header: A QNetworkRequest::KnownHeaders member.
|
|
|
|
"""
|
|
|
|
key = self.KNOWN_HEADERS[known_header]
|
|
|
|
try:
|
|
|
|
return self.headers[key]
|
|
|
|
except KeyError:
|
|
|
|
return None
|
|
|
|
|
|
|
|
def setHeader(self, known_header, value):
|
|
|
|
"""Set a known header.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
known_header: A QNetworkRequest::KnownHeaders member.
|
|
|
|
value: The value to set.
|
2014-06-23 19:44:21 +02:00
|
|
|
"""
|
2014-08-12 09:03:38 +02:00
|
|
|
key = self.KNOWN_HEADERS[known_header]
|
|
|
|
self.headers[key] = value
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
2015-02-27 12:43:54 +01:00
|
|
|
class FakeQProcess(mock.Mock):
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
"""QProcess stub.
|
|
|
|
|
2015-02-27 12:43:54 +01:00
|
|
|
Gets some enum values from the real QProcess.
|
2014-06-23 19:44:21 +02:00
|
|
|
"""
|
|
|
|
|
|
|
|
NormalExit = QProcess.NormalExit
|
|
|
|
CrashExit = QProcess.CrashExit
|
|
|
|
|
|
|
|
FailedToStart = QProcess.FailedToStart
|
|
|
|
Crashed = QProcess.Crashed
|
|
|
|
Timedout = QProcess.Timedout
|
|
|
|
WriteError = QProcess.WriteError
|
|
|
|
ReadError = QProcess.ReadError
|
|
|
|
UnknownError = QProcess.UnknownError
|
|
|
|
|
|
|
|
|
|
|
|
class FakeSignal:
|
|
|
|
|
|
|
|
"""Fake pyqtSignal stub which uses a mock to see if it was called."""
|
|
|
|
|
|
|
|
def __init__(self, name='fake'):
|
|
|
|
self.signal = '2{}(int, int)'.format(name)
|
2014-08-05 14:14:16 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeCmdUtils:
|
|
|
|
|
|
|
|
"""Stub for cmdutils which provides a cmd_dict."""
|
|
|
|
|
|
|
|
def __init__(self, commands):
|
|
|
|
self.cmd_dict = commands
|
|
|
|
|
|
|
|
|
|
|
|
class FakeCommand:
|
|
|
|
|
|
|
|
"""A simple command stub which has a description."""
|
|
|
|
|
|
|
|
def __init__(self, desc):
|
|
|
|
self.desc = desc
|
2015-02-27 12:43:54 +01:00
|
|
|
|
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
class FakeTimer(QObject):
|
2015-02-27 12:43:54 +01:00
|
|
|
|
|
|
|
"""Stub for a usertypes.Timer."""
|
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
# pylint: disable=missing-docstring
|
|
|
|
|
|
|
|
timeout_signal = pyqtSignal()
|
|
|
|
|
2015-02-27 12:43:54 +01:00
|
|
|
def __init__(self, parent=None, name=None):
|
2015-03-01 21:29:27 +01:00
|
|
|
super().__init__(parent)
|
|
|
|
self.timeout = mock.Mock(spec=['connect', 'disconnect', 'emit'])
|
|
|
|
self.timeout.connect.side_effect = self.timeout_signal.connect
|
|
|
|
self.timeout.disconnect.side_effect = self.timeout_signal.disconnect
|
|
|
|
self.timeout.emit.side_effect = self._emit
|
|
|
|
self._started = False
|
|
|
|
self._singleshot = False
|
|
|
|
self._interval = 0
|
|
|
|
self._name = name
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return '<{} name={!r}>'.format(self.__class__.__name__, self._name)
|
|
|
|
|
|
|
|
def _emit(self):
|
|
|
|
"""Called when the timeout "signal" gets emitted."""
|
|
|
|
if self._singleshot:
|
|
|
|
self._started = False
|
|
|
|
self.timeout_signal.emit()
|
|
|
|
|
|
|
|
def setInterval(self, interval):
|
|
|
|
self._interval = interval
|
|
|
|
|
|
|
|
def interval(self):
|
|
|
|
return self._interval
|
|
|
|
|
|
|
|
def setSingleShot(self, singleshot):
|
|
|
|
self._singleshot = singleshot
|
|
|
|
|
2015-04-04 17:29:17 +02:00
|
|
|
def isSingleShot(self):
|
2015-03-01 21:29:27 +01:00
|
|
|
return self._singleshot
|
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self._started = True
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self._started = False
|
|
|
|
|
|
|
|
def isActive(self):
|
|
|
|
return self._started
|
2015-04-04 18:24:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
class MessageModule:
|
2015-04-05 20:30:31 +02:00
|
|
|
|
2015-04-04 18:24:26 +02:00
|
|
|
"""A drop-in replacement for qutebrowser.utils.message."""
|
|
|
|
|
|
|
|
def error(self, _win_id, message, _immediately=False):
|
|
|
|
"""Log an error to the message logger."""
|
|
|
|
logging.getLogger('message').error(message)
|
|
|
|
|
|
|
|
def warning(self, _win_id, message, _immediately=False):
|
|
|
|
"""Log a warning to the message logger."""
|
|
|
|
logging.getLogger('message').warning(message)
|
|
|
|
|
|
|
|
def info(self, _win_id, message, _immediately=True):
|
|
|
|
"""Log an info message to the message logger."""
|
2015-04-05 20:30:31 +02:00
|
|
|
logging.getLogger('message').info(message)
|